mirror of
https://github.com/facebook/sapling.git
synced 2024-10-09 00:14:35 +03:00
98d9269874
Summary: Create a fork of the Mercurial code that we can use to build server rpms. The hg servers will continue to exist for a few more months while we move the darkstorm and ediscovery use cases off them. In the mean time, we want to start making breaking changes to the client, so let's create a stable copy of the hg code to produce rpms for the hg servers. The fork is based off c7770c78d, the latest hg release. This copies the files as is, then adds some minor tweaks to get it to build: - Disables some lint checks that appear to be bypassed by path - sed replace eden/scm with eden/hg-server - Removed a dependency on scm/telemetry from the edenfs-client tests since scm/telemetry pulls in the original eden/scm/lib/configparser which conflicts with the hg-server conflict parser. allow-large-files Reviewed By: quark-zju Differential Revision: D27632557 fbshipit-source-id: b2f442f4ec000ea08e4d62de068750832198e1f4
241 lines
6.5 KiB
Perl
241 lines
6.5 KiB
Perl
#chg-compatible
|
|
#require no-windows
|
|
|
|
Tests for the journal extension; records bookmark locations.
|
|
|
|
$ newext testmocks <<EOF
|
|
> # mock out util.getuser() and util.makedate() to supply testable values
|
|
> import os
|
|
> from edenscm.mercurial import util
|
|
> def mockgetuser():
|
|
> return 'foobar'
|
|
>
|
|
> def mockmakedate():
|
|
> filename = os.path.join(os.environ['TESTTMP'], 'testtime')
|
|
> try:
|
|
> with open(filename, 'rb') as timef:
|
|
> time = float(timef.read()) + 1
|
|
> except IOError:
|
|
> time = 0.0
|
|
> with open(filename, 'w') as timef:
|
|
> timef.write(str(time))
|
|
> return (time, 0)
|
|
>
|
|
> util.getuser = mockgetuser
|
|
> util.makedate = mockmakedate
|
|
> EOF
|
|
|
|
$ enable journal
|
|
|
|
Setup repo
|
|
|
|
$ hg init repo
|
|
$ cd repo
|
|
|
|
Test empty journal
|
|
|
|
$ hg journal
|
|
previous locations of '.':
|
|
no recorded locations
|
|
$ hg journal foo
|
|
previous locations of 'foo':
|
|
no recorded locations
|
|
$ hg journal -Tjson 2> /dev/null
|
|
[
|
|
]
|
|
|
|
Test that working copy changes are tracked
|
|
|
|
$ echo a > a
|
|
$ hg commit -Aqm a
|
|
$ hg journal
|
|
previous locations of '.':
|
|
cb9a9f314b8b commit -Aqm a
|
|
$ echo b > a
|
|
$ hg commit -Aqm b
|
|
$ hg journal
|
|
previous locations of '.':
|
|
1e6c11564562 commit -Aqm b
|
|
cb9a9f314b8b commit -Aqm a
|
|
$ hg up 'desc(a)'
|
|
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
$ hg journal
|
|
previous locations of '.':
|
|
cb9a9f314b8b up 'desc(a)'
|
|
1e6c11564562 commit -Aqm b
|
|
cb9a9f314b8b commit -Aqm a
|
|
|
|
Test that bookmarks are tracked
|
|
|
|
$ hg book -r tip bar
|
|
$ hg journal bar
|
|
previous locations of 'bar':
|
|
1e6c11564562 book -r tip bar
|
|
$ hg book -f bar
|
|
$ hg journal bar
|
|
previous locations of 'bar':
|
|
cb9a9f314b8b book -f bar
|
|
1e6c11564562 book -r tip bar
|
|
$ hg up
|
|
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
updating bookmark bar
|
|
$ hg journal bar
|
|
previous locations of 'bar':
|
|
1e6c11564562 up
|
|
cb9a9f314b8b book -f bar
|
|
1e6c11564562 book -r tip bar
|
|
|
|
Test that bookmarks and working copy tracking is not mixed
|
|
|
|
$ hg journal
|
|
previous locations of '.':
|
|
1e6c11564562 up
|
|
cb9a9f314b8b up 'desc(a)'
|
|
1e6c11564562 commit -Aqm b
|
|
cb9a9f314b8b commit -Aqm a
|
|
|
|
Test that you can list all entries as well as limit the list or filter on them
|
|
|
|
$ hg book -r tip baz
|
|
$ hg journal --all
|
|
previous locations of the working copy and bookmarks:
|
|
1e6c11564562 baz book -r tip baz
|
|
1e6c11564562 bar up
|
|
1e6c11564562 . up
|
|
cb9a9f314b8b bar book -f bar
|
|
1e6c11564562 bar book -r tip bar
|
|
cb9a9f314b8b . up 'desc(a)'
|
|
1e6c11564562 . commit -Aqm b
|
|
cb9a9f314b8b . commit -Aqm a
|
|
$ hg journal --limit 2
|
|
previous locations of '.':
|
|
1e6c11564562 up
|
|
cb9a9f314b8b up 'desc(a)'
|
|
$ hg journal bar
|
|
previous locations of 'bar':
|
|
1e6c11564562 up
|
|
cb9a9f314b8b book -f bar
|
|
1e6c11564562 book -r tip bar
|
|
$ hg journal foo
|
|
previous locations of 'foo':
|
|
no recorded locations
|
|
$ hg journal .
|
|
previous locations of '.':
|
|
1e6c11564562 up
|
|
cb9a9f314b8b up 'desc(a)'
|
|
1e6c11564562 commit -Aqm b
|
|
cb9a9f314b8b commit -Aqm a
|
|
$ hg journal "re:ba."
|
|
previous locations of 're:ba.':
|
|
1e6c11564562 baz book -r tip baz
|
|
1e6c11564562 bar up
|
|
cb9a9f314b8b bar book -f bar
|
|
1e6c11564562 bar book -r tip bar
|
|
|
|
Test that verbose, JSON, template and commit output work
|
|
|
|
$ hg journal --verbose --all
|
|
previous locations of the working copy and bookmarks:
|
|
000000000000 -> 1e6c11564562 foobar baz 1970-01-01 00:00 +0000 book -r tip baz
|
|
cb9a9f314b8b -> 1e6c11564562 foobar bar 1970-01-01 00:00 +0000 up
|
|
cb9a9f314b8b -> 1e6c11564562 foobar . 1970-01-01 00:00 +0000 up
|
|
1e6c11564562 -> cb9a9f314b8b foobar bar 1970-01-01 00:00 +0000 book -f bar
|
|
000000000000 -> 1e6c11564562 foobar bar 1970-01-01 00:00 +0000 book -r tip bar
|
|
1e6c11564562 -> cb9a9f314b8b foobar . 1970-01-01 00:00 +0000 up 'desc(a)'
|
|
cb9a9f314b8b -> 1e6c11564562 foobar . 1970-01-01 00:00 +0000 commit -Aqm b
|
|
000000000000 -> cb9a9f314b8b foobar . 1970-01-01 00:00 +0000 commit -Aqm a
|
|
$ hg journal --verbose -Tjson
|
|
[
|
|
{
|
|
"command": "up",
|
|
"date": [5.0, 0],
|
|
"name": ".",
|
|
"newhashes": ["1e6c11564562b4ed919baca798bc4338bd299d6a"],
|
|
"oldhashes": ["cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b"],
|
|
"user": "foobar"
|
|
},
|
|
{
|
|
"command": "up 'desc(a)'",
|
|
"date": [2.0, 0],
|
|
"name": ".",
|
|
"newhashes": ["cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b"],
|
|
"oldhashes": ["1e6c11564562b4ed919baca798bc4338bd299d6a"],
|
|
"user": "foobar"
|
|
},
|
|
{
|
|
"command": "commit -Aqm b",
|
|
"date": [1.0, 0],
|
|
"name": ".",
|
|
"newhashes": ["1e6c11564562b4ed919baca798bc4338bd299d6a"],
|
|
"oldhashes": ["cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b"],
|
|
"user": "foobar"
|
|
},
|
|
{
|
|
"command": "commit -Aqm a",
|
|
"date": [0.0, 0],
|
|
"name": ".",
|
|
"newhashes": ["cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b"],
|
|
"oldhashes": ["0000000000000000000000000000000000000000"],
|
|
"user": "foobar"
|
|
}
|
|
]
|
|
|
|
$ cat <<EOF >> $HGRCPATH
|
|
> [templates]
|
|
> j = "{oldhashes % '{node|upper}'} -> {newhashes % '{node|upper}'}
|
|
> - user: {user}
|
|
> - command: {command}
|
|
> - date: {date|rfc3339date}
|
|
> - newhashes: {newhashes}
|
|
> - oldhashes: {oldhashes}
|
|
> "
|
|
> EOF
|
|
$ hg journal -Tj -l1
|
|
CB9A9F314B8B07BA71012FCDBC544B5A4D82FF5B -> 1E6C11564562B4ED919BACA798BC4338BD299D6A
|
|
- user: foobar
|
|
- command: up
|
|
- date: 1970-01-01T00:00:05+00:00
|
|
- newhashes: 1e6c11564562b4ed919baca798bc4338bd299d6a
|
|
- oldhashes: cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b
|
|
|
|
$ hg journal --commit
|
|
previous locations of '.':
|
|
1e6c11564562 up
|
|
commit: 1e6c11564562
|
|
bookmark: bar
|
|
bookmark: baz
|
|
user: test
|
|
date: Thu Jan 01 00:00:00 1970 +0000
|
|
summary: b
|
|
|
|
cb9a9f314b8b up 'desc(a)'
|
|
commit: cb9a9f314b8b
|
|
user: test
|
|
date: Thu Jan 01 00:00:00 1970 +0000
|
|
summary: a
|
|
|
|
1e6c11564562 commit -Aqm b
|
|
commit: 1e6c11564562
|
|
bookmark: bar
|
|
bookmark: baz
|
|
user: test
|
|
date: Thu Jan 01 00:00:00 1970 +0000
|
|
summary: b
|
|
|
|
cb9a9f314b8b commit -Aqm a
|
|
commit: cb9a9f314b8b
|
|
user: test
|
|
date: Thu Jan 01 00:00:00 1970 +0000
|
|
summary: a
|
|
|
|
|
|
Test for behaviour on unexpected storage version information
|
|
|
|
$ printf '42\0' > .hg/namejournal
|
|
$ hg journal
|
|
previous locations of '.':
|
|
abort: unknown journal file version '42'
|
|
[255]
|
|
$ hg book -r tip doomed
|
|
unsupported journal file version '42'
|