Mercurial > hg-allpaths
view tests/basic.t @ 74:879d1f392fa7 1.1.0
Version number set to 1.1.0
author | Marcin Kasperski <Marcin.Kasperski@mekk.waw.pl> |
---|---|
date | Thu, 18 May 2017 17:36:23 +0200 |
parents | 91efe98be062 |
children |
line wrap: on
line source
Let's test all_paths operations. Some locations used during testing: $ WORK_DIR=${WORK_DIR-`pwd`/work} $ rm -rf $WORK_DIR $ export BASE=$WORK_DIR/base $ export REP1=$WORK_DIR/rep1 $ export REP2=$WORK_DIR/rep2 $ export REP3=$WORK_DIR/rep3 Some verifications, just to make sure $ mkdir -p $WORK_DIR $ cd $WORK_DIR $ pwd /tmp/cramtests-*/basic.t/work (glob) First we need appropriate Mercurial configuration file (and variable which ensures it is used). $ export HGRCPATH=$WORK_DIR/hgrc $ mkdir -p $HGRCPATH $ cat > $HGRCPATH/basic.rc << EOF > [ui] > username = Andy Default <default@nowhere.net> > [extensions] > mercurial_all_paths = > EOF We need some repositories to test. $ hg init "$BASE" $ hg init "$REP1" $ hg init "$REP2" $ hg init "$REP3" $ cat > $BASE/.hg/hgrc << EOF > [paths] > remote1=$REP1 > remote2=$REP2 > remote3=$REP3 > EOF Let's test pushing $ cat > $BASE/file.txt << EOF > Some text > EOF $ hg --cwd $BASE add adding file.txt $ hg --cwd $BASE commit -m 'First' $ hg --cwd $BASE pushall pushing to */rep1 (glob) searching for changes adding changesets adding manifests adding file changes added 1 changesets with 1 changes to 1 files pushing to */rep2 (glob) searching for changes adding changesets adding manifests adding file changes added 1 changesets with 1 changes to 1 files pushing to */rep3 (glob) searching for changes adding changesets adding manifests adding file changes added 1 changesets with 1 changes to 1 files $ hg --cwd $REP1 log --template '{rev}: {desc}\n' 0: First $ hg --cwd $REP2 log --template '{rev}: {desc}\n' 0: First $ hg --cwd $REP3 log --template '{rev}: {desc}\n' 0: First Let's also test pulling $ hg --cwd $REP1 update 1 files updated, 0 files merged, 0 files removed, 0 files unresolved $ cat > $REP1/rep1.txt << EOF > Another text > EOF $ hg --cwd $REP1 add adding rep1.txt $ hg --cwd $REP1 commit -m "In repo1" $ hg --cwd $REP2 update 1 files updated, 0 files merged, 0 files removed, 0 files unresolved $ cat >> $REP2/file.txt << EOF > From repo2… > EOF $ hg --cwd $REP2 add $ hg --cwd $REP2 commit -m "In repo2" $ hg --cwd $BASE incomingall comparing with */rep1 (glob) searching for changes changeset: 1:* (glob) tag: tip user: Andy Default <default@nowhere.net> date: .* (re) summary: In repo1 comparing with */rep2 (glob) searching for changes changeset: 1:* (glob) tag: tip user: Andy Default <default@nowhere.net> date: .* (re) summary: In repo2 comparing with */rep3 (glob) searching for changes no changes found $ hg --cwd $BASE pullall pulling from */rep1 (glob) searching for changes adding changesets adding manifests adding file changes added 1 changesets with 1 changes to 1 files (run 'hg update' to get a working copy) pulling from */rep2 (glob) searching for changes adding changesets adding manifests adding file changes added 1 changesets with 1 changes to 1 files (+1 heads) (run 'hg heads' to see heads, 'hg merge' to merge) pulling from */rep3 (glob) searching for changes no changes found $ hg --cwd $BASE log --template '{rev}: {desc}\n' 2: In repo2 1: In repo1 0: First $ hg --cwd $BASE outgoingall comparing with */rep1 (glob) searching for changes changeset: 2:.* (re) tag: tip parent: 0:.* (re) user: Andy Default <default@nowhere.net> date: .* (re) summary: In repo2 comparing with */rep2 (glob) searching for changes changeset: 1:* (glob) user: Andy Default <default@nowhere.net> date: .* (re) summary: In repo1 comparing with */rep3 (glob) searching for changes changeset: 1:* (glob) user: Andy Default <default@nowhere.net> date: .* (re) summary: In repo1 changeset: 2:* (glob) tag: tip parent: 0:* (glob) user: Andy Default <default@nowhere.net> date: .* (re) summary: In repo2 Without remotes those commands do nothing $ hg --cwd $REP3 pullall abort: No paths defined for repository [255] $ hg --cwd $REP3 pushall abort: No paths defined for repository [255] $ hg --cwd $REP3 incomingall abort: No paths defined for repository [255] $ hg --cwd $REP3 outgoingall abort: No paths defined for repository [255] Finally let's test that push options work $ cat > $BASE/br1.txt << EOF > Br1 text > EOF $ hg --cwd $BASE branch br1 marked working directory as branch br1 (branches are permanent and global, did you want a bookmark?) $ hg --cwd $BASE add adding br1.txt $ hg --cwd $BASE commit -m 'Br1' Filtering out warnings in command below avoids hg 4.0 warning about current directory removal which for some mysterious reason shows up only during drone testing. $ hg --cwd $BASE update default 2>/dev/null 1 files updated, 0 files merged, 1 files removed, 0 files unresolved $ cat >> $BASE/file.txt << EOF > later text > EOF $ hg --cwd $BASE commit -m 'Normal' $ hg --cwd $BASE pushall -r default -f pushing to */rep1 (glob) searching for changes adding changesets adding manifests adding file changes added 2 changesets with 2 changes to 1 files (+1 heads) pushing to */rep2 (glob) searching for changes adding changesets adding manifests adding file changes added 1 changesets with 1 changes to 1 files pushing to */rep3 (glob) searching for changes adding changesets adding manifests adding file changes added 2 changesets with 2 changes to 1 files $ hg --cwd $BASE log --template '{rev}: {desc}\n' 4: Normal 3: Br1 2: In repo2 1: In repo1 0: First $ hg --cwd $REP1 log --template '{rev}: {desc}\n' 3: Normal 2: In repo2 1: In repo1 0: First $ hg --cwd $REP2 log --template '{rev}: {desc}\n' 2: Normal 1: In repo2 0: First $ hg --cwd $REP3 log --template '{rev}: {desc}\n' 2: Normal 1: In repo2 0: First