3 test_description
='help'
8 test_config
help.format html
&&
10 # Unless the path has "://" in it, Git tries to make sure
11 # the documentation directory locally exists. Avoid it as
12 # we are only interested in seeing an attempt to correctly
13 # invoke a help browser in this test.
14 test_config
help.htmlpath
test://html
&&
16 # Name a custom browser
17 test_config browser.
test.cmd .
/test-browser
&&
18 test_config
help.browser
test
21 test_expect_success
"setup" '
22 # Just write out which page gets requested
23 write_script test-browser <<-\EOF
24 echo "$*" >test-browser.log
28 # make sure to exercise these code paths, the output is a bit tricky
30 test_expect_success
'basic help commands' '
31 git help >/dev/null &&
32 git help -a --no-verbose >/dev/null &&
33 git help -g >/dev/null &&
34 git help -a >/dev/null
37 test_expect_success
'invalid usage' '
38 test_expect_code 129 git help -g add &&
39 test_expect_code 129 git help -a -c &&
41 test_expect_code 129 git help -g add &&
42 test_expect_code 129 git help -a -g &&
44 test_expect_code 129 git help -g -c &&
45 test_expect_code 129 git help --config-for-completion add &&
46 test_expect_code 129 git help --config-sections-for-completion add
49 test_expect_success
"works for commands and guides by default" '
52 echo "test://html/git-status.html" >expect &&
53 test_cmp expect test-browser.log &&
55 echo "test://html/gitrevisions.html" >expect &&
56 test_cmp expect test-browser.log
59 test_expect_success
"--exclude-guides does not work for guides" '
61 test_must_fail git help --exclude-guides revisions &&
62 test_must_be_empty test-browser.log
65 test_expect_success
"--help does not work for guides" "
67 git: 'revisions' is not a git command. See 'git --help'.
69 test_must_fail git revisions --help 2>actual &&
70 test_cmp expect actual
73 test_expect_success
'git help' '
74 git help >help.output &&
75 test_i18ngrep "^ clone " help.output &&
76 test_i18ngrep "^ add " help.output &&
77 test_i18ngrep "^ log " help.output &&
78 test_i18ngrep "^ commit " help.output &&
79 test_i18ngrep "^ fetch " help.output
81 test_expect_success
'git help -g' '
82 git help -g >help.output &&
83 test_i18ngrep "^ attributes " help.output &&
84 test_i18ngrep "^ everyday " help.output &&
85 test_i18ngrep "^ tutorial " help.output
88 test_expect_success
'git help fails for non-existing html pages' '
91 test_must_fail git -c help.htmlpath=html-empty help status &&
92 test_must_be_empty test-browser.log
95 test_expect_success
'git help succeeds without git.html' '
97 mkdir html-with-docs &&
98 touch html-with-docs/git-status.html &&
99 git -c help.htmlpath=html-with-docs help status &&
100 echo "html-with-docs/git-status.html" >expect &&
101 test_cmp expect test-browser.log
104 test_expect_success
'git help -c' '
105 git help -c >help.output &&
106 cat >expect <<-\EOF &&
108 '\''git help config'\'' for more information
111 -e "^[^.]+\.[^.]+$" \
112 -e "^[^.]+\.[^.]+\.[^.]+$" \
113 help.output >actual &&
114 test_cmp expect actual
117 test_expect_success
'git help --config-for-completion' '
118 git help -c >human &&
120 -e "^[^.]+\.[^.]+$" \
121 -e "^[^.]+\.[^.]+\.[^.]+$" human |
122 sed -e "s/\*.*//" -e "s/<.*//" |
123 sort -u >human.munged &&
125 git help --config-for-completion >vars &&
126 test_cmp human.munged vars
129 test_expect_success
'git help --config-sections-for-completion' '
130 git help -c >human &&
132 -e "^[^.]+\.[^.]+$" \
133 -e "^[^.]+\.[^.]+\.[^.]+$" human |
135 sort -u >human.munged &&
137 git help --config-sections-for-completion >sections &&
138 test_cmp human.munged sections
141 test_expect_success
'generate builtin list' '
142 git --list-cmds=builtins >builtins
147 test_expect_success
"$builtin can handle -h" '
148 test_expect_code 129 git $builtin -h >output 2>&1 &&
149 test_i18ngrep usage output