git/t/t1307-config-blob.sh
Vasco Almeida 1edbaac3bb tests: use test_i18n* functions to suppress false positives
The test functions test_i18ncmp and test_i18ngrep pretend success if run
under GETTEXT_POISON. By using those functions to test output which is
correctly marked as translatable, enables one to detect if the strings
newly marked for translation are from plumbing output. If they are
indeed from plumbing, the test would fail, and the string should be
unmarked, since it is not seen by users.

Thus, it is productive to not have false positives when running the test
under GETTEXT_POISON. This commit replaces normal test functions by
their i18n aware variants in use-cases know to be correctly marked for
translation, suppressing false positives.

Signed-off-by: Vasco Almeida <vascomalmeida@sapo.pt>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2016-06-17 15:45:48 -07:00

77 lines
1.9 KiB
Bash
Executable File

#!/bin/sh
test_description='support for reading config from a blob'
. ./test-lib.sh
test_expect_success 'create config blob' '
cat >config <<-\EOF &&
[some]
value = 1
EOF
git add config &&
git commit -m foo
'
test_expect_success 'list config blob contents' '
echo some.value=1 >expect &&
git config --blob=HEAD:config --list >actual &&
test_cmp expect actual
'
test_expect_success 'fetch value from blob' '
echo true >expect &&
git config --blob=HEAD:config --bool some.value >actual &&
test_cmp expect actual
'
test_expect_success 'reading non-existing value from blob is an error' '
test_must_fail git config --blob=HEAD:config non.existing
'
test_expect_success 'reading from blob and file is an error' '
test_must_fail git config --blob=HEAD:config --system --list
'
test_expect_success 'reading from missing ref is an error' '
test_must_fail git config --blob=HEAD:doesnotexist --list
'
test_expect_success 'reading from non-blob is an error' '
test_must_fail git config --blob=HEAD --list
'
test_expect_success 'setting a value in a blob is an error' '
test_must_fail git config --blob=HEAD:config some.value foo
'
test_expect_success 'deleting a value in a blob is an error' '
test_must_fail git config --blob=HEAD:config --unset some.value
'
test_expect_success 'editing a blob is an error' '
test_must_fail git config --blob=HEAD:config --edit
'
test_expect_success 'parse errors in blobs are properly attributed' '
cat >config <<-\EOF &&
[some]
value = "
EOF
git add config &&
git commit -m broken &&
test_must_fail git config --blob=HEAD:config some.value 2>err &&
test_i18ngrep "HEAD:config" err
'
test_expect_success 'can parse blob ending with CR' '
printf "[some]key = value\\r" >config &&
git add config &&
git commit -m CR &&
echo value >expect &&
git config --blob=HEAD:config some.key >actual &&
test_cmp expect actual
'
test_done