From c79aa14295f907ffac0cf5555515602b7393b8b6 Mon Sep 17 00:00:00 2001 From: netblue30 Date: Thu, 9 Mar 2023 08:39:25 -0500 Subject: testing --- test/seccomp-extra/noroot.exp | 136 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 136 insertions(+) create mode 100755 test/seccomp-extra/noroot.exp (limited to 'test/seccomp-extra/noroot.exp') diff --git a/test/seccomp-extra/noroot.exp b/test/seccomp-extra/noroot.exp new file mode 100755 index 000000000..eeb82833e --- /dev/null +++ b/test/seccomp-extra/noroot.exp @@ -0,0 +1,136 @@ +#!/usr/bin/expect -f +# This file is part of Firejail project +# Copyright (C) 2014-2023 Firejail Authors +# License GPL v2 + +set timeout 10 +spawn $env(SHELL) +match_max 100000 + +send -- "firejail --name=test --noroot --noprofile\r" +expect { + timeout {puts "TESTING ERROR 1\n";exit} + -re "Child process initialized in \[0-9\]+.\[0-9\]+ ms" +} +sleep 1 + +# check seccomp disabled and all caps enabled +send -- "cat /proc/self/status\r" +expect { + timeout {puts "TESTING ERROR 2\n";exit} + "CapBnd:" +} +expect { + timeout {puts "TESTING ERROR 3\n";exit} + "ffffffff" +} +expect { + timeout {puts "TESTING ERROR 4\n";exit} + "Seccomp:" +} +expect { + timeout {puts "TESTING ERROR 5\n";exit} + "0" +} +expect { + timeout {puts "TESTING ERROR 6\n";exit} + "Cpus_allowed:" +} +puts "\n" + +send -- "whoami\r" +expect { + timeout {puts "TESTING ERROR 7\n";exit} + $env(USER) +} +send -- "sudo -s\r" +expect { + timeout {puts "TESTING ERROR 8\n";exit} + "effective uid is not 0, is sudo installed setuid root?" { puts "OK\n";} + "sudo must be owned by uid 0 and have the setuid bit set" { puts "OK\n";} +} + +send -- "sudo su -\r" +expect { + timeout {puts "TESTING ERROR 9\n";exit} + "effective uid is not 0" {puts "OK\n"} + "sudo must be owned by uid 0 and have the setuid bit set" { puts "OK\n";} +} + +send -- "sudo ls\r" +expect { + timeout {puts "TESTING ERROR 10\n";exit} + "effective uid is not 0" {puts "OK\n"} + "sudo must be owned by uid 0 and have the setuid bit set" { puts "OK\n";} +} + +send -- "cat /proc/self/uid_map | wc -l\r" +expect { + timeout {puts "TESTING ERROR 11\n";exit} + "1" +} +send -- "cat /proc/self/gid_map | wc -l\r" +expect { + timeout {puts "TESTING ERROR 12\n";exit} + "9" +} + + + +spawn $env(SHELL) +send -- "firejail --debug --join=test\r" +expect { + timeout {puts "TESTING ERROR 13\n";exit} + "Joining user namespace" +} +expect { + timeout {puts "TESTING ERROR 14\n";exit} + "Child process initialized" +} +sleep 1 + +send -- "sudo -s\r" +expect { + timeout {puts "TESTING ERROR 15\n";exit} + "effective uid is not 0, is sudo installed setuid root?" { puts "OK\n";} + "sudo must be owned by uid 0 and have the setuid bit set" { puts "OK\n";} + "Permission denied" { puts "OK\n";} +} +send -- "cat /proc/self/uid_map | wc -l\r" +expect { + timeout {puts "TESTING ERROR 16\n";exit} + "1" +} +send -- "cat /proc/self/gid_map | wc -l\r" +expect { + timeout {puts "TESTING ERROR 17\n";exit} + "9" +} + +# check seccomp disabled and all caps enabled +send -- "cat /proc/self/status\r" +expect { + timeout {puts "TESTING ERROR 18\n";exit} + "CapBnd:" +} +expect { + timeout {puts "TESTING ERROR 19\n";exit} + "ffffffff" +} +expect { + timeout {puts "TESTING ERROR 20\n";exit} + "Seccomp:" +} +expect { + timeout {puts "TESTING ERROR 21\n";exit} + "0" +} +expect { + timeout {puts "TESTING ERROR 22\n";exit} + "Cpus_allowed:" +} +puts "\n" + + +after 500 +puts "\nall done\n" -- cgit v1.2.3-70-g09d2