issue #410: support sudo --user and SELinux options, add stub test.
parent
0d410aef51
commit
fadb9181bc
@ -0,0 +1,60 @@
|
|||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
|
import mitogen
|
||||||
|
import mitogen.lxd
|
||||||
|
import mitogen.parent
|
||||||
|
|
||||||
|
import unittest2
|
||||||
|
|
||||||
|
import testlib
|
||||||
|
|
||||||
|
|
||||||
|
class ConstructorTest(testlib.RouterMixin, testlib.TestCase):
|
||||||
|
sudo_path = testlib.data_path('stubs/stub-sudo.py')
|
||||||
|
|
||||||
|
def run_sudo(self, **kwargs):
|
||||||
|
context = self.router.sudo(
|
||||||
|
sudo_path=self.sudo_path,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
argv = eval(context.call(os.getenv, 'ORIGINAL_ARGV'))
|
||||||
|
return context, argv
|
||||||
|
|
||||||
|
|
||||||
|
def test_basic(self):
|
||||||
|
context, argv = self.run_sudo()
|
||||||
|
self.assertEquals(argv[:4], [
|
||||||
|
self.sudo_path,
|
||||||
|
'-u', 'root',
|
||||||
|
'--'
|
||||||
|
])
|
||||||
|
|
||||||
|
def test_selinux_type_role(self):
|
||||||
|
context, argv = self.run_sudo(
|
||||||
|
selinux_type='setype',
|
||||||
|
selinux_role='serole',
|
||||||
|
)
|
||||||
|
self.assertEquals(argv[:8], [
|
||||||
|
self.sudo_path,
|
||||||
|
'-u', 'root',
|
||||||
|
'-r', 'serole',
|
||||||
|
'-t', 'setype',
|
||||||
|
'--'
|
||||||
|
])
|
||||||
|
|
||||||
|
def test_reparse_args(self):
|
||||||
|
context, argv = self.run_sudo(
|
||||||
|
sudo_args=['--type', 'setype', '--role', 'serole', '--user', 'user']
|
||||||
|
)
|
||||||
|
self.assertEquals(argv[:8], [
|
||||||
|
self.sudo_path,
|
||||||
|
'-u', 'user',
|
||||||
|
'-r', 'serole',
|
||||||
|
'-t', 'setype',
|
||||||
|
'--'
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest2.main()
|
Loading…
Reference in New Issue