|
|
|
@ -20,8 +20,7 @@ Extras
@@ -20,8 +20,7 @@ Extras
|
|
|
|
|
|
|
|
|
|
EOF |
|
|
|
|
|
|
|
|
|
test_expect_success 'test --parseopt help output' ' |
|
|
|
|
git rev-parse --parseopt -- -h 2> output.err <<EOF |
|
|
|
|
cat > optionspec << EOF |
|
|
|
|
some-command [options] <args>... |
|
|
|
|
|
|
|
|
|
some-command does foo and bar! |
|
|
|
@ -37,7 +36,42 @@ C? option C with an optional argument
@@ -37,7 +36,42 @@ C? option C with an optional argument
|
|
|
|
|
Extras |
|
|
|
|
extra1 line above used to cause a segfault but no longer does |
|
|
|
|
EOF |
|
|
|
|
|
|
|
|
|
test_expect_success 'test --parseopt help output' ' |
|
|
|
|
git rev-parse --parseopt -- -h 2> output.err < optionspec |
|
|
|
|
test_cmp expect.err output.err |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
cat > expect <<EOF |
|
|
|
|
set -- --foo --bar 'ham' -- 'arg' |
|
|
|
|
EOF |
|
|
|
|
|
|
|
|
|
test_expect_success 'test --parseopt' ' |
|
|
|
|
git rev-parse --parseopt -- --foo --bar=ham arg < optionspec > output && |
|
|
|
|
test_cmp expect output |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
test_expect_success 'test --parseopt with mixed options and arguments' ' |
|
|
|
|
git rev-parse --parseopt -- --foo arg --bar=ham < optionspec > output && |
|
|
|
|
test_cmp expect output |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
cat > expect <<EOF |
|
|
|
|
set -- --foo -- 'arg' '--bar=ham' |
|
|
|
|
EOF |
|
|
|
|
|
|
|
|
|
test_expect_success 'test --parseopt with --' ' |
|
|
|
|
git rev-parse --parseopt -- --foo -- arg --bar=ham < optionspec > output && |
|
|
|
|
test_cmp expect output |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
cat > expect <<EOF |
|
|
|
|
set -- --foo -- '--' 'arg' '--bar=ham' |
|
|
|
|
EOF |
|
|
|
|
|
|
|
|
|
test_expect_success 'test --parseopt --keep-dashdash' ' |
|
|
|
|
git rev-parse --parseopt --keep-dashdash -- --foo -- arg --bar=ham < optionspec > output && |
|
|
|
|
test_cmp expect output |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
test_done |
|
|
|
|