Mercurial > hg-stable
changeset 15378:fbebc039687c stable
tests: use $DAEMON_PIDS and killdaemons in largefiles test
$DAEMON_PIDS is used by tests to make sure there will be no leftover
processes, the cycling through ports is needed because they are not
available for a new bind that quickly on some systems.
There are not enough $HGPORT variables available for each hg serve,
so use the killdaemons script before reusing ports.
author | Thomas Arendsen Hein <thomas@intevation.de> |
---|---|
date | Fri, 28 Oct 2011 12:44:19 +0200 |
parents | 107ff02b134d |
children | 3ca419fb435e |
files | tests/test-largefiles.t |
diffstat | 1 files changed, 13 insertions(+), 10 deletions(-) [+] |
line wrap: on
line diff
--- a/tests/test-largefiles.t Fri Oct 28 11:16:39 2011 +0200 +++ b/tests/test-largefiles.t Fri Oct 28 12:44:19 2011 +0200 @@ -742,7 +742,8 @@ $ hg add f1 $ hg com -m "m1" $ cd .. - $ hg serve -R r1 -d -p $HGPORT --pid-file serve.pid + $ hg serve -R r1 -d -p $HGPORT --pid-file hg.pid + $ cat hg.pid >> $DAEMON_PIDS $ hg --config extensions.largefiles=! clone http://localhost:$HGPORT r2 requesting all changes adding changesets @@ -751,11 +752,11 @@ added 1 changesets with 1 changes to 1 files updating to branch default 1 files updated, 0 files merged, 0 files removed, 0 files unresolved - $ kill `cat serve.pid` largefiles clients still work with vanilla servers - $ hg --config extensions.largefiles=! serve -R r1 -d -p $HGPORT --pid-file serve.pid - $ hg clone http://localhost:$HGPORT r3 + $ hg --config extensions.largefiles=! serve -R r1 -d -p $HGPORT1 --pid-file hg.pid + $ cat hg.pid >> $DAEMON_PIDS + $ hg clone http://localhost:$HGPORT1 r3 requesting all changes adding changesets adding manifests @@ -763,7 +764,6 @@ added 1 changesets with 1 changes to 1 files updating to branch default 1 files updated, 0 files merged, 0 files removed, 0 files unresolved - $ kill `cat serve.pid` vanilla clients locked out from largefiles http repos $ mkdir r4 @@ -773,15 +773,18 @@ $ hg add --large f1 $ hg com -m "m1" $ cd .. - $ hg serve -R r4 -d -p $HGPORT --pid-file serve.pid - $ hg --config extensions.largefiles=! clone http://localhost:$HGPORT r5 + $ hg serve -R r4 -d -p $HGPORT2 --pid-file hg.pid + $ cat hg.pid >> $DAEMON_PIDS + $ hg --config extensions.largefiles=! clone http://localhost:$HGPORT2 r5 abort: remote error: This repository uses the largefiles extension. Please enable it in your Mercurial config file. [255] - $ kill `cat serve.pid` + +used all HGPORTs, kill all daemons + $ "$TESTDIR/killdaemons.py" vanilla clients locked out from largefiles ssh repos $ hg --config extensions.largefiles=! clone -e "python $TESTDIR/dummyssh" ssh://user@dummy/r4 r5 @@ -812,14 +815,14 @@ $ echo c2 > f2 $ hg add --large f2 $ hg com -m "m2" - $ hg --config extensions.largefiles=! -R ../r6 serve -d -p $HGPORT --pid-file ../serve.pid + $ hg --config extensions.largefiles=! -R ../r6 serve -d -p $HGPORT --pid-file ../hg.pid + $ cat ../hg.pid >> $DAEMON_PIDS $ hg push http://localhost:$HGPORT pushing to http://localhost:$HGPORT/ searching for changes abort: http://localhost:$HGPORT/ does not appear to be a largefile store [255] $ cd .. - $ kill `cat serve.pid` $ cd ..