| #!/bin/sh | 
 | # | 
 | # Copyright (c) 2007 Johannes Sixt | 
 | # | 
 |  | 
 | test_description='merging symlinks on filesystem w/o symlink support. | 
 |  | 
 | This tests that git merge-recursive writes merge results as plain files | 
 | if core.symlinks is false.' | 
 |  | 
 | . ./test-lib.sh | 
 |  | 
 | test_expect_success \ | 
 | 'setup' ' | 
 | git config core.symlinks false && | 
 | > file && | 
 | git add file && | 
 | git commit -m initial && | 
 | git branch b-symlink && | 
 | git branch b-file && | 
 | l=$(printf file | git hash-object -t blob -w --stdin) && | 
 | echo "120000 $l	symlink" | git update-index --index-info && | 
 | git commit -m master && | 
 | git checkout b-symlink && | 
 | l=$(printf file-different | git hash-object -t blob -w --stdin) && | 
 | echo "120000 $l	symlink" | git update-index --index-info && | 
 | git commit -m b-symlink && | 
 | git checkout b-file && | 
 | echo plain-file > symlink && | 
 | git add symlink && | 
 | git commit -m b-file' | 
 |  | 
 | test_expect_success \ | 
 | 'merge master into b-symlink, which has a different symbolic link' ' | 
 | git checkout b-symlink && | 
 | test_must_fail git merge master' | 
 |  | 
 | test_expect_success \ | 
 | 'the merge result must be a file' ' | 
 | test -f symlink' | 
 |  | 
 | test_expect_success \ | 
 | 'merge master into b-file, which has a file instead of a symbolic link' ' | 
 | git reset --hard && git checkout b-file && | 
 | test_must_fail git merge master' | 
 |  | 
 | test_expect_success \ | 
 | 'the merge result must be a file' ' | 
 | test -f symlink' | 
 |  | 
 | test_expect_success \ | 
 | 'merge b-file, which has a file instead of a symbolic link, into master' ' | 
 | git reset --hard && | 
 | git checkout master && | 
 | test_must_fail git merge b-file' | 
 |  | 
 | test_expect_success \ | 
 | 'the merge result must be a file' ' | 
 | test -f symlink' | 
 |  | 
 | test_done |