test-share-safe.t
626 lines
| 17.6 KiB
| text/troff
|
Tads3Lexer
/ tests / test-share-safe.t
Pulkit Goyal
|
r46055 | setup | ||
$ cat >> $HGRCPATH <<EOF | ||||
> [extensions] | ||||
> share = | ||||
> [format] | ||||
Pulkit Goyal
|
r47052 | > use-share-safe = True | ||
r47028 | > [storage] | |||
> revlog.persistent-nodemap.slow-path=allow | ||||
Pulkit Goyal
|
r46055 | > EOF | ||
prepare source repo | ||||
$ hg init source | ||||
$ cd source | ||||
$ cat .hg/requires | ||||
Pulkit Goyal
|
r47052 | share-safe | ||
Pulkit Goyal
|
r46055 | $ cat .hg/store/requires | ||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
sparserevlog | ||||
store | ||||
$ hg debugrequirements | ||||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
Pulkit Goyal
|
r47052 | share-safe | ||
Pulkit Goyal
|
r46055 | sparserevlog | ||
store | ||||
$ echo a > a | ||||
$ hg ci -Aqm "added a" | ||||
$ echo b > b | ||||
$ hg ci -Aqm "added b" | ||||
Pulkit Goyal
|
r46058 | |||
$ HGEDITOR=cat hg config --shared | ||||
abort: repository is not shared; can't use --shared | ||||
Martin von Zweigbergk
|
r46431 | [10] | ||
Pulkit Goyal
|
r46055 | $ cd .. | ||
Create a shared repo and check the requirements are shared and read correctly | ||||
$ hg share source shared1 | ||||
updating working directory | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd shared1 | ||||
$ cat .hg/requires | ||||
Pulkit Goyal
|
r47052 | share-safe | ||
Pulkit Goyal
|
r46055 | shared | ||
$ hg debugrequirements -R ../source | ||||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
Pulkit Goyal
|
r47052 | share-safe | ||
Pulkit Goyal
|
r46055 | sparserevlog | ||
store | ||||
$ hg debugrequirements | ||||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
Pulkit Goyal
|
r47052 | share-safe | ||
Pulkit Goyal
|
r46055 | shared | ||
sparserevlog | ||||
store | ||||
$ echo c > c | ||||
$ hg ci -Aqm "added c" | ||||
Pulkit Goyal
|
r46057 | Check that config of the source repository is also loaded | ||
$ hg showconfig ui.curses | ||||
[1] | ||||
$ echo "[ui]" >> ../source/.hg/hgrc | ||||
$ echo "curses=true" >> ../source/.hg/hgrc | ||||
$ hg showconfig ui.curses | ||||
true | ||||
Pulkit Goyal
|
r46366 | Test that extensions of source repository are also loaded | ||
$ hg debugextensions | ||||
share | ||||
$ hg extdiff -p echo | ||||
hg: unknown command 'extdiff' | ||||
'extdiff' is provided by the following extension: | ||||
extdiff command to allow external programs to compare revisions | ||||
(use 'hg help extensions' for information on enabling extensions) | ||||
Martin von Zweigbergk
|
r46888 | [10] | ||
Pulkit Goyal
|
r46366 | |||
$ echo "[extensions]" >> ../source/.hg/hgrc | ||||
$ echo "extdiff=" >> ../source/.hg/hgrc | ||||
$ hg debugextensions -R ../source | ||||
extdiff | ||||
share | ||||
$ hg extdiff -R ../source -p echo | ||||
Pulkit Goyal
|
r46367 | BROKEN: the command below will not work if config of shared source is not loaded | ||
on dispatch but debugextensions says that extension | ||||
Pulkit Goyal
|
r46366 | is loaded | ||
$ hg debugextensions | ||||
extdiff | ||||
share | ||||
$ hg extdiff -p echo | ||||
Pulkit Goyal
|
r46057 | However, local .hg/hgrc should override the config set by share source | ||
$ echo "[ui]" >> .hg/hgrc | ||||
$ echo "curses=false" >> .hg/hgrc | ||||
$ hg showconfig ui.curses | ||||
false | ||||
Pulkit Goyal
|
r46058 | $ HGEDITOR=cat hg config --shared | ||
[ui] | ||||
curses=true | ||||
Pulkit Goyal
|
r46366 | [extensions] | ||
extdiff= | ||||
Pulkit Goyal
|
r46058 | |||
$ HGEDITOR=cat hg config --local | ||||
[ui] | ||||
curses=false | ||||
Pulkit Goyal
|
r46057 | Testing that hooks set in source repository also runs in shared repo | ||
$ cd ../source | ||||
$ cat <<EOF >> .hg/hgrc | ||||
> [extensions] | ||||
> hooklib= | ||||
> [hooks] | ||||
> pretxnchangegroup.reject_merge_commits = \ | ||||
> python:hgext.hooklib.reject_merge_commits.hook | ||||
> EOF | ||||
$ cd .. | ||||
$ hg clone source cloned | ||||
updating to branch default | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd cloned | ||||
$ hg up 0 | ||||
0 files updated, 0 files merged, 2 files removed, 0 files unresolved | ||||
$ echo bar > bar | ||||
$ hg ci -Aqm "added bar" | ||||
$ hg merge | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m "merge commit" | ||||
$ hg push ../source | ||||
pushing to ../source | ||||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
error: pretxnchangegroup.reject_merge_commits hook failed: bcde3522682d rejected as merge on the same branch. Please consider rebase. | ||||
transaction abort! | ||||
rollback completed | ||||
abort: bcde3522682d rejected as merge on the same branch. Please consider rebase. | ||||
[255] | ||||
$ hg push ../shared1 | ||||
pushing to ../shared1 | ||||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
error: pretxnchangegroup.reject_merge_commits hook failed: bcde3522682d rejected as merge on the same branch. Please consider rebase. | ||||
transaction abort! | ||||
rollback completed | ||||
abort: bcde3522682d rejected as merge on the same branch. Please consider rebase. | ||||
[255] | ||||
Test that if share source config is untrusted, we dont read it | ||||
$ cd ../shared1 | ||||
$ cat << EOF > $TESTTMP/untrusted.py | ||||
> from mercurial import scmutil, util | ||||
> def uisetup(ui): | ||||
> class untrustedui(ui.__class__): | ||||
> def _trusted(self, fp, f): | ||||
> if util.normpath(fp.name).endswith(b'source/.hg/hgrc'): | ||||
> return False | ||||
> return super(untrustedui, self)._trusted(fp, f) | ||||
> ui.__class__ = untrustedui | ||||
> EOF | ||||
$ hg showconfig hooks | ||||
hooks.pretxnchangegroup.reject_merge_commits=python:hgext.hooklib.reject_merge_commits.hook | ||||
$ hg showconfig hooks --config extensions.untrusted=$TESTTMP/untrusted.py | ||||
[1] | ||||
Pulkit Goyal
|
r46059 | Update the source repository format and check that shared repo works | ||
$ cd ../source | ||||
Pulkit Goyal
|
r46114 | |||
Disable zstd related tests because its not present on pure version | ||||
#if zstd | ||||
Pulkit Goyal
|
r46059 | $ echo "[format]" >> .hg/hgrc | ||
$ echo "revlog-compression=zstd" >> .hg/hgrc | ||||
$ hg debugupgraderepo --run -q | ||||
upgrade will perform the following actions: | ||||
requirements | ||||
Pulkit Goyal
|
r47052 | preserved: dotencode, fncache, generaldelta, revlogv1, share-safe, sparserevlog, store | ||
Pulkit Goyal
|
r46059 | added: revlog-compression-zstd | ||
r46649 | processed revlogs: | |||
- all-filelogs | ||||
- changelog | ||||
- manifest | ||||
Pulkit Goyal
|
r46059 | $ hg log -r . | ||
changeset: 1:5f6d8a4bf34a | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: added b | ||||
Pulkit Goyal
|
r46114 | #endif | ||
$ echo "[format]" >> .hg/hgrc | ||||
$ echo "use-persistent-nodemap=True" >> .hg/hgrc | ||||
$ hg debugupgraderepo --run -q -R ../shared1 | ||||
abort: cannot upgrade repository; unsupported source requirement: shared | ||||
[255] | ||||
$ hg debugupgraderepo --run -q | ||||
upgrade will perform the following actions: | ||||
requirements | ||||
Pulkit Goyal
|
r47052 | preserved: dotencode, fncache, generaldelta, revlogv1, share-safe, sparserevlog, store (no-zstd !) | ||
preserved: dotencode, fncache, generaldelta, revlog-compression-zstd, revlogv1, share-safe, sparserevlog, store (zstd !) | ||||
Pulkit Goyal
|
r46114 | added: persistent-nodemap | ||
r46649 | processed revlogs: | |||
- all-filelogs | ||||
- changelog | ||||
- manifest | ||||
Pulkit Goyal
|
r46114 | $ hg log -r . | ||
changeset: 1:5f6d8a4bf34a | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: added b | ||||
Pulkit Goyal
|
r46059 | Shared one should work | ||
$ cd ../shared1 | ||||
$ hg log -r . | ||||
changeset: 2:155349b645be | ||||
tag: tip | ||||
user: test | ||||
date: Thu Jan 01 00:00:00 1970 +0000 | ||||
summary: added c | ||||
Pulkit Goyal
|
r46368 | |||
Testing that nonsharedrc is loaded for source and not shared | ||||
$ cd ../source | ||||
$ touch .hg/hgrc-not-shared | ||||
$ echo "[ui]" >> .hg/hgrc-not-shared | ||||
$ echo "traceback=true" >> .hg/hgrc-not-shared | ||||
$ hg showconfig ui.traceback | ||||
true | ||||
$ HGEDITOR=cat hg config --non-shared | ||||
[ui] | ||||
traceback=true | ||||
$ cd ../shared1 | ||||
$ hg showconfig ui.traceback | ||||
[1] | ||||
Pulkit Goyal
|
r46057 | Unsharing works | ||
Pulkit Goyal
|
r46055 | $ hg unshare | ||
Pulkit Goyal
|
r46057 | |||
Test that source config is added to the shared one after unshare, and the config | ||||
of current repo is still respected over the config which came from source config | ||||
$ cd ../cloned | ||||
$ hg push ../shared1 | ||||
pushing to ../shared1 | ||||
searching for changes | ||||
adding changesets | ||||
adding manifests | ||||
adding file changes | ||||
error: pretxnchangegroup.reject_merge_commits hook failed: bcde3522682d rejected as merge on the same branch. Please consider rebase. | ||||
transaction abort! | ||||
rollback completed | ||||
abort: bcde3522682d rejected as merge on the same branch. Please consider rebase. | ||||
[255] | ||||
$ hg showconfig ui.curses -R ../shared1 | ||||
false | ||||
Pulkit Goyal
|
r46617 | |||
$ cd ../ | ||||
Test that upgrading using debugupgraderepo works | ||||
================================================= | ||||
Pulkit Goyal
|
r47052 | $ hg init non-share-safe --config format.use-share-safe=false | ||
Pulkit Goyal
|
r46617 | $ cd non-share-safe | ||
$ hg debugrequirements | ||||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
sparserevlog | ||||
store | ||||
$ echo foo > foo | ||||
$ hg ci -Aqm 'added foo' | ||||
$ echo bar > bar | ||||
$ hg ci -Aqm 'added bar' | ||||
Create a share before upgrading | ||||
$ cd .. | ||||
$ hg share non-share-safe nss-share | ||||
updating working directory | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg debugrequirements -R nss-share | ||||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
shared | ||||
sparserevlog | ||||
store | ||||
$ cd non-share-safe | ||||
Upgrade | ||||
$ hg debugupgraderepo -q | ||||
requirements | ||||
preserved: dotencode, fncache, generaldelta, revlogv1, sparserevlog, store | ||||
Pulkit Goyal
|
r47052 | added: share-safe | ||
Pulkit Goyal
|
r46617 | |||
r46649 | processed revlogs: | |||
- all-filelogs | ||||
- changelog | ||||
- manifest | ||||
Pulkit Goyal
|
r47095 | $ hg debugupgraderepo --run | ||
Pulkit Goyal
|
r46617 | upgrade will perform the following actions: | ||
requirements | ||||
preserved: dotencode, fncache, generaldelta, revlogv1, sparserevlog, store | ||||
Pulkit Goyal
|
r47052 | added: share-safe | ||
Pulkit Goyal
|
r46617 | |||
Pulkit Goyal
|
r47095 | share-safe | ||
Upgrades a repository to share-safe format so that future shares of this repository share its requirements and configs. | ||||
r46649 | processed revlogs: | |||
- all-filelogs | ||||
- changelog | ||||
- manifest | ||||
Pulkit Goyal
|
r47095 | beginning upgrade... | ||
repository locked and read-only | ||||
creating temporary repository to stage upgraded data: $TESTTMP/non-share-safe/.hg/upgrade.* (glob) | ||||
(it is safe to interrupt this process any time before data migration completes) | ||||
migrating 6 total revisions (2 in filelogs, 2 in manifests, 2 in changelog) | ||||
migrating 626 bytes in store; 271 bytes tracked data | ||||
migrating 2 filelogs containing 2 revisions (138 bytes in store; 8 bytes tracked data) | ||||
finished migrating 2 filelog revisions across 2 filelogs; change in size: 0 bytes | ||||
migrating 1 manifests containing 2 revisions (230 bytes in store; 135 bytes tracked data) | ||||
finished migrating 2 manifest revisions across 1 manifests; change in size: 0 bytes | ||||
migrating changelog containing 2 revisions (258 bytes in store; 128 bytes tracked data) | ||||
finished migrating 2 changelog revisions; change in size: 0 bytes | ||||
finished migrating 6 total revisions; total change in store size: 0 bytes | ||||
copying phaseroots | ||||
data fully upgraded in a temporary repository | ||||
marking source repository as being upgraded; clients will be unable to read from repository | ||||
starting in-place swap of repository data | ||||
replaced files will be backed up at $TESTTMP/non-share-safe/.hg/upgradebackup.* (glob) | ||||
replacing store... | ||||
store replacement complete; repository was inconsistent for *s (glob) | ||||
finalizing requirements file and making repository readable again | ||||
removing temporary repository $TESTTMP/non-share-safe/.hg/upgrade.* (glob) | ||||
copy of old repository backed up at $TESTTMP/non-share-safe/.hg/upgradebackup.* (glob) | ||||
the old repository will not be deleted; remove it to free up disk space once the upgraded repository is verified | ||||
Pulkit Goyal
|
r46617 | repository upgraded to share safe mode, existing shares will still work in old non-safe mode. Re-share existing shares to use them in safe mode New shares will be created in safe mode. | ||
$ hg debugrequirements | ||||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
Pulkit Goyal
|
r47052 | share-safe | ||
Pulkit Goyal
|
r46617 | sparserevlog | ||
store | ||||
$ cat .hg/requires | ||||
Pulkit Goyal
|
r47052 | share-safe | ||
Pulkit Goyal
|
r46617 | |||
$ cat .hg/store/requires | ||||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
sparserevlog | ||||
store | ||||
$ hg log -GT "{node}: {desc}\n" | ||||
@ f63db81e6dde1d9c78814167f77fb1fb49283f4f: added bar | ||||
| | ||||
o f3ba8b99bb6f897c87bbc1c07b75c6ddf43a4f77: added foo | ||||
Pulkit Goyal
|
r47049 | Make sure existing shares dont work with default config | ||
Pulkit Goyal
|
r46855 | |||
Pulkit Goyal
|
r46617 | $ hg log -GT "{node}: {desc}\n" -R ../nss-share | ||
Pulkit Goyal
|
r47049 | abort: version mismatch: source uses share-safe functionality while the current share does not | ||
[255] | ||||
Pulkit Goyal
|
r46618 | |||
Create a safe share from upgrade one | ||||
$ cd .. | ||||
$ hg share non-share-safe ss-share | ||||
updating working directory | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd ss-share | ||||
$ hg log -GT "{node}: {desc}\n" | ||||
@ f63db81e6dde1d9c78814167f77fb1fb49283f4f: added bar | ||||
| | ||||
o f3ba8b99bb6f897c87bbc1c07b75c6ddf43a4f77: added foo | ||||
$ cd ../non-share-safe | ||||
Test that downgrading works too | ||||
$ cat >> $HGRCPATH <<EOF | ||||
> [extensions] | ||||
> share = | ||||
> [format] | ||||
Pulkit Goyal
|
r47052 | > use-share-safe = False | ||
Pulkit Goyal
|
r46618 | > EOF | ||
$ hg debugupgraderepo -q | ||||
requirements | ||||
preserved: dotencode, fncache, generaldelta, revlogv1, sparserevlog, store | ||||
Pulkit Goyal
|
r47052 | removed: share-safe | ||
Pulkit Goyal
|
r46618 | |||
r46649 | processed revlogs: | |||
- all-filelogs | ||||
- changelog | ||||
- manifest | ||||
Pulkit Goyal
|
r47095 | $ hg debugupgraderepo --run | ||
Pulkit Goyal
|
r46618 | upgrade will perform the following actions: | ||
requirements | ||||
preserved: dotencode, fncache, generaldelta, revlogv1, sparserevlog, store | ||||
Pulkit Goyal
|
r47052 | removed: share-safe | ||
Pulkit Goyal
|
r46618 | |||
r46649 | processed revlogs: | |||
- all-filelogs | ||||
- changelog | ||||
- manifest | ||||
Pulkit Goyal
|
r47095 | beginning upgrade... | ||
repository locked and read-only | ||||
creating temporary repository to stage upgraded data: $TESTTMP/non-share-safe/.hg/upgrade.* (glob) | ||||
(it is safe to interrupt this process any time before data migration completes) | ||||
migrating 6 total revisions (2 in filelogs, 2 in manifests, 2 in changelog) | ||||
migrating 626 bytes in store; 271 bytes tracked data | ||||
migrating 2 filelogs containing 2 revisions (138 bytes in store; 8 bytes tracked data) | ||||
finished migrating 2 filelog revisions across 2 filelogs; change in size: 0 bytes | ||||
migrating 1 manifests containing 2 revisions (230 bytes in store; 135 bytes tracked data) | ||||
finished migrating 2 manifest revisions across 1 manifests; change in size: 0 bytes | ||||
migrating changelog containing 2 revisions (258 bytes in store; 128 bytes tracked data) | ||||
finished migrating 2 changelog revisions; change in size: 0 bytes | ||||
finished migrating 6 total revisions; total change in store size: 0 bytes | ||||
copying phaseroots | ||||
copying requires | ||||
data fully upgraded in a temporary repository | ||||
marking source repository as being upgraded; clients will be unable to read from repository | ||||
starting in-place swap of repository data | ||||
replaced files will be backed up at $TESTTMP/non-share-safe/.hg/upgradebackup.* (glob) | ||||
replacing store... | ||||
store replacement complete; repository was inconsistent for *s (glob) | ||||
finalizing requirements file and making repository readable again | ||||
removing temporary repository $TESTTMP/non-share-safe/.hg/upgrade.* (glob) | ||||
copy of old repository backed up at $TESTTMP/non-share-safe/.hg/upgradebackup.* (glob) | ||||
the old repository will not be deleted; remove it to free up disk space once the upgraded repository is verified | ||||
Pulkit Goyal
|
r46618 | repository downgraded to not use share safe mode, existing shares will not work and needs to be reshared. | ||
$ hg debugrequirements | ||||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
sparserevlog | ||||
store | ||||
$ cat .hg/requires | ||||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
sparserevlog | ||||
store | ||||
$ test -f .hg/store/requires | ||||
[1] | ||||
$ hg log -GT "{node}: {desc}\n" | ||||
@ f63db81e6dde1d9c78814167f77fb1fb49283f4f: added bar | ||||
| | ||||
o f3ba8b99bb6f897c87bbc1c07b75c6ddf43a4f77: added foo | ||||
Make sure existing shares still works | ||||
$ hg log -GT "{node}: {desc}\n" -R ../nss-share | ||||
@ f63db81e6dde1d9c78814167f77fb1fb49283f4f: added bar | ||||
| | ||||
o f3ba8b99bb6f897c87bbc1c07b75c6ddf43a4f77: added foo | ||||
$ hg log -GT "{node}: {desc}\n" -R ../ss-share | ||||
abort: share source does not support exp-sharesafe requirement | ||||
[255] | ||||
Pulkit Goyal
|
r46852 | |||
Pulkit Goyal
|
r46853 | Testing automatic downgrade of shares when config is set | ||
$ touch ../ss-share/.hg/wlock | ||||
Pulkit Goyal
|
r47050 | $ hg log -GT "{node}: {desc}\n" -R ../ss-share --config share.safe-mismatch.source-not-safe=downgrade-abort | ||
Pulkit Goyal
|
r46853 | abort: failed to downgrade share, got error: Lock held | ||
[255] | ||||
$ rm ../ss-share/.hg/wlock | ||||
Pulkit Goyal
|
r47050 | $ hg log -GT "{node}: {desc}\n" -R ../ss-share --config share.safe-mismatch.source-not-safe=downgrade-abort | ||
Pulkit Goyal
|
r46853 | repository downgraded to not use share-safe mode | ||
@ f63db81e6dde1d9c78814167f77fb1fb49283f4f: added bar | ||||
| | ||||
o f3ba8b99bb6f897c87bbc1c07b75c6ddf43a4f77: added foo | ||||
$ hg log -GT "{node}: {desc}\n" -R ../ss-share | ||||
@ f63db81e6dde1d9c78814167f77fb1fb49283f4f: added bar | ||||
| | ||||
o f3ba8b99bb6f897c87bbc1c07b75c6ddf43a4f77: added foo | ||||
Pulkit Goyal
|
r46852 | |||
Testing automatic upgrade of shares when config is set | ||||
Pulkit Goyal
|
r47052 | $ hg debugupgraderepo -q --run --config format.use-share-safe=True | ||
Pulkit Goyal
|
r46852 | upgrade will perform the following actions: | ||
requirements | ||||
preserved: dotencode, fncache, generaldelta, revlogv1, sparserevlog, store | ||||
Pulkit Goyal
|
r47052 | added: share-safe | ||
Pulkit Goyal
|
r46852 | |||
processed revlogs: | ||||
- all-filelogs | ||||
- changelog | ||||
- manifest | ||||
repository upgraded to share safe mode, existing shares will still work in old non-safe mode. Re-share existing shares to use them in safe mode New shares will be created in safe mode. | ||||
$ hg debugrequirements | ||||
dotencode | ||||
fncache | ||||
generaldelta | ||||
revlogv1 | ||||
Pulkit Goyal
|
r47052 | share-safe | ||
Pulkit Goyal
|
r46852 | sparserevlog | ||
store | ||||
$ hg log -GT "{node}: {desc}\n" -R ../nss-share | ||||
Pulkit Goyal
|
r47049 | abort: version mismatch: source uses share-safe functionality while the current share does not | ||
[255] | ||||
Pulkit Goyal
|
r46852 | |||
Check that if lock is taken, upgrade fails but read operation are successful | ||||
Pulkit Goyal
|
r47050 | $ hg log -GT "{node}: {desc}\n" -R ../nss-share --config share.safe-mismatch.source-safe=upgra | ||
abort: share-safe mismatch with source. | ||||
Unrecognized value 'upgra' of `share.safe-mismatch.source-safe` set. | ||||
(run `hg help config.share.safe-mismatch.source-safe`) | ||||
[255] | ||||
Pulkit Goyal
|
r46852 | $ touch ../nss-share/.hg/wlock | ||
Pulkit Goyal
|
r47050 | $ hg log -GT "{node}: {desc}\n" -R ../nss-share --config share.safe-mismatch.source-safe=upgrade-allow | ||
Pulkit Goyal
|
r46852 | failed to upgrade share, got error: Lock held | ||
@ f63db81e6dde1d9c78814167f77fb1fb49283f4f: added bar | ||||
| | ||||
o f3ba8b99bb6f897c87bbc1c07b75c6ddf43a4f77: added foo | ||||
Pulkit Goyal
|
r46855 | |||
Pulkit Goyal
|
r47051 | $ hg log -GT "{node}: {desc}\n" -R ../nss-share --config share.safe-mismatch.source-safe=upgrade-allow --config share.safe-mismatch.source-safe.warn=False | ||
Pulkit Goyal
|
r46855 | @ f63db81e6dde1d9c78814167f77fb1fb49283f4f: added bar | ||
| | ||||
o f3ba8b99bb6f897c87bbc1c07b75c6ddf43a4f77: added foo | ||||
Pulkit Goyal
|
r47050 | $ hg log -GT "{node}: {desc}\n" -R ../nss-share --config share.safe-mismatch.source-safe=upgrade-abort | ||
Pulkit Goyal
|
r46856 | abort: failed to upgrade share, got error: Lock held | ||
[255] | ||||
Pulkit Goyal
|
r46852 | $ rm ../nss-share/.hg/wlock | ||
Pulkit Goyal
|
r47050 | $ hg log -GT "{node}: {desc}\n" -R ../nss-share --config share.safe-mismatch.source-safe=upgrade-abort | ||
Pulkit Goyal
|
r46852 | repository upgraded to use share-safe mode | ||
@ f63db81e6dde1d9c78814167f77fb1fb49283f4f: added bar | ||||
| | ||||
o f3ba8b99bb6f897c87bbc1c07b75c6ddf43a4f77: added foo | ||||
Test that unshare works | ||||
$ hg unshare -R ../nss-share | ||||
$ hg log -GT "{node}: {desc}\n" -R ../nss-share | ||||
@ f63db81e6dde1d9c78814167f77fb1fb49283f4f: added bar | ||||
| | ||||
o f3ba8b99bb6f897c87bbc1c07b75c6ddf43a4f77: added foo | ||||