about summary refs log tree commit diff
path: root/third_party/git/t/t1310-config-default.sh
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/git/t/t1310-config-default.sh')
-rwxr-xr-xthird_party/git/t/t1310-config-default.sh36
1 files changed, 36 insertions, 0 deletions
diff --git a/third_party/git/t/t1310-config-default.sh b/third_party/git/t/t1310-config-default.sh
new file mode 100755
index 000000000000..6049d9170814
--- /dev/null
+++ b/third_party/git/t/t1310-config-default.sh
@@ -0,0 +1,36 @@
+#!/bin/sh
+
+test_description='Test git config in different settings (with --default)'
+
+. ./test-lib.sh
+
+test_expect_success 'uses --default when entry missing' '
+	echo quux >expect &&
+	git config -f config --default=quux core.foo >actual &&
+	test_cmp expect actual
+'
+
+test_expect_success 'does not use --default when entry present' '
+	echo bar >expect &&
+	git -c core.foo=bar config --default=baz core.foo >actual &&
+	test_cmp expect actual
+'
+
+test_expect_success 'canonicalizes --default with appropriate type' '
+	echo true >expect &&
+	git config -f config --default=yes --bool core.foo >actual &&
+	test_cmp expect actual
+'
+
+test_expect_success 'dies when --default cannot be parsed' '
+	test_must_fail git config -f config --type=expiry-date --default=x --get \
+		not.a.section 2>error &&
+	test_i18ngrep "failed to format default config value" error
+'
+
+test_expect_success 'does not allow --default without --get' '
+	test_must_fail git config --default=quux --unset a.section >output 2>&1 &&
+	test_i18ngrep "\-\-default is only applicable to" output
+'
+
+test_done