3 # Copyright (c) 2010 Stefan-W. Hahn
 
   6 test_description='git-am mbox with dos line ending.
 
  11 # Three patches which will be added as files with dos line ending.
 
  33 test_expect_success 'setup repository with dos files' '
 
  34         append_cr <file1 >file &&
 
  36         git commit -m Initial &&
 
  38         append_cr <file2 >file &&
 
  39         git commit -a -m Second &&
 
  40         append_cr <file3 >file &&
 
  41         git commit -a -m Third
 
  44 test_expect_success 'am with dos files without --keep-cr' '
 
  45         git checkout -b dosfiles initial &&
 
  46         git format-patch -k initial..master &&
 
  47         test_must_fail git am -k -3 000*.patch &&
 
  49         rm -rf .git/rebase-apply 000*.patch
 
  52 test_expect_success 'am with dos files with --keep-cr' '
 
  53         git checkout -b dosfiles-keep-cr initial &&
 
  54         git format-patch -k --stdout initial..master | git am --keep-cr -k -3 &&
 
  55         git diff --exit-code master
 
  58 test_expect_success 'am with dos files config am.keepcr' '
 
  59         git config am.keepcr 1 &&
 
  60         git checkout -b dosfiles-conf-keepcr initial &&
 
  61         git format-patch -k --stdout initial..master | git am -k -3 &&
 
  62         git diff --exit-code master
 
  65 test_expect_success 'am with dos files config am.keepcr overriden by --no-keep-cr' '
 
  66         git config am.keepcr 1 &&
 
  67         git checkout -b dosfiles-conf-keepcr-override initial &&
 
  68         git format-patch -k initial..master &&
 
  69         test_must_fail git am -k -3 --no-keep-cr 000*.patch &&
 
  71         rm -rf .git/rebase-apply 000*.patch
 
  74 test_expect_success 'am with dos files with --keep-cr continue' '
 
  75         git checkout -b dosfiles-keep-cr-continue initial &&
 
  76         git format-patch -k initial..master &&
 
  77         append_cr <file1a >file &&
 
  78         git commit -m "different patch" file &&
 
  79         test_must_fail git am --keep-cr -k -3 000*.patch &&
 
  80         append_cr <file2 >file &&
 
  82         git am -3 --resolved &&
 
  83         git diff --exit-code master
 
  86 test_expect_success 'am with unix files config am.keepcr overriden by --no-keep-cr' '
 
  87         git config am.keepcr 1 &&
 
  88         git checkout -b unixfiles-conf-keepcr-override initial &&
 
  90         git commit -m "line ending to unix" file &&
 
  91         git format-patch -k initial..master &&
 
  92         git am -k -3 --no-keep-cr 000*.patch &&
 
  93         git diff --exit-code -w master