diff --git a/tests/commit.bats b/tests/commit.bats index 646138c..e033f4a 100644 --- a/tests/commit.bats +++ b/tests/commit.bats @@ -308,3 +308,46 @@ main() { } +@test "can-checkout-different-branch" { + + INPUT_BRANCH="foo" + + touch "${test_repository}"/new-file-{1,2,3}.txt + + shellmock_expect git --type partial --output " M new-file-1.txt M new-file-2.txt M new-file-3.txt" --match "status" + shellmock_expect git --type exact --match "fetch" + shellmock_expect git --type exact --match "checkout foo" + shellmock_expect git --type partial --match "add ." + shellmock_expect git --type partial --match '-c' + shellmock_expect git --type partial --match 'push --set-upstream origin' + + run main + + echo "$output" + + # Success Exit Code + [ "$status" = 0 ] + + [ "${lines[0]}" = "INPUT_REPOSITORY value: ${INPUT_REPOSITORY}" ] + [ "${lines[1]}" = "::set-output name=changes_detected::true" ] + [ "${lines[2]}" = "INPUT_BRANCH value: foo" ] + [ "${lines[3]}" = "INPUT_FILE_PATTERN: ." ] + [ "${lines[4]}" = "INPUT_COMMIT_OPTIONS: " ] + [ "${lines[5]}" = "::debug::Apply commit options " ] + [ "${lines[6]}" = "INPUT_TAGGING_MESSAGE: " ] + [ "${lines[7]}" = "No tagging message supplied. No tag will be added." ] + [ "${lines[8]}" = "INPUT_PUSH_OPTIONS: " ] + [ "${lines[9]}" = "::debug::Apply push options " ] + [ "${lines[10]}" = "::debug::Push commit to remote branch foo" ] + + + shellmock_verify + [ "${capture[0]}" = "git-stub status -s -- ." ] + [ "${capture[1]}" = "git-stub fetch" ] + [ "${capture[2]}" = "git-stub checkout foo" ] + [ "${capture[3]}" = "git-stub add ." ] + [ "${capture[4]}" = "git-stub -c user.name=Test Suite -c user.email=test@github.com commit -m Commit Message --author=Test Suite " ] + [ "${capture[5]}" = "git-stub push --set-upstream origin HEAD:foo --tags" ] + +} +