##// END OF EJS Templates
Do not use osutil.c with python 2.4 and Windows (issue1364)...
Do not use osutil.c with python 2.4 and Windows (issue1364) Windows python 2.4 os.stat() reports times including DST offset, while osutil.c reports the correct value, which makes status() systematically compare files content. This bug is fixed in python 2.5. Using osutil.py instead of osutil.c is 4x times slower on large repositories but current code is completely unusable. Given few people are likely to use python 2.4 on Windows this solution was considered a good trade-off compared to more invasive solutions trying to address the offset issue.

File last commit:

r9543:56a5f805 default
r10521:bde1bb25 stable
Show More
test-convert-cvs-synthetic
118 lines | 2.4 KiB | text/plain | TextLexer
/ tests / test-convert-cvs-synthetic
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862 #!/bin/sh
# This feature requires use of builtin cvsps!
"$TESTDIR/hghave" cvs || exit 80
set -e
echo "[extensions]" >> $HGRCPATH
echo "convert = " >> $HGRCPATH
Greg Ward
Reproduce crash where synthetic revs break merge detection (issue1578)....
r8249 echo "graphlog = " >> $HGRCPATH
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862
echo % create cvs repository with one project
mkdir cvsrepo
cd cvsrepo
Martin Geisler
tests: avoid export FOO=bar bashism
r8350 CVSROOT=`pwd`
export CVSROOT
CVS_OPTIONS=-f
export CVS_OPTIONS
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862 cd ..
Greg Ward
issue1577: fix broken test by assuming less about CVS output....
r8081 filterpath()
{
eval "$@" | sed "s:$CVSROOT:*REPO*:g"
}
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862 cvscall()
{
Greg Ward
issue1577: fix broken test by assuming less about CVS output....
r8081 echo cvs -f "$@"
cvs -f "$@" 2>&1
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862 }
Greg Ward
issue1577: fix broken test by assuming less about CVS output....
r8081 # output of 'cvs ci' varies unpredictably, so just discard it
cvsci()
{
echo cvs -f ci "$@"
cvs -f ci "$@" >/dev/null 2>&1
}
filterpath cvscall -d "$CVSROOT" init
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862 mkdir cvsrepo/proj
Greg Ward
issue1577: fix broken test by assuming less about CVS output....
r8081 cvscall -q co proj
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862
echo % create file1 on the trunk
cd proj
touch file1
Greg Ward
issue1577: fix broken test by assuming less about CVS output....
r8081 cvscall -Q add file1
cvsci -m"add file1 on trunk" file1
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862
echo % create two branches
Greg Ward
issue1577: fix broken test by assuming less about CVS output....
r8081 cvscall -q tag -b v1_0
cvscall -q tag -b v1_1
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862
echo % create file2 on branch v1_0
Greg Ward
Reproduce crash where synthetic revs break merge detection (issue1578)....
r8249 cvscall -Q up -rv1_0
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862 touch file2
Greg Ward
issue1577: fix broken test by assuming less about CVS output....
r8081 cvscall -Q add file2
Greg Ward
Reproduce crash where synthetic revs break merge detection (issue1578)....
r8249 cvsci -m"add file2" file2
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862
echo % create file3, file4 on branch v1_1
Greg Ward
issue1577: fix broken test by assuming less about CVS output....
r8081 cvscall -Q up -rv1_1
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862 touch file3
touch file4
Greg Ward
issue1577: fix broken test by assuming less about CVS output....
r8081 cvscall -Q add file3 file4
cvsci -m"add file3, file4 on branch v1_1" file3 file4
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862
echo % merge file2 from v1_0 to v1_1
Greg Ward
Reproduce crash where synthetic revs break merge detection (issue1578)....
r8249 cvscall -Q up -jv1_0
cvsci -m"MERGE from v1_0: add file2"
# 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.)
echo "% create branch v1_2"
cvscall -Q up -A
cvscall -q tag -b v1_2
echo "% create file5 on branch v1_2"
cvscall -Q up -rv1_2
touch file5
cvs -Q add file5
cvsci -m"add file5 on v1_2"
echo "% 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"
echo "% 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"
echo "% merge file6 from trunk to v1_2"
cvscall -Q up -rv1_2
cvscall up -jHEAD file6
cvsci -m"MERGE from HEAD: add file6"
Greg Ward
issue1577: fix broken test by assuming less about CVS output....
r8081
echo % cvs rlog output
filterpath cvscall -q rlog proj | egrep '^(RCS file|revision)'
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862
Greg Ward
Reproduce crash where synthetic revs break merge detection (issue1578)....
r8249 echo "% convert to hg (#1)"
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862 cd ..
Greg Ward
Reproduce crash where synthetic revs break merge detection (issue1578)....
r8249 filterpath hg convert --datesort proj proj.hg
echo "% hg glog output (#1)"
hg -R proj.hg glog --template "{rev} {desc}\n"
Greg Ward
cvsps: recognize and eliminate CVS' synthetic "file added" revisions.
r7862
Greg Ward
Reproduce crash where synthetic revs break merge detection (issue1578)....
r8249 echo "% convert to hg (#2: with merge detection)"
filterpath hg convert \
--config convert.cvsps.mergefrom="\"^MERGE from (\S+):\"" \
--datesort \
proj proj.hg2
echo "% hg glog output (#2)"
hg -R proj.hg2 glog --template "{rev} {desc}\n"