##// END OF EJS Templates
convert: fix crash when existing converted revision didn't come from source...
convert: fix crash when existing converted revision didn't come from source This case can happen when converting from multiple repositories with filemap.

File last commit:

r18262:ed923a2d default
r19863:daeab82f default
Show More
test-convert-cvs-synthetic.t
223 lines | 4.7 KiB | text/troff | Tads3Lexer
/ tests / test-convert-cvs-synthetic.t
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 This feature requires use of builtin cvsps!
$ "$TESTDIR/hghave" cvs || exit 80
$ echo "[extensions]" >> $HGRCPATH
$ echo "convert = " >> $HGRCPATH
$ echo "graphlog = " >> $HGRCPATH
create cvs repository with one project
$ mkdir cvsrepo
$ cd cvsrepo
$ CVSROOT=`pwd`
$ export CVSROOT
$ CVS_OPTIONS=-f
$ export CVS_OPTIONS
$ cd ..
$ cvscall()
> {
> cvs -f "$@"
> }
output of 'cvs ci' varies unpredictably, so just discard it
$ cvsci()
> {
Matt Mackall
tests: avoid instability in test-convert-cvs-synthetic
r14602 > sleep 1
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 > cvs -f ci "$@" >/dev/null
> }
$ cvscall -d "$CVSROOT" init
$ mkdir cvsrepo/proj
$ cvscall -q co proj
create file1 on the trunk
$ cd proj
$ touch file1
$ cvscall -Q add file1
$ cvsci -m"add file1 on trunk" file1
create two branches
$ cvscall -q tag -b v1_0
T file1
$ cvscall -q tag -b v1_1
T file1
create file2 on branch v1_0
$ cvscall -Q up -rv1_0
$ touch file2
$ cvscall -Q add file2
$ cvsci -m"add file2" file2
create file3, file4 on branch v1_1
$ cvscall -Q up -rv1_1
$ touch file3
$ touch file4
$ cvscall -Q add file3 file4
$ cvsci -m"add file3, file4 on branch v1_1" file3 file4
merge file2 from v1_0 to v1_1
$ cvscall -Q up -jv1_0
$ cvsci -m"MERGE from v1_0: add file2"
cvs commit: Examining .
Step things up a notch: now we make the history really hairy, with
changes bouncing back and forth between trunk and v1_2 and merges
going both ways. (I.e., try to model the real world.)
create branch v1_2
$ cvscall -Q up -A
$ cvscall -q tag -b v1_2
T file1
create file5 on branch v1_2
$ cvscall -Q up -rv1_2
$ touch file5
$ cvs -Q add file5
$ cvsci -m"add file5 on v1_2"
cvs commit: Examining .
create file6 on trunk post-v1_2
$ cvscall -Q up -A
$ touch file6
$ cvscall -Q add file6
$ cvsci -m"add file6 on trunk post-v1_2"
cvs commit: Examining .
merge file5 from v1_2 to trunk
$ cvscall -Q up -A
$ cvscall -Q up -jv1_2 file5
$ cvsci -m"MERGE from v1_2: add file5"
cvs commit: Examining .
merge file6 from trunk to v1_2
$ cvscall -Q up -rv1_2
$ cvscall up -jHEAD file6
U file6
$ cvsci -m"MERGE from HEAD: add file6"
cvs commit: Examining .
cvs rlog output
$ cvscall -q rlog proj | egrep '^(RCS file|revision)'
Mads Kiilerich
tests: remove redundant globs...
r12640 RCS file: $TESTTMP/cvsrepo/proj/file1,v
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 revision 1.1
Mads Kiilerich
tests: remove redundant globs...
r12640 RCS file: $TESTTMP/cvsrepo/proj/Attic/file2,v
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 revision 1.1
revision 1.1.4.2
revision 1.1.4.1
revision 1.1.2.1
Mads Kiilerich
tests: remove redundant globs...
r12640 RCS file: $TESTTMP/cvsrepo/proj/Attic/file3,v
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 revision 1.1
revision 1.1.2.1
Mads Kiilerich
tests: remove redundant globs...
r12640 RCS file: $TESTTMP/cvsrepo/proj/Attic/file4,v
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 revision 1.1
revision 1.1.2.1
Mads Kiilerich
tests: remove redundant globs...
r12640 RCS file: $TESTTMP/cvsrepo/proj/file5,v
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 revision 1.2
revision 1.1
revision 1.1.2.1
Mads Kiilerich
tests: remove redundant globs...
r12640 RCS file: $TESTTMP/cvsrepo/proj/file6,v
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 revision 1.1
revision 1.1.2.2
revision 1.1.2.1
convert to hg (#1)
$ cd ..
$ hg convert --datesort proj proj.hg
initializing destination proj.hg repository
Mads Kiilerich
tests: remove redundant globs...
r12640 connecting to $TESTTMP/cvsrepo
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 scanning source...
collecting CVS rlog
15 log entries
creating changesets
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 9 changeset entries
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 sorting...
converting...
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 8 add file1 on trunk
7 add file2
6 MERGE from v1_0: add file2
5 file file3 was initially added on branch v1_1.
4 add file3, file4 on branch v1_1
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 3 add file5 on v1_2
2 add file6 on trunk post-v1_2
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 1 MERGE from HEAD: add file6
0 MERGE from v1_2: add file5
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522
hg glog output (#1)
$ hg -R proj.hg glog --template "{rev} {desc}\n"
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 o 8 MERGE from v1_2: add file5
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 |
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 | o 7 MERGE from HEAD: add file6
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 | |
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 o | 6 add file6 on trunk post-v1_2
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 | |
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 | o 5 add file5 on v1_2
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 | |
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 | | o 4 add file3, file4 on branch v1_1
| | |
o | | 3 file file3 was initially added on branch v1_1.
|/ /
| o 2 MERGE from v1_0: add file2
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 |/
| o 1 add file2
|/
o 0 add file1 on trunk
convert to hg (#2: with merge detection)
$ hg convert \
> --config convert.cvsps.mergefrom='"^MERGE from (\S+):"' \
> --datesort \
> proj proj.hg2
initializing destination proj.hg2 repository
Mads Kiilerich
tests: remove redundant globs...
r12640 connecting to $TESTTMP/cvsrepo
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 scanning source...
collecting CVS rlog
15 log entries
creating changesets
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 9 changeset entries
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 sorting...
converting...
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 8 add file1 on trunk
7 add file2
6 MERGE from v1_0: add file2
5 file file3 was initially added on branch v1_1.
4 add file3, file4 on branch v1_1
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 3 add file5 on v1_2
2 add file6 on trunk post-v1_2
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 1 MERGE from HEAD: add file6
0 MERGE from v1_2: add file5
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522
hg glog output (#2)
$ hg -R proj.hg2 glog --template "{rev} {desc}\n"
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 o 8 MERGE from v1_2: add file5
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 |
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 | o 7 MERGE from HEAD: add file6
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 | |
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 o | 6 add file6 on trunk post-v1_2
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 | |
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 | o 5 add file5 on v1_2
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 | |
Bryan O'Sullivan
tests: update test-convert-cvs*.t...
r18262 | | o 4 add file3, file4 on branch v1_1
| | |
o | | 3 file file3 was initially added on branch v1_1.
|/ /
| o 2 MERGE from v1_0: add file2
Matt Mackall
tests: unify test-convert-cvs-synthetic
r12522 |/
| o 1 add file2
|/
o 0 add file1 on trunk