74bae64dc5
Create a new user 'sudotest' to validate that sudo really works (i.e. properly has setuid). Creating the user and adding it to sudoers is done at runtime, otherwise we'd need to add extra files to the config which complicates things a little bit. Signed-off-by: Arnout Vandecappelle (Essensium/Mind) <arnout@mind.be> Signed-off-by: Peter Korsgaard <peter@korsgaard.com>
37 lines
1.2 KiB
Python
37 lines
1.2 KiB
Python
import os
|
|
|
|
import infra.basetest
|
|
|
|
|
|
class TestSudo(infra.basetest.BRTest):
|
|
config = infra.basetest.BASIC_TOOLCHAIN_CONFIG + \
|
|
"""
|
|
BR2_PACKAGE_SUDO=y
|
|
BR2_TARGET_ROOTFS_CPIO=y
|
|
# BR2_TARGET_ROOTFS_TAR is not set
|
|
"""
|
|
|
|
def test_run(self):
|
|
img = os.path.join(self.builddir, "images", "rootfs.cpio")
|
|
self.emulator.boot(arch="armv5",
|
|
kernel="builtin",
|
|
options=["-initrd", img])
|
|
self.emulator.login()
|
|
|
|
# -D don't set a password
|
|
# -h set home directory
|
|
# -H don't create home directory
|
|
# -s set shell
|
|
_, exit_code = self.emulator.run("adduser -D -h /tmp -H -s /bin/sh sudotest")
|
|
self.assertEqual(exit_code, 0)
|
|
|
|
_, exit_code = self.emulator.run("echo 'sudotest ALL=(ALL) NOPASSWD: ALL' >> /etc/sudoers")
|
|
self.assertEqual(exit_code, 0)
|
|
|
|
output, exit_code = self.emulator.run("su - sudotest -c 'echo hello world'")
|
|
self.assertEqual(output, ["hello world"])
|
|
|
|
output, exit_code = self.emulator.run("su - sudotest -c 'sudo echo hello world'")
|
|
self.assertEqual(exit_code, 0)
|
|
self.assertEqual(output, ["hello world"])
|