tests/test-copy
author Alexis S. L. Carvalho <alexis@cecm.usp.br>
Sun, 23 Mar 2008 21:03:24 -0300
changeset 6370 6440e25a1ba3
parent 3853 c0b449154a90
child 11331 997ab9af81df
permissions -rwxr-xr-x
localrepo.commit: grab locks before getting the list of files to commit Somebody may change the dirstate after we've determined the parents of the working dir and run repo.status, but before we called wlock(). This should also fix issue997, where backout would change a file without changing its size and then call repo.commit without passing the list of files. If this happened in less than one second, we wouldn't detect any file changes - the in-memory dirstate still has the cached stat data for that file. Grabbing the wlock early causes the dirstate to be invalidated and we end up reading the dirstate file again, which has that file marked for lookup (size == -1). A better fix would be for backout to give repo.commit the exact list of files, but that'll require some changes to the revert operation. A significant user-visible change is that the precommit hook is always run with both locks grabbed - previously, hg commit would run it before grabbing any locks, but hg import would run it after grabbing locks.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
544
3d4d5f2aba9a Remove bashisms and use /bin/sh instead of /bin/bash.
Thomas Arendsen Hein <thomas@intevation.de>
parents: 464
diff changeset
     1
#!/bin/sh
363
ae96b7e1318d Add hg copy
mpm@selenic.com
parents:
diff changeset
     2
ae96b7e1318d Add hg copy
mpm@selenic.com
parents:
diff changeset
     3
hg init
ae96b7e1318d Add hg copy
mpm@selenic.com
parents:
diff changeset
     4
echo a > a
ae96b7e1318d Add hg copy
mpm@selenic.com
parents:
diff changeset
     5
hg add a
1933
7544700fd931 Use 'hg ci -d "1000000 0"' in tests to circumvent problem with leading zero.
Thomas Arendsen Hein <thomas@intevation.de>
parents: 1926
diff changeset
     6
hg commit -m "1" -d "1000000 0"
363
ae96b7e1318d Add hg copy
mpm@selenic.com
parents:
diff changeset
     7
hg status
ae96b7e1318d Add hg copy
mpm@selenic.com
parents:
diff changeset
     8
hg copy a b
ae96b7e1318d Add hg copy
mpm@selenic.com
parents:
diff changeset
     9
hg status
1933
7544700fd931 Use 'hg ci -d "1000000 0"' in tests to circumvent problem with leading zero.
Thomas Arendsen Hein <thomas@intevation.de>
parents: 1926
diff changeset
    10
hg --debug commit -m "2" -d "1000000 0"
1043
9344f5dd4488 Update tests
mpm@selenic.com
parents: 814
diff changeset
    11
echo "we should see two history entries"
9344f5dd4488 Update tests
mpm@selenic.com
parents: 814
diff changeset
    12
hg history -v
9344f5dd4488 Update tests
mpm@selenic.com
parents: 814
diff changeset
    13
echo "we should see one log entry for a"
363
ae96b7e1318d Add hg copy
mpm@selenic.com
parents:
diff changeset
    14
hg log a
1043
9344f5dd4488 Update tests
mpm@selenic.com
parents: 814
diff changeset
    15
echo "this should show a revision linked to changeset 0"
3853
c0b449154a90 switch to the .hg/store layout, fix the tests
Benoit Boissinot <benoit.boissinot@ens-lyon.org>
parents: 2223
diff changeset
    16
hg debugindex .hg/store/data/a.i
1043
9344f5dd4488 Update tests
mpm@selenic.com
parents: 814
diff changeset
    17
echo "we should see one log entry for b"
9344f5dd4488 Update tests
mpm@selenic.com
parents: 814
diff changeset
    18
hg log b
9344f5dd4488 Update tests
mpm@selenic.com
parents: 814
diff changeset
    19
echo "this should show a revision linked to changeset 1"
3853
c0b449154a90 switch to the .hg/store layout, fix the tests
Benoit Boissinot <benoit.boissinot@ens-lyon.org>
parents: 2223
diff changeset
    20
hg debugindex .hg/store/data/b.i
1043
9344f5dd4488 Update tests
mpm@selenic.com
parents: 814
diff changeset
    21
9344f5dd4488 Update tests
mpm@selenic.com
parents: 814
diff changeset
    22
echo "this should show the rename information in the metadata"
3853
c0b449154a90 switch to the .hg/store layout, fix the tests
Benoit Boissinot <benoit.boissinot@ens-lyon.org>
parents: 2223
diff changeset
    23
hg debugdata .hg/store/data/b.d 0 | head -3 | tail -2
1043
9344f5dd4488 Update tests
mpm@selenic.com
parents: 814
diff changeset
    24
3853
c0b449154a90 switch to the .hg/store layout, fix the tests
Benoit Boissinot <benoit.boissinot@ens-lyon.org>
parents: 2223
diff changeset
    25
$TESTDIR/md5sum.py .hg/store/data/b.i
462
512d76558bd4 Fix pipe timing for copy test
mpm@selenic.com
parents: 363
diff changeset
    26
hg cat b > bsum
1923
7d83a351a936 fix testsuite for freebsd and one timingissue
Peter van Dijk <peter@dataloss.nl>
parents: 1252
diff changeset
    27
$TESTDIR/md5sum.py bsum
462
512d76558bd4 Fix pipe timing for copy test
mpm@selenic.com
parents: 363
diff changeset
    28
hg cat a > asum
1923
7d83a351a936 fix testsuite for freebsd and one timingissue
Peter van Dijk <peter@dataloss.nl>
parents: 1252
diff changeset
    29
$TESTDIR/md5sum.py asum
363
ae96b7e1318d Add hg copy
mpm@selenic.com
parents:
diff changeset
    30
hg verify