948d5b5a7a584a7e9655e21a438093e97b4014b4
   1#!/bin/sh
   2#
   3# Copyright (c) 2005 Junio C Hamano
   4#
   5
   6test_description='git-apply handling binary patches
   7
   8'
   9. ./test-lib.sh
  10
  11# setup
  12
  13cat >file1 <<EOF
  14A quick brown fox jumps over the lazy dog.
  15A tiny little penguin runs around in circles.
  16There is a flag with Linux written on it.
  17A slow black-and-white panda just sits there,
  18munching on his bamboo.
  19EOF
  20cat file1 >file2
  21cat file1 >file4
  22
  23git-update-index --add --remove file1 file2 file4
  24git-commit -m 'Initial Version' 2>/dev/null
  25
  26git-checkout -b binary
  27tr 'x' '\0' <file1 >file3
  28cat file3 >file4
  29git-add file2
  30tr '\0' 'v' <file3 >file1
  31rm -f file2
  32git-update-index --add --remove file1 file2 file3 file4
  33git-commit -m 'Second Version'
  34
  35git-diff-tree -p master binary >B.diff
  36git-diff-tree -p -C master binary >C.diff
  37
  38test_expect_success 'stat binary diff -- should not fail.' \
  39        'git-checkout master
  40         git-apply --stat --summary B.diff'
  41
  42test_expect_success 'stat binary diff (copy) -- should not fail.' \
  43        'git-checkout master
  44         git-apply --stat --summary C.diff'
  45
  46test_expect_failure 'check binary diff -- should fail.' \
  47        'git-checkout master
  48         git-apply --check B.diff'
  49
  50test_expect_failure 'check binary diff (copy) -- should fail.' \
  51        'git-checkout master
  52         git-apply --check C.diff'
  53
  54# Now we start applying them.
  55
  56test_expect_failure 'apply binary diff -- should fail.' \
  57        'git-checkout master
  58         git-apply B.diff'
  59
  60git-reset --hard
  61
  62test_expect_failure 'apply binary diff -- should fail.' \
  63        'git-checkout master
  64         git-apply --index B.diff'
  65
  66git-reset --hard
  67
  68test_expect_failure 'apply binary diff (copy) -- should fail.' \
  69        'git-checkout master
  70         git-apply C.diff'
  71
  72git-reset --hard
  73
  74test_expect_failure 'apply binary diff (copy) -- should fail.' \
  75        'git-checkout master
  76         git-apply --index C.diff'
  77
  78test_done