|  | #!/bin/sh | 
|  |  | 
|  | test_description='unpack-trees error messages' | 
|  |  | 
|  | GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main | 
|  | export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME | 
|  |  | 
|  | TEST_PASSES_SANITIZE_LEAK=true | 
|  | . ./test-lib.sh | 
|  |  | 
|  |  | 
|  | test_expect_success 'setup' ' | 
|  | echo one >one && | 
|  | git add one && | 
|  | git commit -a -m First && | 
|  |  | 
|  | git checkout -b branch && | 
|  | echo two >two && | 
|  | echo three >three && | 
|  | echo four >four && | 
|  | echo five >five && | 
|  | git add two three four five && | 
|  | git commit -m Second && | 
|  |  | 
|  | git checkout main && | 
|  | echo other >two && | 
|  | echo other >three && | 
|  | echo other >four && | 
|  | echo other >five | 
|  | ' | 
|  |  | 
|  | cat >expect <<\EOF | 
|  | error: The following untracked working tree files would be overwritten by merge: | 
|  | five | 
|  | four | 
|  | three | 
|  | two | 
|  | Please move or remove them before you merge. | 
|  | Aborting | 
|  | EOF | 
|  |  | 
|  | test_expect_success 'untracked files overwritten by merge (fast and non-fast forward)' ' | 
|  | test_must_fail git merge branch 2>out && | 
|  | test_cmp out expect && | 
|  | git commit --allow-empty -m empty && | 
|  | ( | 
|  | GIT_MERGE_VERBOSITY=0 && | 
|  | export GIT_MERGE_VERBOSITY && | 
|  | test_must_fail git merge branch 2>out2 | 
|  | ) && | 
|  | echo "Merge with strategy ${GIT_TEST_MERGE_ALGORITHM:-ort} failed." >>expect && | 
|  | test_cmp out2 expect && | 
|  | git reset --hard HEAD^ | 
|  | ' | 
|  |  | 
|  | cat >expect <<\EOF | 
|  | error: Your local changes to the following files would be overwritten by merge: | 
|  | four | 
|  | three | 
|  | two | 
|  | Please commit your changes or stash them before you merge. | 
|  | error: The following untracked working tree files would be overwritten by merge: | 
|  | five | 
|  | Please move or remove them before you merge. | 
|  | Aborting | 
|  | EOF | 
|  |  | 
|  | test_expect_success 'untracked files or local changes ovewritten by merge' ' | 
|  | git add two && | 
|  | git add three && | 
|  | git add four && | 
|  | test_must_fail git merge branch 2>out && | 
|  | test_cmp out expect | 
|  | ' | 
|  |  | 
|  | cat >expect <<\EOF | 
|  | error: Your local changes to the following files would be overwritten by checkout: | 
|  | rep/one | 
|  | rep/two | 
|  | Please commit your changes or stash them before you switch branches. | 
|  | Aborting | 
|  | EOF | 
|  |  | 
|  | test_expect_success 'cannot switch branches because of local changes' ' | 
|  | git add five && | 
|  | mkdir rep && | 
|  | echo one >rep/one && | 
|  | echo two >rep/two && | 
|  | git add rep/one rep/two && | 
|  | git commit -m Fourth && | 
|  | git checkout main && | 
|  | echo uno >rep/one && | 
|  | echo dos >rep/two && | 
|  | test_must_fail git checkout branch 2>out && | 
|  | test_cmp out expect | 
|  | ' | 
|  |  | 
|  | cat >expect <<\EOF | 
|  | error: Your local changes to the following files would be overwritten by checkout: | 
|  | rep/one | 
|  | rep/two | 
|  | Please commit your changes or stash them before you switch branches. | 
|  | Aborting | 
|  | EOF | 
|  |  | 
|  | test_expect_success 'not uptodate file porcelain checkout error' ' | 
|  | git add rep/one rep/two && | 
|  | test_must_fail git checkout branch 2>out && | 
|  | test_cmp out expect | 
|  | ' | 
|  |  | 
|  | cat >expect <<\EOF | 
|  | error: Updating the following directories would lose untracked files in them: | 
|  | rep | 
|  | rep2 | 
|  |  | 
|  | Aborting | 
|  | EOF | 
|  |  | 
|  | test_expect_success 'not_uptodate_dir porcelain checkout error' ' | 
|  | git init uptodate && | 
|  | cd uptodate && | 
|  | mkdir rep && | 
|  | mkdir rep2 && | 
|  | touch rep/foo && | 
|  | touch rep2/foo && | 
|  | git add rep/foo rep2/foo && | 
|  | git commit -m init && | 
|  | git checkout -b branch && | 
|  | git rm rep -r && | 
|  | git rm rep2 -r && | 
|  | >rep && | 
|  | >rep2 && | 
|  | git add rep rep2 && | 
|  | git commit -m "added test as a file" && | 
|  | git checkout main && | 
|  | >rep/untracked-file && | 
|  | >rep2/untracked-file && | 
|  | test_must_fail git checkout branch 2>out && | 
|  | test_cmp out ../expect | 
|  | ' | 
|  |  | 
|  | test_done |