test-convert-hg-source.t
140 lines
| 3.2 KiB
| text/troff
|
Tads3Lexer
/ tests / test-convert-hg-source.t
Mads Kiilerich
|
r15442 | $ "$TESTDIR/hghave" execbit || exit 80 | ||
Matt Mackall
|
r12526 | |||
$ cat >> $HGRCPATH <<EOF | ||||
> [extensions] | ||||
> convert= | ||||
> [convert] | ||||
> hg.saverev=False | ||||
> EOF | ||||
$ hg init orig | ||||
$ cd orig | ||||
$ echo foo > foo | ||||
$ echo bar > bar | ||||
$ hg ci -qAm 'add foo bar' -d '0 0' | ||||
$ echo >> foo | ||||
$ hg ci -m 'change foo' -d '1 0' | ||||
$ hg up -qC 0 | ||||
$ hg copy --after --force foo bar | ||||
$ hg copy foo baz | ||||
$ hg ci -m 'make bar and baz copies of foo' -d '2 0' | ||||
created new head | ||||
Edouard Gomez
|
r13866 | $ hg bookmark premerge1 | ||
David Soria Parra
|
r16708 | $ hg merge -r 1 | ||
Matt Mackall
|
r12526 | merging baz and foo to baz | ||
1 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m 'merge local copy' -d '3 0' | ||||
$ hg up -C 1 | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Edouard Gomez
|
r13866 | $ hg bookmark premerge2 | ||
Matt Mackall
|
r12526 | $ hg merge 2 | ||
merging foo and baz to baz | ||||
1 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg ci -m 'merge remote copy' -d '4 0' | ||||
created new head | ||||
$ chmod +x baz | ||||
$ hg ci -m 'mark baz executable' -d '5 0' | ||||
$ cd .. | ||||
$ hg convert --datesort orig new 2>&1 | grep -v 'subversion python bindings could not be loaded' | ||||
initializing destination new repository | ||||
scanning source... | ||||
sorting... | ||||
converting... | ||||
Patrick Mezard
|
r13968 | 5 add foo bar | ||
4 change foo | ||||
3 make bar and baz copies of foo | ||||
2 merge local copy | ||||
1 merge remote copy | ||||
0 mark baz executable | ||||
Edouard Gomez
|
r13866 | updating bookmarks | ||
Matt Mackall
|
r12526 | $ cd new | ||
$ hg out ../orig | ||||
comparing with ../orig | ||||
searching for changes | ||||
no changes found | ||||
[1] | ||||
Edouard Gomez
|
r13866 | $ hg bookmarks | ||
premerge1 3:973ef48a98a4 | ||||
Patrick Mezard
|
r13969 | premerge2 5:13d9b87cf8f8 | ||
Matt Mackall
|
r12526 | $ cd .. | ||
check shamap LF and CRLF handling | ||||
$ cat > rewrite.py <<EOF | ||||
> import sys | ||||
> # Interlace LF and CRLF | ||||
> lines = [(l.rstrip() + ((i % 2) and '\n' or '\r\n')) | ||||
> for i, l in enumerate(file(sys.argv[1]))] | ||||
> file(sys.argv[1], 'wb').write(''.join(lines)) | ||||
> EOF | ||||
$ python rewrite.py new/.hg/shamap | ||||
$ cd orig | ||||
$ hg up -qC 1 | ||||
$ echo foo >> foo | ||||
$ hg ci -qm 'change foo again' | ||||
$ hg up -qC 2 | ||||
$ echo foo >> foo | ||||
$ hg ci -qm 'change foo again again' | ||||
$ cd .. | ||||
$ hg convert --datesort orig new 2>&1 | grep -v 'subversion python bindings could not be loaded' | ||||
scanning source... | ||||
sorting... | ||||
converting... | ||||
1 change foo again again | ||||
0 change foo again | ||||
Edouard Gomez
|
r13866 | updating bookmarks | ||
Matt Mackall
|
r12526 | |||
init broken repository | ||||
$ hg init broken | ||||
$ cd broken | ||||
$ echo a >> a | ||||
$ echo b >> b | ||||
$ hg ci -qAm init | ||||
$ echo a >> a | ||||
$ echo b >> b | ||||
$ hg copy b c | ||||
$ hg ci -qAm changeall | ||||
$ hg up -qC 0 | ||||
$ echo bc >> b | ||||
$ hg ci -m changebagain | ||||
created new head | ||||
$ HGMERGE=internal:local hg -q merge | ||||
$ hg ci -m merge | ||||
$ hg mv b d | ||||
$ hg ci -m moveb | ||||
break it | ||||
$ rm .hg/store/data/b.* | ||||
$ cd .. | ||||
$ hg --config convert.hg.ignoreerrors=True convert broken fixed | ||||
initializing destination fixed repository | ||||
scanning source... | ||||
sorting... | ||||
converting... | ||||
4 init | ||||
ignoring: data/b.i@1e88685f5dde: no match found | ||||
3 changeall | ||||
2 changebagain | ||||
1 merge | ||||
0 moveb | ||||
$ hg -R fixed verify | ||||
checking changesets | ||||
checking manifests | ||||
crosschecking files in changesets and manifests | ||||
checking files | ||||
3 files, 5 changesets, 5 total revisions | ||||
manifest -r 0 | ||||
$ hg -R fixed manifest -r 0 | ||||
a | ||||
manifest -r tip | ||||
$ hg -R fixed manifest -r tip | ||||
a | ||||
c | ||||
d | ||||