]> granicus.if.org Git - git/commitdiff
t0027: improve test for not-normalized files
authorTorsten Bögershausen <tboegi@web.de>
Sat, 10 Oct 2015 04:23:53 +0000 (06:23 +0200)
committerJunio C Hamano <gitster@pobox.com>
Mon, 12 Oct 2015 22:07:45 +0000 (15:07 -0700)
When a text file with mixed line endings is commited into the repo,
it is called "not normalized" (or NNO) in t0027.  The existing test
case using repoMIX did not fully test all combinations: (Especially
when core.autocrlf = true) Files with NL are not converted at
commit, but at checkout, so a warning NL->CRLF is given.  Files with
CRLF are not converted at all (so no warning will be given), unless
they are marked as "text" or "auto".

Remove repoMIX introduced in commit 8eeab92f02, and replace it with
a combination of NNO tests.

Signed-off-by: Torsten Bögershausen <tboegi@web.de>
t/t0027-auto-crlf.sh

index 1a56e5e82ee807895da0d597ab75c10cb0299082..b3436515044e9d9be04b8164b704106835c31db1 100755 (executable)
@@ -55,6 +55,26 @@ create_gitattributes () {
        esac
 }
 
+create_NNO_files () {
+       lfname=$1
+       crlfname=$2
+       lfmixcrlf=$3
+       lfmixcr=$4
+       crlfnul=$5
+       for crlf in false true input
+       do
+               for attr in "" auto text -text lf crlf
+               do
+                       pfx=NNO_${crlf}_attr_${attr} &&
+                       cp $lfname    ${pfx}_LF.txt &&
+                       cp $crlfname  ${pfx}_CRLF.txt &&
+                       cp $lfmixcrlf ${pfx}_CRLF_mix_LF.txt &&
+                       cp $lfmixcr   ${pfx}_LF_mix_CR.txt &&
+                       cp $crlfnul   ${pfx}_CRLF_nul.txt
+               done
+       done
+}
+
 check_warning () {
        case "$1" in
        LF_CRLF) echo "warning: LF will be replaced by CRLF" >"$2".expect ;;
@@ -62,7 +82,7 @@ check_warning () {
        '')                                                      >"$2".expect ;;
        *) echo >&2 "Illegal 1": "$1" ; return false ;;
        esac
-       grep "will be replaced by" "$2" | sed -e "s/\(.*\) in [^ ]*$/\1/" >"$2".actual
+       grep "will be replaced by" "$2" | sed -e "s/\(.*\) in [^ ]*$/\1/" | uniq  >"$2".actual
        test_cmp "$2".expect "$2".actual
 }
 
@@ -71,19 +91,10 @@ commit_check_warn () {
        attr=$2
        lfname=$3
        crlfname=$4
-       repoMIX=$5
-       lfmixcrlf=$6
-       lfmixcr=$7
-       crlfnul=$8
+       lfmixcrlf=$5
+       lfmixcr=$6
+       crlfnul=$7
        pfx=crlf_${crlf}_attr_${attr}
-       # Special handling for repoMIX: It should already be in the repo
-       # with CRLF
-       f=repoMIX
-       fname=${pfx}_$f.txt
-       echo >.gitattributes &&
-       cp $f $fname &&
-       git -c core.autocrlf=false add $fname 2>"${pfx}_$f.err" &&
-       git commit -m "repoMIX" &&
        create_gitattributes "$attr" &&
        for f in LF CRLF repoMIX LF_mix_CR CRLF_mix_LF LF_nul CRLF_nul
        do
@@ -99,6 +110,45 @@ commit_check_warn () {
        check_warning "$crlfnul" ${pfx}_CRLF_nul.err
 }
 
+commit_chk_wrnNNO () {
+       crlf=$1
+       attr=$2
+       lfwarn=$3
+       crlfwarn=$4
+       lfmixcrlf=$5
+       lfmixcr=$6
+       crlfnul=$7
+       pfx=NNO_${crlf}_attr_${attr}
+       #Commit files on top of existing file
+       create_gitattributes "$attr" &&
+       for f in LF CRLF CRLF_mix_LF LF_mix_CR CRLF_nul
+       do
+               fname=${pfx}_$f.txt &&
+               cp $f $fname &&
+               git -c core.autocrlf=$crlf add $fname 2>/dev/null &&
+               git -c core.autocrlf=$crlf commit -m "commit_$fname" $fname >"${pfx}_$f.err" 2>&1
+       done
+
+       test_expect_success "commit NNO files crlf=$crlf attr=$attr LF" '
+               check_warning "$lfwarn" ${pfx}_LF.err
+       '
+       test_expect_success "commit NNO files crlf=$crlf attr=$attr CRLF" '
+               check_warning "$crlfwarn" ${pfx}_CRLF.err
+       '
+
+       test_expect_success "commit NNO files crlf=$crlf attr=$attr CRLF_mix_LF" '
+               check_warning "$lfmixcrlf" ${pfx}_CRLF_mix_LF.err
+       '
+
+       test_expect_success "commit NNO files crlf=$crlf attr=$attr LF_mix_cr" '
+               check_warning "$lfmixcr" ${pfx}_LF_mix_CR.err
+       '
+
+       test_expect_success "commit NNO files crlf=$crlf attr=$attr CRLF_nul" '
+               check_warning "$crlfnul" ${pfx}_CRLF_nul.err
+       '
+}
+
 check_files_in_repo () {
        crlf=$1
        attr=$2
@@ -115,6 +165,31 @@ check_files_in_repo () {
        compare_files $crlfnul ${pfx}CRLF_nul.txt
 }
 
+check_in_repo_NNO () {
+       crlf=$1
+       attr=$2
+       lfname=$3
+       crlfname=$4
+       lfmixcrlf=$5
+       lfmixcr=$6
+       crlfnul=$7
+       pfx=NNO_${crlf}_attr_${attr}_
+       test_expect_success "compare_files $lfname ${pfx}LF.txt" '
+               compare_files $lfname ${pfx}LF.txt
+       '
+       test_expect_success "compare_files $crlfname ${pfx}CRLF.txt" '
+               compare_files $crlfname ${pfx}CRLF.txt
+       '
+       test_expect_success "compare_files $lfmixcrlf ${pfx}CRLF_mix_LF.txt" '
+               compare_files $lfmixcrlf ${pfx}CRLF_mix_LF.txt
+       '
+       test_expect_success "compare_files $lfmixcr ${pfx}LF_mix_CR.txt" '
+               compare_files $lfmixcr ${pfx}LF_mix_CR.txt
+       '
+       test_expect_success "compare_files $crlfnul ${pfx}CRLF_nul.txt" '
+               compare_files $crlfnul ${pfx}CRLF_nul.txt
+       '
+}
 
 checkout_files () {
        eol=$1
@@ -169,7 +244,11 @@ test_expect_success 'setup master' '
        printf "line1\nline2\rline3"     >LF_mix_CR &&
        printf "line1\r\nline2\rline3"   >CRLF_mix_CR &&
        printf "line1Q\r\nline2\r\nline3" | q_to_nul >CRLF_nul &&
-       printf "line1Q\nline2\nline3" | q_to_nul >LF_nul
+       printf "line1Q\nline2\nline3" | q_to_nul >LF_nul &&
+       create_NNO_files CRLF_mix_LF CRLF_mix_LF CRLF_mix_LF CRLF_mix_LF CRLF_mix_LF &&
+       git -c core.autocrlf=false add NNO_*.txt &&
+       git commit -m "mixed line endings" &&
+       test_tick
 '
 
 
@@ -191,46 +270,72 @@ else
        WAMIX=CRLF_LF
 fi
 
-#                         attr   LF        CRLF      repoMIX   CRLFmixLF LFmixCR   CRLFNUL
+#                         attr   LF        CRLF      CRLFmixLF LFmixCR   CRLFNUL
 test_expect_success 'commit files empty attr' '
-       commit_check_warn false ""     ""        ""        ""        ""        ""        "" &&
-       commit_check_warn true  ""     "LF_CRLF" ""        "LF_CRLF" "LF_CRLF" ""        "" &&
-       commit_check_warn input ""     ""        "CRLF_LF" "CRLF_LF" "CRLF_LF" ""        ""
+       commit_check_warn false ""     ""        ""        ""        ""        "" &&
+       commit_check_warn true  ""     "LF_CRLF" ""        "LF_CRLF" ""        "" &&
+       commit_check_warn input ""     ""        "CRLF_LF" "CRLF_LF" ""        ""
 '
 
 test_expect_success 'commit files attr=auto' '
-       commit_check_warn false "auto" "$WILC"   "$WICL"   "$WAMIX"  "$WAMIX"  ""        "" &&
-       commit_check_warn true  "auto" "LF_CRLF" ""        "LF_CRLF" "LF_CRLF" ""        "" &&
-       commit_check_warn input "auto" ""        "CRLF_LF" "CRLF_LF" "CRLF_LF" ""        ""
+       commit_check_warn false "auto" "$WILC"   "$WICL"   "$WAMIX"  ""        "" &&
+       commit_check_warn true  "auto" "LF_CRLF" ""        "LF_CRLF" ""        "" &&
+       commit_check_warn input "auto" ""        "CRLF_LF" "CRLF_LF" ""        ""
 '
 
 test_expect_success 'commit files attr=text' '
-       commit_check_warn false "text" "$WILC"   "$WICL"   "$WAMIX"  "$WAMIX"  "$WILC"   "$WICL"   &&
-       commit_check_warn true  "text" "LF_CRLF" ""        "LF_CRLF" "LF_CRLF" "LF_CRLF" ""        &&
-       commit_check_warn input "text" ""        "CRLF_LF" "CRLF_LF" "CRLF_LF" ""        "CRLF_LF"
+       commit_check_warn false "text" "$WILC"   "$WICL"   "$WAMIX"  "$WILC"   "$WICL"   &&
+       commit_check_warn true  "text" "LF_CRLF" ""        "LF_CRLF" "LF_CRLF" ""        &&
+       commit_check_warn input "text" ""        "CRLF_LF" "CRLF_LF" ""        "CRLF_LF"
 '
 
 test_expect_success 'commit files attr=-text' '
-       commit_check_warn false "-text" ""       ""        ""        ""        ""        "" &&
-       commit_check_warn true  "-text" ""       ""        ""        ""        ""        "" &&
-       commit_check_warn input "-text" ""       ""        ""        ""        ""        ""
+       commit_check_warn false "-text" ""       ""        ""        ""        "" &&
+       commit_check_warn true  "-text" ""       ""        ""        ""        "" &&
+       commit_check_warn input "-text" ""       ""        ""        ""        ""
 '
 
 test_expect_success 'commit files attr=lf' '
-       commit_check_warn false "lf"    ""       "CRLF_LF" "CRLF_LF" "CRLF_LF"  ""       "CRLF_LF" &&
-       commit_check_warn true  "lf"    ""       "CRLF_LF" "CRLF_LF" "CRLF_LF"  ""       "CRLF_LF" &&
-       commit_check_warn input "lf"    ""       "CRLF_LF" "CRLF_LF" "CRLF_LF"  ""       "CRLF_LF"
+       commit_check_warn false "lf"    ""       "CRLF_LF" "CRLF_LF"  ""       "CRLF_LF" &&
+       commit_check_warn true  "lf"    ""       "CRLF_LF" "CRLF_LF"  ""       "CRLF_LF" &&
+       commit_check_warn input "lf"    ""       "CRLF_LF" "CRLF_LF"  ""       "CRLF_LF"
 '
 
 test_expect_success 'commit files attr=crlf' '
-       commit_check_warn false "crlf" "LF_CRLF" ""        "LF_CRLF" "LF_CRLF" "LF_CRLF" "" &&
-       commit_check_warn true  "crlf" "LF_CRLF" ""        "LF_CRLF" "LF_CRLF" "LF_CRLF" "" &&
-       commit_check_warn input "crlf" "LF_CRLF" ""        "LF_CRLF" "LF_CRLF" "LF_CRLF" ""
+       commit_check_warn false "crlf" "LF_CRLF" ""        "LF_CRLF" "LF_CRLF" "" &&
+       commit_check_warn true  "crlf" "LF_CRLF" ""        "LF_CRLF" "LF_CRLF" "" &&
+       commit_check_warn input "crlf" "LF_CRLF" ""        "LF_CRLF" "LF_CRLF" ""
 '
 
+#                       attr   LF        CRLF      CRLFmixLF    LF_mix_CR   CRLFNUL
+commit_chk_wrnNNO false ""     ""        ""        ""           ""              ""
+commit_chk_wrnNNO true  ""     "LF_CRLF" ""        ""           ""              ""
+commit_chk_wrnNNO input ""     ""        ""        ""           ""              ""
+
+
+commit_chk_wrnNNO false "auto" "$WILC"   "$WICL"   "$WAMIX"     ""              ""
+commit_chk_wrnNNO true  "auto" "LF_CRLF" ""        "LF_CRLF"    ""              ""
+commit_chk_wrnNNO input "auto" ""        "CRLF_LF" "CRLF_LF"    ""              ""
+
+commit_chk_wrnNNO false "text" "$WILC"   "$WICL"   "$WAMIX"     "$WILC"         "$WICL"
+commit_chk_wrnNNO true  "text" "LF_CRLF" ""        "LF_CRLF"    "LF_CRLF"       ""
+commit_chk_wrnNNO input "text" ""        "CRLF_LF" "CRLF_LF"    ""              "CRLF_LF"
+
+commit_chk_wrnNNO false "-text" ""       ""        ""           ""              ""
+commit_chk_wrnNNO true  "-text" ""       ""        ""           ""              ""
+commit_chk_wrnNNO input "-text" ""       ""        ""           ""              ""
+
+commit_chk_wrnNNO false "lf"    ""       "CRLF_LF" "CRLF_LF"     ""             "CRLF_LF"
+commit_chk_wrnNNO true  "lf"    ""       "CRLF_LF" "CRLF_LF"     ""             "CRLF_LF"
+commit_chk_wrnNNO input "lf"    ""       "CRLF_LF" "CRLF_LF"     ""             "CRLF_LF"
+
+commit_chk_wrnNNO false "crlf" "LF_CRLF" ""        "LF_CRLF"    "LF_CRLF"       ""
+commit_chk_wrnNNO true  "crlf" "LF_CRLF" ""        "LF_CRLF"    "LF_CRLF"       ""
+commit_chk_wrnNNO input "crlf" "LF_CRLF" ""        "LF_CRLF"    "LF_CRLF"       ""
+
 test_expect_success 'create files cleanup' '
        rm -f *.txt &&
-       git reset --hard
+       git -c core.autocrlf=false reset --hard
 '
 
 test_expect_success 'commit empty gitattribues' '
@@ -257,6 +362,24 @@ test_expect_success 'commit -text' '
        check_files_in_repo input "-text" LF CRLF CRLF_mix_LF LF_mix_CR CRLF_nul
 '
 
+#                       attr    LF        CRLF      CRLF_mix_LF  LF_mix_CR     CRLFNUL
+check_in_repo_NNO false ""      LF        CRLF      CRLF_mix_LF  LF_mix_CR     CRLF_nul
+check_in_repo_NNO true  ""      LF        CRLF      CRLF_mix_LF  LF_mix_CR     CRLF_nul
+check_in_repo_NNO input ""      LF        CRLF      CRLF_mix_LF  LF_mix_CR     CRLF_nul
+
+check_in_repo_NNO false "auto"  LF        LF        LF           LF_mix_CR     CRLF_nul
+check_in_repo_NNO true  "auto"  LF        LF        LF           LF_mix_CR     CRLF_nul
+check_in_repo_NNO input "auto"  LF        LF        LF           LF_mix_CR     CRLF_nul
+
+check_in_repo_NNO false "text"  LF        LF        LF           LF_mix_CR     LF_nul
+check_in_repo_NNO true  "text"  LF        LF        LF           LF_mix_CR     LF_nul
+check_in_repo_NNO input "text"  LF        LF        LF           LF_mix_CR     LF_nul
+
+check_in_repo_NNO false "-text" LF        CRLF      CRLF_mix_LF  LF_mix_CR     CRLF_nul
+check_in_repo_NNO true  "-text" LF        CRLF      CRLF_mix_LF  LF_mix_CR     CRLF_nul
+check_in_repo_NNO input "-text" LF        CRLF      CRLF_mix_LF  LF_mix_CR     CRLF_nul
+
+
 ################################################################################
 # Check how files in the repo are changed when they are checked out
 # How to read the table below: