1#!/bin/sh 2# 3# Copyright (c) 2005 Junio C Hamano 4# 5 6test_description='git-checkout-cache test. 7 8This test registers the following filesystem structure in the cache: 9 10 path0/file0 - a file in a directory 11 path1/file1 - a file in a directory 12 13and attempts to check it out when the work tree has: 14 15 path0/file0 - a file in a directory 16 path1 - a symlink pointing at "path0" 17 18Checkout cache should fail to extract path1/file1 because the leading 19path path1 is occupied by a non-directory. With "-f" it should remove 20the symlink path1 and create directory path1 and file path1/file1. 21' 22. ./test-lib.sh 23 24show_files() { 25# show filesystem files, just [-dl] for type and name 26find path? -ls| 27sed-e's/^[0-9]* * [0-9]* * \([-bcdl]\)[^ ]* *[0-9]* *[^ ]* *[^ ]* *[0-9]* [A-Z][a-z][a-z] [0-9][0-9] [^ ]* /fs: \1 /' 28# what's in the cache, just mode and name 29 git-ls-files --stage| 30sed-e's/^\([0-9]*\) [0-9a-f]* [0-3] /ca: \1 /' 31# what's in the tree, just mode and name. 32 git-ls-tree -r"$1"| 33sed-e's/^\([0-9]*\) [^ ]* [0-9a-f]* /tr: \1 /' 34} 35 36mkdir path0 37date>path0/file0 38test_expect_success \ 39'git-update-cache --add path0/file0' \ 40'git-update-cache --add path0/file0' 41test_expect_success \ 42'writing tree out with git-write-tree' \ 43'tree1=$(git-write-tree)' 44test_debug 'show_files$tree1' 45 46mkdir path1 47date>path1/file1 48test_expect_success \ 49'git-update-cache --add path1/file1' \ 50'git-update-cache --add path1/file1' 51test_expect_success \ 52'writing tree out with git-write-tree' \ 53'tree2=$(git-write-tree)' 54test_debug 'show_files$tree2' 55 56rm-fr path1 57test_expect_success \ 58'read previously written tree and checkout.' \ 59'git-read-tree -m$tree1&& git-checkout-cache -f -a' 60test_debug 'show_files$tree1' 61 62ln-s path0 path1 63test_expect_success \ 64'git-update-cache --add a symlink.' \ 65'git-update-cache --add path1' 66test_expect_success \ 67'writing tree out with git-write-tree' \ 68'tree3=$(git-write-tree)' 69test_debug 'show_files$tree3' 70 71# Morten says "Got that?" here. 72# Test begins. 73 74test_expect_success \ 75'read previously written tree and checkout.' \ 76'git-read-tree$tree2&& git-checkout-cache -f -a' 77test_debug show_files $tree2 78 79test_expect_success \ 80'checking out conflicting path with -f' \ 81'test ! -h path0 && test -d path0 && 82 test ! -h path1 && test -d path1 && 83 test ! -h path0/file0 && test -f path0/file0 && 84 test ! -h path1/file1 && test -f path1/file1' 85 86test_done 87