# HG changeset patch # User Paul Tonelli # Date 1400764992 -7200 # Node ID cdde1656346f75ee492404b8560f7b8b12d3fbe9 # Parent e05b0cf920bba927ad08c3e436ea8a19203efc58 client: add 'hidden' property to show hidden changesets. This enables interactions with the obsolete changesets in the repository: - add the attribute in client class - add the keyword to the relevant commands - enable log without hidden changesets even when self.hidden is True - add a few tests with the hidden keyword This changeset mirrors the behavior of the mercurial global command --hidden: an attribute is added to the client library. If set at True, adds the hidden keyword to all command which can use it to show hidden changesets. The alternative would be to add the keyword in rawcommand, but the hidden flag is not relevant for commands such as add or branch. diff -r e05b0cf920bb -r cdde1656346f hglib/client.py --- a/hglib/client.py Wed Apr 30 16:44:59 2014 +0200 +++ b/hglib/client.py Thu May 22 15:23:12 2014 +0200 @@ -54,6 +54,8 @@ self.server = None self._version = None + #include the hidden changesets if True + self.hidden = None if connect: self.open() @@ -282,7 +284,8 @@ args = cmdbuilder('annotate', r=rev, no_follow=nofollow, a=text, u=user, f=file, d=date, n=number, c=changeset, - l=line, v=verbose, I=include, X=exclude, *files) + l=line, v=verbose, I=include, X=exclude, + hidden=self.hidden, *files) out = self.rawcommand(args) @@ -324,7 +327,8 @@ exclude - exclude names matching the given patterns """ args = cmdbuilder('archive', dest, r=rev, no_decode=nodecode, p=prefix, - t=type, S=subrepos, I=include, X=exclude) + t=type, S=subrepos, I=include, X=exclude, + hidden=self.hidden) self.rawcommand(args) @@ -351,7 +355,8 @@ raise ValueError("cannot specify both a message and a logfile") args = cmdbuilder('backout', r=rev, merge=merge, parent=parent, t=tool, - m=message, l=logfile, d=date, u=user) + m=message, l=logfile, d=date, u=user, + hidden=self.hidden) self.rawcommand(args) @@ -380,7 +385,8 @@ If there isn't a current one, -1 is returned as the index. """ - out = self.rawcommand(['bookmarks']) + args = cmdbuilder('bookmarks', hidden=self.hidden) + out = self.rawcommand(args) bms = [] current = -1 @@ -429,7 +435,7 @@ active - show only branches that have unmerged heads closed - show normal and closed branches """ - args = cmdbuilder('branches', a=active, c=closed) + args = cmdbuilder('branches', a=active, c=closed, hidden=self.hidden) out = self.rawcommand(args) branches = [] @@ -469,7 +475,7 @@ """ args = cmdbuilder('bundle', file, destrepo, f=force, r=rev, b=branch, base=base, a=all, t=type, e=ssh, remotecmd=remotecmd, - insecure=insecure) + insecure=insecure, hidden=self.hidden) eh = util.reterrorhandler(args) self.rawcommand(args, eh=eh) @@ -490,7 +496,7 @@ "%d" dirname of file being printed, or '.' if in repository root "%p" root-relative path name of file being printed """ - args = cmdbuilder('cat', r=rev, o=output, *files) + args = cmdbuilder('cat', r=rev, o=output, hidden=self.hidden, *files) out = self.rawcommand(args) if not output: @@ -643,7 +649,8 @@ p=showfunction, reverse=reverse, w=ignoreallspace, b=ignorespacechange, B=ignoreblanklines, U=unified, stat=stat, - S=subrepos, I=include, X=exclude, *files) + S=subrepos, I=include, X=exclude, hidden=self.hidden, + *files) return self.rawcommand(args) @@ -673,7 +680,8 @@ if not isinstance(revs, list): revs = [revs] args = cmdbuilder('export', o=output, switch_parent=switchparent, - a=text, g=git, nodates=nodates, *revs) + a=text, g=git, nodates=nodates, hidden=self.hidden, + *revs) out = self.rawcommand(args) @@ -732,7 +740,8 @@ args = cmdbuilder('grep', all=all, a=text, f=follow, i=ignorecase, l=fileswithmatches, n=line, u=user, d=date, - I=include, X=exclude, *[pattern] + files) + I=include, X=exclude, hidden=self.hidden, + *[pattern] + files) args.append('-0') def eh(ret, out, err): @@ -773,7 +782,8 @@ rev = [rev] args = cmdbuilder('heads', r=startrev, t=topological, c=closed, - template=templates.changeset, *rev) + template=templates.changeset, hidden=self.hidden, + *rev) def eh(ret, out, err): if ret != 1: @@ -804,7 +814,7 @@ bookmarks - show bookmarks """ args = cmdbuilder('identify', source, r=rev, n=num, i=id, b=branch, t=tags, - B=bookmarks) + B=bookmarks, hidden=self.hidden) return self.rawcommand(args) @@ -902,7 +912,7 @@ def log(self, revrange=None, files=[], follow=False, followfirst=False, date=None, copies=False, keyword=None, removed=False, onlymerges=False, - user=None, branch=None, prune=None, hidden=False, limit=None, + user=None, branch=None, prune=None, hidden=None, limit=None, nomerges=False, include=None, exclude=None): """ Return the revision history of the specified files or the entire project. @@ -941,11 +951,14 @@ include - include names matching the given patterns exclude - exclude names matching the given patterns """ + if hidden is None: + hidden = self.hidden args = cmdbuilder('log', template=templates.changeset, r=revrange, f=follow, follow_first=followfirst, d=date, C=copies, k=keyword, removed=removed, - m=onlymerges, u=user, b=branch, P=prune, hidden=hidden, - l=limit, M=nomerges, I=include, X=exclude, *files) + m=onlymerges, u=user, b=branch, P=prune, + l=limit, M=nomerges, I=include, X=exclude, + hidden=hidden, *files) out = self.rawcommand(args) out = out.split('\0')[:-1] @@ -962,7 +975,8 @@ When all is True, all files from all revisions are yielded (just the name). This includes deleted and renamed files. """ - args = cmdbuilder('manifest', r=rev, all=all, debug=True) + args = cmdbuilder('manifest', r=rev, all=all, debug=True, + hidden=self.hidden) out = self.rawcommand(args) @@ -1094,7 +1108,8 @@ in which the file was last changed (before the working directory revision or the revision specified by rev) is returned. """ - args = cmdbuilder('parents', file, template=templates.changeset, r=rev) + args = cmdbuilder('parents', file, template=templates.changeset, r=rev, + hidden=self.hidden) out = self.rawcommand(args) if not out: @@ -1277,7 +1292,7 @@ args = cmdbuilder('revert', r=rev, a=all, d=date, no_backup=nobackup, n=dryrun, I=include, X=exclude, - *files) + hidden=self.hidden, *files) eh = util.reterrorhandler(args) self.rawcommand(args, eh=eh) @@ -1327,7 +1342,8 @@ args = cmdbuilder('status', rev=rev, change=change, A=all, m=modified, a=added, r=removed, d=deleted, c=clean, u=unknown, - i=ignored, C=copies, S=subrepos, I=include, X=exclude) + i=ignored, C=copies, S=subrepos, I=include, + X=exclude, hidden=self.hidden) args.append('-0') @@ -1366,7 +1382,8 @@ names = [names] args = cmdbuilder('tag', r=rev, m=message, f=force, l=local, - remove=remove, d=date, u=user, *names) + remove=remove, d=date, u=user, hidden=self.hidden, + *names) self.rawcommand(args) @@ -1402,7 +1419,7 @@ unparsed entries will be of them form key : value """ - args = cmdbuilder('summary', remote=remote) + args = cmdbuilder('summary', remote=remote, hidden=self.hidden) out = self.rawcommand(args).splitlines() @@ -1474,7 +1491,8 @@ changeset most recently added to the repository (and therefore the most recently changed head). """ - args = cmdbuilder('tip', template=templates.changeset) + args = cmdbuilder('tip', template=templates.changeset, + hidden=self.hidden) out = self.rawcommand(args) out = out.split('\0') @@ -1494,7 +1512,8 @@ if clean and check: raise ValueError('clean and check cannot both be True') - args = cmdbuilder('update', r=rev, C=clean, c=check, d=date) + args = cmdbuilder('update', r=rev, C=clean, c=check, d=date, + hidden=self.hidden) def eh(ret, out, err): if ret == 1: diff -r e05b0cf920bb -r cdde1656346f tests/test-hidden.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tests/test-hidden.py Thu May 22 15:23:12 2014 +0200 @@ -0,0 +1,43 @@ +import common, hglib, datetime +from hglib.error import CommandError + +class test_obsolete_reference(common.basetest): + '''make sure obsolete changesets are disabled''' + def test_debugobsolete_failure(self): + f = open('gna1','w') + f.write('g') + f.close() + self.client.add('gna1') + cs = self.client.commit('gna1')[1] #get id + with self.assertRaises(CommandError): + self.client.rawcommand(['debugobsolete', cs]) + + +class test_obsolete(common.basetest): + '''test a few client methods with obsolete changesets enabled''' + def setUp(self): + #create an extension which only activates obsolete + super(test_obsolete, self).setUp() + self.append('.hg/obs.py','''import mercurial.obsolete\nmercurial.obsolete._enabled = True''') + self.append('.hg/hgrc','\n[extensions]\nobs=.hg/obs.py') + + def test_debugobsolete_success(self): + self.append('gna1','ga') + self.client.add('gna1') + cs = self.client.commit('gna1')[1] #get id + self.client.rawcommand(['debugobsolete', cs]) + + def test_obsolete_in(self): + self.append('gna1','ga') + self.client.add('gna1') + cs0 = self.client.commit('gna1')[1] #get id + self.append('gna2','gaaa') + self.client.add('gna2') + cs1 = self.client.commit('gna2')[1] #get id + self.client.rawcommand(['debugobsolete', cs1]) + self.client.update(cs0) + self.assertFalse(cs1 in self.client) + self.assertTrue(cs0 in self.client) + self.client.hidden = True + self.assertTrue(cs1 in self.client) +