t / t4114-apply-typechange.shon commit Merge branch 'cj/doc-format' (477fde6)
   1#!/bin/sh
   2#
   3# Copyright (c) 2006 Eric Wong
   4#
   5
   6test_description='git apply should not get confused with type changes.
   7
   8'
   9
  10. ./test-lib.sh
  11
  12if ! test_have_prereq SYMLINKS
  13then
  14        say 'Symbolic links not supported, skipping tests.'
  15        test_done
  16        exit
  17fi
  18
  19test_expect_success 'setup repository and commits' '
  20        echo "hello world" > foo &&
  21        echo "hi planet" > bar &&
  22        git update-index --add foo bar &&
  23        git commit -m initial &&
  24        git branch initial &&
  25        rm -f foo &&
  26        ln -s bar foo &&
  27        git update-index foo &&
  28        git commit -m "foo symlinked to bar" &&
  29        git branch foo-symlinked-to-bar &&
  30        rm -f foo &&
  31        echo "how far is the sun?" > foo &&
  32        git update-index foo &&
  33        git commit -m "foo back to file" &&
  34        git branch foo-back-to-file &&
  35        printf "\0" > foo &&
  36        git update-index foo &&
  37        git commit -m "foo becomes binary" &&
  38        git branch foo-becomes-binary &&
  39        rm -f foo &&
  40        git update-index --remove foo &&
  41        mkdir foo &&
  42        echo "if only I knew" > foo/baz &&
  43        git update-index --add foo/baz &&
  44        git commit -m "foo becomes a directory" &&
  45        git branch "foo-becomes-a-directory" &&
  46        echo "hello world" > foo/baz &&
  47        git update-index foo/baz &&
  48        git commit -m "foo/baz is the original foo" &&
  49        git branch foo-baz-renamed-from-foo
  50        '
  51
  52test_expect_success 'file renamed from foo to foo/baz' '
  53        git checkout -f initial &&
  54        git diff-tree -M -p HEAD foo-baz-renamed-from-foo > patch &&
  55        git apply --index < patch
  56        '
  57test_debug 'cat patch'
  58
  59
  60test_expect_success 'file renamed from foo/baz to foo' '
  61        git checkout -f foo-baz-renamed-from-foo &&
  62        git diff-tree -M -p HEAD initial > patch &&
  63        git apply --index < patch
  64        '
  65test_debug 'cat patch'
  66
  67
  68test_expect_success 'directory becomes file' '
  69        git checkout -f foo-becomes-a-directory &&
  70        git diff-tree -p HEAD initial > patch &&
  71        git apply --index < patch
  72        '
  73test_debug 'cat patch'
  74
  75
  76test_expect_success 'file becomes directory' '
  77        git checkout -f initial &&
  78        git diff-tree -p HEAD foo-becomes-a-directory > patch &&
  79        git apply --index < patch
  80        '
  81test_debug 'cat patch'
  82
  83
  84test_expect_success 'file becomes symlink' '
  85        git checkout -f initial &&
  86        git diff-tree -p HEAD foo-symlinked-to-bar > patch &&
  87        git apply --index < patch
  88        '
  89test_debug 'cat patch'
  90
  91
  92test_expect_success 'symlink becomes file' '
  93        git checkout -f foo-symlinked-to-bar &&
  94        git diff-tree -p HEAD foo-back-to-file > patch &&
  95        git apply --index < patch
  96        '
  97test_debug 'cat patch'
  98
  99test_expect_success 'binary file becomes symlink' '
 100        git checkout -f foo-becomes-binary &&
 101        git diff-tree -p --binary HEAD foo-symlinked-to-bar > patch &&
 102        git apply --index < patch
 103        '
 104test_debug 'cat patch'
 105
 106test_expect_success 'symlink becomes binary file' '
 107        git checkout -f foo-symlinked-to-bar &&
 108        git diff-tree -p --binary HEAD foo-becomes-binary > patch &&
 109        git apply --index < patch
 110        '
 111test_debug 'cat patch'
 112
 113
 114test_expect_success 'symlink becomes directory' '
 115        git checkout -f foo-symlinked-to-bar &&
 116        git diff-tree -p HEAD foo-becomes-a-directory > patch &&
 117        git apply --index < patch
 118        '
 119test_debug 'cat patch'
 120
 121
 122test_expect_success 'directory becomes symlink' '
 123        git checkout -f foo-becomes-a-directory &&
 124        git diff-tree -p HEAD foo-symlinked-to-bar > patch &&
 125        git apply --index < patch
 126        '
 127test_debug 'cat patch'
 128
 129
 130test_done