t / t3101-ls-tree-dirname.shon commit Merge branch 'maint' (b895076)
   1#!/bin/sh
   2#
   3# Copyright (c) 2005 Junio C Hamano
   4# Copyright (c) 2005 Robert Fitzsimons
   5#
   6
   7test_description='git-ls-tree directory and filenames handling.
   8
   9This test runs git-ls-tree with the following in a tree.
  10
  11    1.txt              - a file
  12    2.txt              - a file
  13    path0/a/b/c/1.txt  - a file in a directory
  14    path1/b/c/1.txt    - a file in a directory
  15    path2/1.txt        - a file in a directory
  16    path3/1.txt        - a file in a directory
  17    path3/2.txt        - a file in a directory
  18
  19Test the handling of mulitple directories which have matching file
  20entries.  Also test odd filename and missing entries handling.
  21'
  22. ./test-lib.sh
  23
  24test_expect_success \
  25    'setup' \
  26    'echo 111 >1.txt &&
  27     echo 222 >2.txt &&
  28     mkdir path0 path0/a path0/a/b path0/a/b/c &&
  29     echo 111 >path0/a/b/c/1.txt &&
  30     mkdir path1 path1/b path1/b/c &&
  31     echo 111 >path1/b/c/1.txt &&
  32     mkdir path2 &&
  33     echo 111 >path2/1.txt &&
  34     mkdir path3 &&
  35     echo 111 >path3/1.txt &&
  36     echo 222 >path3/2.txt &&
  37     find *.txt path* \( -type f -o -type l \) -print |
  38     xargs git-update-index --add &&
  39     tree=`git-write-tree` &&
  40     echo $tree'
  41
  42_x40='[0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f]'
  43_x40="$_x40$_x40$_x40$_x40$_x40$_x40$_x40$_x40"
  44test_output () {
  45    sed -e "s/ $_x40    / X     /" <current >check
  46    diff -u expected check
  47}
  48
  49test_expect_success \
  50    'ls-tree plain' \
  51    'git-ls-tree $tree >current &&
  52     cat >expected <<\EOF &&
  53100644 blob X   1.txt
  54100644 blob X   2.txt
  55040000 tree X   path0
  56040000 tree X   path1
  57040000 tree X   path2
  58040000 tree X   path3
  59EOF
  60     test_output'
  61
  62# Recursive does not show tree nodes anymore...
  63test_expect_success \
  64    'ls-tree recursive' \
  65    'git-ls-tree -r $tree >current &&
  66     cat >expected <<\EOF &&
  67100644 blob X   1.txt
  68100644 blob X   2.txt
  69100644 blob X   path0/a/b/c/1.txt
  70100644 blob X   path1/b/c/1.txt
  71100644 blob X   path2/1.txt
  72100644 blob X   path3/1.txt
  73100644 blob X   path3/2.txt
  74EOF
  75     test_output'
  76
  77test_expect_success \
  78    'ls-tree filter 1.txt' \
  79    'git-ls-tree $tree 1.txt >current &&
  80     cat >expected <<\EOF &&
  81100644 blob X   1.txt
  82EOF
  83     test_output'
  84
  85test_expect_success \
  86    'ls-tree filter path1/b/c/1.txt' \
  87    'git-ls-tree $tree path1/b/c/1.txt >current &&
  88     cat >expected <<\EOF &&
  89100644 blob X   path1/b/c/1.txt
  90EOF
  91     test_output'
  92
  93test_expect_success \
  94    'ls-tree filter all 1.txt files' \
  95    'git-ls-tree $tree 1.txt path0/a/b/c/1.txt path1/b/c/1.txt path2/1.txt path3/1.txt >current &&
  96     cat >expected <<\EOF &&
  97100644 blob X   1.txt
  98100644 blob X   path0/a/b/c/1.txt
  99100644 blob X   path1/b/c/1.txt
 100100644 blob X   path2/1.txt
 101100644 blob X   path3/1.txt
 102EOF
 103     test_output'
 104
 105# I am not so sure about this one after ls-tree doing pathspec match.
 106# Having both path0/a and path0/a/b/c makes path0/a redundant, and
 107# it behaves as if path0/a/b/c, path1/b/c, path2 and path3 are specified.
 108test_expect_success \
 109    'ls-tree filter directories' \
 110    'git-ls-tree $tree path3 path2 path0/a/b/c path1/b/c path0/a >current &&
 111     cat >expected <<\EOF &&
 112040000 tree X   path0/a/b/c
 113040000 tree X   path1/b/c
 114040000 tree X   path2
 115040000 tree X   path3
 116EOF
 117     test_output'
 118
 119# Again, duplicates are filtered away so this is equivalent to
 120# having 1.txt and path3
 121test_expect_success \
 122    'ls-tree filter odd names' \
 123    'git-ls-tree $tree 1.txt /1.txt //1.txt path3/1.txt /path3/1.txt //path3//1.txt path3 /path3/ path3// >current &&
 124     cat >expected <<\EOF &&
 125100644 blob X   1.txt
 126100644 blob X   path3/1.txt
 127100644 blob X   path3/2.txt
 128EOF
 129     test_output'
 130
 131test_expect_success \
 132    'ls-tree filter missing files and extra slashes' \
 133    'git-ls-tree $tree 1.txt/ abc.txt path3//23.txt path3/2.txt/// >current &&
 134     cat >expected <<\EOF &&
 135EOF
 136     test_output'
 137
 138test_done