sapling/eden/scm/tests/test-identify.t
Jun Wu eb4c007145 changelog: use Rust RevlogIndex for partialmatch
Summary:
I dropped the special case of wdir handling. With the hope that we will handle
the virtual commits differently eventually (ex. drop special cases, insert real
commits to Rust DAG but do not flush them to disk, support multiple wdir
virtual commits, null is no longer an ancestor of every commit).

`test-listkeyspatterns.t` is changed because `0` no longer resolves to `null`.

Reviewed By: DurhamG

Differential Revision: D22368836

fbshipit-source-id: 14b9914506ef59bb69363b602d646ec89ce0d89a
2020-07-17 22:23:04 -07:00

158 lines
3.1 KiB
Perl

#chg-compatible
#require serve
#if no-outer-repo
no repo
$ hg id
abort: there is no Mercurial repository here (.hg not found)
[255]
#endif
$ configure dummyssh
create repo
$ hg init test
$ cd test
$ echo a > a
$ hg ci -Ama
adding a
basic id usage
$ hg id
cb9a9f314b8b
$ hg id --debug
cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b
$ hg id -q
cb9a9f314b8b
$ hg id -v
cb9a9f314b8b
with options
$ hg id -r.
cb9a9f314b8b
$ hg id -n
0
$ hg id -b
default
$ hg id -i
cb9a9f314b8b
$ hg id -n -t -b -i
cb9a9f314b8b 0 default
$ hg id -Tjson
[
{
"bookmarks": [],
"dirty": "",
"id": "cb9a9f314b8b",
"node": "ffffffffffffffffffffffffffffffffffffffff",
"parents": [{"node": "cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b", "rev": 0}]
}
]
test template keywords and functions which require changectx:
(The Rust layer does not special handle the wdir commit hash so shortest does
not "work" here. In the future we want to change virtual commits handling to
use normal (non-special-cased) in-memory-only commits in the Rust DAG instead
of special casing them in various APIs (ex. partialmatch))
$ hg id -T '{rev} {node|shortest}\n'
2147483647 ffffffffffffffffffffffffffffffffffffffff
$ hg id -T '{parents % "{rev} {node|shortest} {desc}\n"}'
0 cb9a a
with modifications
$ echo b > a
$ hg id -n -t -b -i
cb9a9f314b8b+ 0+ default
$ hg id -Tjson
[
{
"bookmarks": [],
"dirty": "+",
"id": "cb9a9f314b8b+",
"node": "ffffffffffffffffffffffffffffffffffffffff",
"parents": [{"node": "cb9a9f314b8b07ba71012fcdbc544b5a4d82ff5b", "rev": 0}]
}
]
other local repo
$ cd ..
$ hg -R test id
cb9a9f314b8b+
#if no-outer-repo
$ hg id test
cb9a9f314b8b+ tip
#endif
with remote ssh repo
$ cd test
$ hg id ssh://user@dummy/test
cb9a9f314b8b
remote with rev number?
$ hg id -n ssh://user@dummy/test
abort: can't query remote revision number or branch
[255]
remote with branch?
$ hg id -b ssh://user@dummy/test
abort: can't query remote revision number or branch
[255]
test bookmark support
$ hg bookmark Y
$ hg bookmark Z
$ hg bookmarks
Y 0:cb9a9f314b8b
* Z 0:cb9a9f314b8b
$ hg id
cb9a9f314b8b+ Y/Z
$ hg id --bookmarks
Y Z
test remote identify with bookmarks
$ hg id ssh://user@dummy/test
cb9a9f314b8b Y/Z
$ hg id --bookmarks ssh://user@dummy/test
Y Z
$ hg id -r . ssh://user@dummy/test
cb9a9f314b8b Y/Z
$ hg id --bookmarks -r . ssh://user@dummy/test
Y Z
test invalid lookup
$ hg id -r noNoNO ssh://user@dummy/test
abort: unknown revision 'noNoNO'!
[255]
Make sure we do not obscure unknown requires file entries (issue2649)
$ echo fake >> .hg/requires
$ hg id
abort: repository requires features unknown to this Mercurial: fake!
(see https://mercurial-scm.org/wiki/MissingRequirement for more information)
[255]
$ cd ..
#if no-outer-repo
$ hg id test
abort: repository requires features unknown to this Mercurial: fake!
(see https://mercurial-scm.org/wiki/MissingRequirement for more information)
[255]
#endif