 3af828634f
			
		
	
	3af828634f
	
	
	
		
			
			As a general principle, we should not use "git diff" to validate the results of what git command that is being tested has done. We would not know if we are testing the command in question, or locating a bug in the cute hack of "git diff --no-index". Rather use test_cmp for that purpose. Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			159 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| #
 | |
| # Copyright (c) 2005 Junio C Hamano
 | |
| #
 | |
| 
 | |
| test_description='git ls-tree test.
 | |
| 
 | |
| This test runs git ls-tree with the following in a tree.
 | |
| 
 | |
|     path0       - a file
 | |
|     path1	- a symlink
 | |
|     path2/foo   - a file in a directory
 | |
|     path2/bazbo - a symlink in a directory
 | |
|     path2/baz/b - a file in a directory in a directory
 | |
| 
 | |
| The new path restriction code should do the right thing for path2 and
 | |
| path2/baz.  Also path0/ should snow nothing.
 | |
| '
 | |
| . ./test-lib.sh
 | |
| 
 | |
| test_expect_success \
 | |
|     'setup' \
 | |
|     'mkdir path2 path2/baz &&
 | |
|      echo Hi >path0 &&
 | |
|      ln -s path0 path1 &&
 | |
|      echo Lo >path2/foo &&
 | |
|      ln -s ../path1 path2/bazbo &&
 | |
|      echo Mi >path2/baz/b &&
 | |
|      find path? \( -type f -o -type l \) -print |
 | |
|      xargs git update-index --add &&
 | |
|      tree=`git write-tree` &&
 | |
|      echo $tree'
 | |
| 
 | |
| _x40='[0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f]'
 | |
| _x40="$_x40$_x40$_x40$_x40$_x40$_x40$_x40$_x40"
 | |
| test_output () {
 | |
|     sed -e "s/ $_x40	/ X	/" <current >check
 | |
|     test_cmp expected check
 | |
| }
 | |
| 
 | |
| test_expect_success \
 | |
|     'ls-tree plain' \
 | |
|     'git ls-tree $tree >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| 100644 blob X	path0
 | |
| 120000 blob X	path1
 | |
| 040000 tree X	path2
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| test_expect_success \
 | |
|     'ls-tree recursive' \
 | |
|     'git ls-tree -r $tree >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| 100644 blob X	path0
 | |
| 120000 blob X	path1
 | |
| 100644 blob X	path2/baz/b
 | |
| 120000 blob X	path2/bazbo
 | |
| 100644 blob X	path2/foo
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| test_expect_success \
 | |
|     'ls-tree recursive with -t' \
 | |
|     'git ls-tree -r -t $tree >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| 100644 blob X	path0
 | |
| 120000 blob X	path1
 | |
| 040000 tree X	path2
 | |
| 040000 tree X	path2/baz
 | |
| 100644 blob X	path2/baz/b
 | |
| 120000 blob X	path2/bazbo
 | |
| 100644 blob X	path2/foo
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| test_expect_success \
 | |
|     'ls-tree recursive with -d' \
 | |
|     'git ls-tree -r -d $tree >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| 040000 tree X	path2
 | |
| 040000 tree X	path2/baz
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| test_expect_success \
 | |
|     'ls-tree filtered with path' \
 | |
|     'git ls-tree $tree path >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| 
 | |
| # it used to be path1 and then path0, but with pathspec semantics
 | |
| # they are shown in canonical order.
 | |
| test_expect_success \
 | |
|     'ls-tree filtered with path1 path0' \
 | |
|     'git ls-tree $tree path1 path0 >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| 100644 blob X	path0
 | |
| 120000 blob X	path1
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| test_expect_success \
 | |
|     'ls-tree filtered with path0/' \
 | |
|     'git ls-tree $tree path0/ >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| # It used to show path2 and its immediate children but
 | |
| # with pathspec semantics it shows only path2
 | |
| test_expect_success \
 | |
|     'ls-tree filtered with path2' \
 | |
|     'git ls-tree $tree path2 >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| 040000 tree X	path2
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| # ... and path2/ shows the children.
 | |
| test_expect_success \
 | |
|     'ls-tree filtered with path2/' \
 | |
|     'git ls-tree $tree path2/ >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| 040000 tree X	path2/baz
 | |
| 120000 blob X	path2/bazbo
 | |
| 100644 blob X	path2/foo
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| # The same change -- exact match does not show children of
 | |
| # path2/baz
 | |
| test_expect_success \
 | |
|     'ls-tree filtered with path2/baz' \
 | |
|     'git ls-tree $tree path2/baz >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| 040000 tree X	path2/baz
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| test_expect_success \
 | |
|     'ls-tree filtered with path2/bak' \
 | |
|     'git ls-tree $tree path2/bak >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| test_expect_success \
 | |
|     'ls-tree -t filtered with path2/bak' \
 | |
|     'git ls-tree -t $tree path2/bak >current &&
 | |
|      cat >expected <<\EOF &&
 | |
| 040000 tree X	path2
 | |
| EOF
 | |
|      test_output'
 | |
| 
 | |
| test_done
 |