t / t9600-cvsimport.shon commit t6038 (merge.renormalize): style nitpicks (18acb30)
   1#!/bin/sh
   2
   3test_description='git cvsimport basic tests'
   4. ./lib-cvs.sh
   5
   6if ! test_have_prereq PERL; then
   7        say 'skipping git cvsimport tests, perl not available'
   8        test_done
   9fi
  10
  11CVSROOT=$(pwd)/cvsroot
  12export CVSROOT
  13
  14test_expect_success 'setup cvsroot' '$CVS init'
  15
  16test_expect_success 'setup a cvs module' '
  17
  18        mkdir "$CVSROOT/module" &&
  19        $CVS co -d module-cvs module &&
  20        cd module-cvs &&
  21        cat <<EOF >o_fortuna &&
  22O Fortuna
  23velut luna
  24statu variabilis,
  25
  26semper crescis
  27aut decrescis;
  28vita detestabilis
  29
  30nunc obdurat
  31et tunc curat
  32ludo mentis aciem,
  33
  34egestatem,
  35potestatem
  36dissolvit ut glaciem.
  37EOF
  38        $CVS add o_fortuna &&
  39        cat <<EOF >message &&
  40add "O Fortuna" lyrics
  41
  42These public domain lyrics make an excellent sample text.
  43EOF
  44        $CVS commit -F message &&
  45        cd ..
  46'
  47
  48test_expect_success 'import a trivial module' '
  49
  50        git cvsimport -a -R -z 0 -C module-git module &&
  51        test_cmp module-cvs/o_fortuna module-git/o_fortuna
  52
  53'
  54
  55test_expect_success 'pack refs' 'cd module-git && git gc && cd ..'
  56
  57test_expect_success 'initial import has correct .git/cvs-revisions' '
  58
  59        (cd module-git &&
  60         git log --format="o_fortuna 1.1 %H" -1) > expected &&
  61        test_cmp expected module-git/.git/cvs-revisions
  62'
  63
  64test_expect_success 'update cvs module' '
  65
  66        cd module-cvs &&
  67        cat <<EOF >o_fortuna &&
  68O Fortune,
  69like the moon
  70you are changeable,
  71
  72ever waxing
  73and waning;
  74hateful life
  75
  76first oppresses
  77and then soothes
  78as fancy takes it;
  79
  80poverty
  81and power
  82it melts them like ice.
  83EOF
  84        cat <<EOF >message &&
  85translate to English
  86
  87My Latin is terrible.
  88EOF
  89        $CVS commit -F message &&
  90        cd ..
  91'
  92
  93test_expect_success 'update git module' '
  94
  95        cd module-git &&
  96        git cvsimport -a -R -z 0 module &&
  97        git merge origin &&
  98        cd .. &&
  99        test_cmp module-cvs/o_fortuna module-git/o_fortuna
 100
 101'
 102
 103test_expect_success 'update has correct .git/cvs-revisions' '
 104
 105        (cd module-git &&
 106         git log --format="o_fortuna 1.1 %H" -1 HEAD^ &&
 107         git log --format="o_fortuna 1.2 %H" -1 HEAD) > expected &&
 108        test_cmp expected module-git/.git/cvs-revisions
 109'
 110
 111test_expect_success 'update cvs module' '
 112
 113        cd module-cvs &&
 114                echo 1 >tick &&
 115                $CVS add tick &&
 116                $CVS commit -m 1
 117        cd ..
 118
 119'
 120
 121test_expect_success 'cvsimport.module config works' '
 122
 123        cd module-git &&
 124                git config cvsimport.module module &&
 125                git cvsimport -a -R -z0 &&
 126                git merge origin &&
 127        cd .. &&
 128        test_cmp module-cvs/tick module-git/tick
 129
 130'
 131
 132test_expect_success 'second update has correct .git/cvs-revisions' '
 133
 134        (cd module-git &&
 135         git log --format="o_fortuna 1.1 %H" -1 HEAD^^ &&
 136         git log --format="o_fortuna 1.2 %H" -1 HEAD^
 137         git log --format="tick 1.1 %H" -1 HEAD) > expected &&
 138        test_cmp expected module-git/.git/cvs-revisions
 139'
 140
 141test_expect_success 'import from a CVS working tree' '
 142
 143        $CVS co -d import-from-wt module &&
 144        cd import-from-wt &&
 145                git cvsimport -a -z0 &&
 146                echo 1 >expect &&
 147                git log -1 --pretty=format:%s%n >actual &&
 148                test_cmp actual expect &&
 149        cd ..
 150
 151'
 152
 153test_expect_success 'no .git/cvs-revisions created by default' '
 154
 155        ! test -e import-from-wt/.git/cvs-revisions
 156
 157'
 158
 159test_expect_success 'test entire HEAD' 'test_cmp_branch_tree master'
 160
 161test_done