t / t4114-apply-typechange.shon commit Extend "checkout --track" DWIM to support more cases (9188ed8)
   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
  12test_expect_success 'setup repository and commits' '
  13        echo "hello world" > foo &&
  14        echo "hi planet" > bar &&
  15        git update-index --add foo bar &&
  16        git commit -m initial &&
  17        git branch initial &&
  18        rm -f foo &&
  19        ln -s bar foo &&
  20        git update-index foo &&
  21        git commit -m "foo symlinked to bar" &&
  22        git branch foo-symlinked-to-bar &&
  23        rm -f foo &&
  24        echo "how far is the sun?" > foo &&
  25        git update-index foo &&
  26        git commit -m "foo back to file" &&
  27        git branch foo-back-to-file &&
  28        rm -f foo &&
  29        git update-index --remove foo &&
  30        mkdir foo &&
  31        echo "if only I knew" > foo/baz &&
  32        git update-index --add foo/baz &&
  33        git commit -m "foo becomes a directory" &&
  34        git branch "foo-becomes-a-directory" &&
  35        echo "hello world" > foo/baz &&
  36        git update-index foo/baz &&
  37        git commit -m "foo/baz is the original foo" &&
  38        git branch foo-baz-renamed-from-foo
  39        '
  40
  41test_expect_success 'file renamed from foo to foo/baz' '
  42        git checkout -f initial &&
  43        git diff-tree -M -p HEAD foo-baz-renamed-from-foo > patch &&
  44        git apply --index < patch
  45        '
  46test_debug 'cat patch'
  47
  48
  49test_expect_success 'file renamed from foo/baz to foo' '
  50        git checkout -f foo-baz-renamed-from-foo &&
  51        git diff-tree -M -p HEAD initial > patch &&
  52        git apply --index < patch
  53        '
  54test_debug 'cat patch'
  55
  56
  57test_expect_success 'directory becomes file' '
  58        git checkout -f foo-becomes-a-directory &&
  59        git diff-tree -p HEAD initial > patch &&
  60        git apply --index < patch
  61        '
  62test_debug 'cat patch'
  63
  64
  65test_expect_success 'file becomes directory' '
  66        git checkout -f initial &&
  67        git diff-tree -p HEAD foo-becomes-a-directory > patch &&
  68        git apply --index < patch
  69        '
  70test_debug 'cat patch'
  71
  72
  73test_expect_success 'file becomes symlink' '
  74        git checkout -f initial &&
  75        git diff-tree -p HEAD foo-symlinked-to-bar > patch &&
  76        git apply --index < patch
  77        '
  78test_debug 'cat patch'
  79
  80
  81test_expect_success 'symlink becomes file' '
  82        git checkout -f foo-symlinked-to-bar &&
  83        git diff-tree -p HEAD foo-back-to-file > patch &&
  84        git apply --index < patch
  85        '
  86test_debug 'cat patch'
  87
  88
  89test_expect_success 'symlink becomes directory' '
  90        git checkout -f foo-symlinked-to-bar &&
  91        git diff-tree -p HEAD foo-becomes-a-directory > patch &&
  92        git apply --index < patch
  93        '
  94test_debug 'cat patch'
  95
  96
  97test_expect_success 'directory becomes symlink' '
  98        git checkout -f foo-becomes-a-directory &&
  99        git diff-tree -p HEAD foo-symlinked-to-bar > patch &&
 100        git apply --index < patch
 101        '
 102test_debug 'cat patch'
 103
 104
 105test_done