test-trusted.py
241 lines
| 7.0 KiB
| text/x-python
|
PythonLexer
/ tests / test-trusted.py
Alexis S. L. Carvalho
|
r3551 | # Since it's not easy to write a test that portably deals | ||
# with files from different users/groups, we cheat a bit by | ||||
# monkey-patching some functions in the util module | ||||
Pulkit Goyal
|
r28934 | from __future__ import absolute_import, print_function | ||
Pulkit Goyal
|
r28913 | |||
Alexis S. L. Carvalho
|
r3551 | import os | ||
Pulkit Goyal
|
r28913 | from mercurial import ( | ||
error, | ||||
ui as uimod, | ||||
util, | ||||
) | ||||
Alexis S. L. Carvalho
|
r3551 | |||
hgrc = os.environ['HGRCPATH'] | ||||
Alexis S. L. Carvalho
|
r5523 | f = open(hgrc) | ||
basehgrc = f.read() | ||||
f.close() | ||||
Alexis S. L. Carvalho
|
r3551 | |||
def testui(user='foo', group='bar', tusers=(), tgroups=(), | ||||
Ry4an Brase
|
r13493 | cuser='foo', cgroup='bar', debug=False, silent=False, | ||
report=True): | ||||
Alexis S. L. Carvalho
|
r3551 | # user, group => owners of the file | ||
# tusers, tgroups => trusted users/groups | ||||
# cuser, cgroup => user/group of the current process | ||||
# write a global hgrc with the list of trusted users/groups and | ||||
# some setting so that we can be sure it was read | ||||
f = open(hgrc, 'w') | ||||
Alexis S. L. Carvalho
|
r5523 | f.write(basehgrc) | ||
f.write('\n[paths]\n') | ||||
Alexis S. L. Carvalho
|
r3551 | f.write('global = /some/path\n\n') | ||
if tusers or tgroups: | ||||
f.write('[trusted]\n') | ||||
if tusers: | ||||
f.write('users = %s\n' % ', '.join(tusers)) | ||||
if tgroups: | ||||
f.write('groups = %s\n' % ', '.join(tgroups)) | ||||
f.close() | ||||
# override the functions that give names to uids and gids | ||||
def username(uid=None): | ||||
if uid is None: | ||||
return cuser | ||||
return user | ||||
util.username = username | ||||
def groupname(gid=None): | ||||
if gid is None: | ||||
return 'bar' | ||||
return group | ||||
util.groupname = groupname | ||||
Martin Geisler
|
r8657 | def isowner(st): | ||
Alexis S. L. Carvalho
|
r3677 | return user == cuser | ||
util.isowner = isowner | ||||
Alexis S. L. Carvalho
|
r3551 | # try to read everything | ||
#print '# File belongs to user %s, group %s' % (user, group) | ||||
#print '# trusted users = %s; trusted groups = %s' % (tusers, tgroups) | ||||
kind = ('different', 'same') | ||||
who = ('', 'user', 'group', 'user and the group') | ||||
trusted = who[(user in tusers) + 2*(group in tgroups)] | ||||
if trusted: | ||||
trusted = ', but we trust the ' + trusted | ||||
Pulkit Goyal
|
r28934 | print('# %s user, %s group%s' % (kind[user == cuser], kind[group == cgroup], | ||
trusted)) | ||||
Alexis S. L. Carvalho
|
r3551 | |||
Yuya Nishihara
|
r30559 | u = uimod.ui.load() | ||
Matt Mackall
|
r8190 | u.setconfig('ui', 'debug', str(bool(debug))) | ||
Ry4an Brase
|
r13493 | u.setconfig('ui', 'report_untrusted', str(bool(report))) | ||
Alexis S. L. Carvalho
|
r3551 | u.readconfig('.hg/hgrc') | ||
Alexis S. L. Carvalho
|
r3552 | if silent: | ||
return u | ||||
Pulkit Goyal
|
r28934 | print('trusted') | ||
Alexis S. L. Carvalho
|
r3551 | for name, path in u.configitems('paths'): | ||
Pulkit Goyal
|
r28934 | print(' ', name, '=', path) | ||
print('untrusted') | ||||
Alexis S. L. Carvalho
|
r3552 | for name, path in u.configitems('paths', untrusted=True): | ||
Pulkit Goyal
|
r28934 | print('.', end=' ') | ||
Alexis S. L. Carvalho
|
r3552 | u.config('paths', name) # warning with debug=True | ||
Pulkit Goyal
|
r28934 | print('.', end=' ') | ||
Alexis S. L. Carvalho
|
r3552 | u.config('paths', name, untrusted=True) # no warnings | ||
Pulkit Goyal
|
r28934 | print(name, '=', path) | ||
print() | ||||
Alexis S. L. Carvalho
|
r3551 | |||
return u | ||||
os.mkdir('repo') | ||||
os.chdir('repo') | ||||
os.mkdir('.hg') | ||||
f = open('.hg/hgrc', 'w') | ||||
f.write('[paths]\n') | ||||
f.write('local = /another/path\n\n') | ||||
f.close() | ||||
#print '# Everything is run by user foo, group bar\n' | ||||
# same user, same group | ||||
testui() | ||||
# same user, different group | ||||
testui(group='def') | ||||
# different user, same group | ||||
testui(user='abc') | ||||
# ... but we trust the group | ||||
testui(user='abc', tgroups=['bar']) | ||||
# different user, different group | ||||
testui(user='abc', group='def') | ||||
# ... but we trust the user | ||||
testui(user='abc', group='def', tusers=['abc']) | ||||
# ... but we trust the group | ||||
testui(user='abc', group='def', tgroups=['def']) | ||||
# ... but we trust the user and the group | ||||
testui(user='abc', group='def', tusers=['abc'], tgroups=['def']) | ||||
# ... but we trust all users | ||||
Pulkit Goyal
|
r28934 | print('# we trust all users') | ||
Alexis S. L. Carvalho
|
r3551 | testui(user='abc', group='def', tusers=['*']) | ||
# ... but we trust all groups | ||||
Pulkit Goyal
|
r28934 | print('# we trust all groups') | ||
Alexis S. L. Carvalho
|
r3551 | testui(user='abc', group='def', tgroups=['*']) | ||
# ... but we trust the whole universe | ||||
Pulkit Goyal
|
r28934 | print('# we trust all users and groups') | ||
Alexis S. L. Carvalho
|
r3551 | testui(user='abc', group='def', tusers=['*'], tgroups=['*']) | ||
# ... check that users and groups are in different namespaces | ||||
Pulkit Goyal
|
r28934 | print("# we don't get confused by users and groups with the same name") | ||
Alexis S. L. Carvalho
|
r3551 | testui(user='abc', group='def', tusers=['def'], tgroups=['abc']) | ||
# ... lists of user names work | ||||
Pulkit Goyal
|
r28934 | print("# list of user names") | ||
Alexis S. L. Carvalho
|
r3551 | testui(user='abc', group='def', tusers=['foo', 'xyz', 'abc', 'bleh'], | ||
tgroups=['bar', 'baz', 'qux']) | ||||
# ... lists of group names work | ||||
Pulkit Goyal
|
r28934 | print("# list of group names") | ||
Alexis S. L. Carvalho
|
r3551 | testui(user='abc', group='def', tusers=['foo', 'xyz', 'bleh'], | ||
tgroups=['bar', 'def', 'baz', 'qux']) | ||||
Pulkit Goyal
|
r28934 | print("# Can't figure out the name of the user running this process") | ||
Alexis S. L. Carvalho
|
r3551 | testui(user='abc', group='def', cuser=None) | ||
Alexis S. L. Carvalho
|
r3552 | |||
Pulkit Goyal
|
r28934 | print("# prints debug warnings") | ||
Alexis S. L. Carvalho
|
r3552 | u = testui(user='abc', group='def', cuser='foo', debug=True) | ||
Pulkit Goyal
|
r28934 | print("# report_untrusted enabled without debug hides warnings") | ||
Ry4an Brase
|
r13493 | u = testui(user='abc', group='def', cuser='foo', report=False) | ||
Pulkit Goyal
|
r28934 | print("# report_untrusted enabled with debug shows warnings") | ||
Ry4an Brase
|
r13493 | u = testui(user='abc', group='def', cuser='foo', debug=True, report=False) | ||
Pulkit Goyal
|
r28934 | print("# ui.readconfig sections") | ||
Alexis S. L. Carvalho
|
r3552 | filename = 'foobar' | ||
f = open(filename, 'w') | ||||
f.write('[foobar]\n') | ||||
f.write('baz = quux\n') | ||||
f.close() | ||||
Mads Kiilerich
|
r19872 | u.readconfig(filename, sections=['foobar']) | ||
Pulkit Goyal
|
r28934 | print(u.config('foobar', 'baz')) | ||
Alexis S. L. Carvalho
|
r3552 | |||
Pulkit Goyal
|
r28934 | print() | ||
print("# read trusted, untrusted, new ui, trusted") | ||||
Yuya Nishihara
|
r30559 | u = uimod.ui.load() | ||
Matt Mackall
|
r8136 | u.setconfig('ui', 'debug', 'on') | ||
Alexis S. L. Carvalho
|
r3552 | u.readconfig(filename) | ||
Matt Mackall
|
r8190 | u2 = u.copy() | ||
Alexis S. L. Carvalho
|
r3552 | def username(uid=None): | ||
return 'foo' | ||||
util.username = username | ||||
u2.readconfig('.hg/hgrc') | ||||
Pulkit Goyal
|
r28934 | print('trusted:') | ||
print(u2.config('foobar', 'baz')) | ||||
print('untrusted:') | ||||
print(u2.config('foobar', 'baz', untrusted=True)) | ||||
Alexis S. L. Carvalho
|
r3552 | |||
Pulkit Goyal
|
r28934 | print() | ||
print("# error handling") | ||||
Alexis S. L. Carvalho
|
r3552 | |||
Pierre-Yves David
|
r26587 | def assertraises(f, exc=error.Abort): | ||
Alexis S. L. Carvalho
|
r3552 | try: | ||
f() | ||||
Gregory Szorc
|
r25660 | except exc as inst: | ||
Pulkit Goyal
|
r28934 | print('raised', inst.__class__.__name__) | ||
Alexis S. L. Carvalho
|
r3552 | else: | ||
Pulkit Goyal
|
r28934 | print('no exception?!') | ||
Alexis S. L. Carvalho
|
r3552 | |||
Pulkit Goyal
|
r28934 | print("# file doesn't exist") | ||
Alexis S. L. Carvalho
|
r3552 | os.unlink('.hg/hgrc') | ||
assert not os.path.exists('.hg/hgrc') | ||||
testui(debug=True, silent=True) | ||||
testui(user='abc', group='def', debug=True, silent=True) | ||||
Pulkit Goyal
|
r28934 | print() | ||
print("# parse error") | ||||
Alexis S. L. Carvalho
|
r3552 | f = open('.hg/hgrc', 'w') | ||
Matt Mackall
|
r8144 | f.write('foo') | ||
Alexis S. L. Carvalho
|
r3552 | f.close() | ||
Matt Mackall
|
r8144 | try: | ||
testui(user='abc', group='def', silent=True) | ||||
Gregory Szorc
|
r25660 | except error.ParseError as inst: | ||
Pulkit Goyal
|
r28934 | print(inst) | ||
Alexis S. L. Carvalho
|
r3552 | |||
Matt Mackall
|
r8144 | try: | ||
testui(debug=True, silent=True) | ||||
Gregory Szorc
|
r25660 | except error.ParseError as inst: | ||
Pulkit Goyal
|
r28934 | print(inst) | ||
Martijn Pieters
|
r31472 | |||
print() | ||||
print('# access typed information') | ||||
with open('.hg/hgrc', 'w') as f: | ||||
f.write('''\ | ||||
[foo] | ||||
sub=main | ||||
sub:one=one | ||||
sub:two=two | ||||
path=monty/python | ||||
bool=true | ||||
int=42 | ||||
bytes=81mb | ||||
list=spam,ham,eggs | ||||
''') | ||||
u = testui(user='abc', group='def', cuser='foo', silent=True) | ||||
print('# suboptions, trusted and untrusted') | ||||
trusted = u.configsuboptions('foo', 'sub') | ||||
untrusted = u.configsuboptions('foo', 'sub', untrusted=True) | ||||
print( | ||||
(trusted[0], sorted(trusted[1].items())), | ||||
(untrusted[0], sorted(untrusted[1].items()))) | ||||
print('# path, trusted and untrusted') | ||||
print(u.configpath('foo', 'path'), u.configpath('foo', 'path', untrusted=True)) | ||||
print('# bool, trusted and untrusted') | ||||
print(u.configbool('foo', 'bool'), u.configbool('foo', 'bool', untrusted=True)) | ||||
print('# int, trusted and untrusted') | ||||
print( | ||||
u.configint('foo', 'int', 0), | ||||
u.configint('foo', 'int', 0, untrusted=True)) | ||||
print('# bytes, trusted and untrusted') | ||||
print( | ||||
u.configbytes('foo', 'bytes', 0), | ||||
u.configbytes('foo', 'bytes', 0, untrusted=True)) | ||||
print('# list, trusted and untrusted') | ||||
print( | ||||
u.configlist('foo', 'list', []), | ||||
u.configlist('foo', 'list', [], untrusted=True)) | ||||