1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
|
#!/usr/bin/expect -f
# This file is part of Firejail project
# Copyright (C) 2014-2026 Firejail Authors
# License GPL v2
set timeout 10
spawn $env(SHELL)
match_max 100000
send -- "rm -f logfile*\r"
sleep 1
puts "\n"
send -- "firejail --output=logfile -- ./output.sh\r"
expect {
timeout {puts "TESTING ERROR 1\n";exit}
"20000"
}
expect {
timeout {puts "TESTING ERROR 1.1\n";exit}
"60000"
}
expect {
timeout {puts "TESTING ERROR 1.2\n";exit}
"100000"
}
expect {
timeout {puts "TESTING ERROR 1.3\n";exit}
"120000"
}
expect {
timeout {puts "TESTING ERROR 1.4\n";exit}
"14999"
}
sleep 2
puts "\n"
set timeout 2
send -- "ls -al logfile*\r"
expect {
timeout {puts "TESTING ERROR 2\n";exit}
"logfile"
}
expect {
timeout {puts "TESTING ERROR 3\n";exit}
"logfile.1"
}
expect {
timeout {puts "TESTING ERROR 4\n";exit}
"logfile.2"
}
expect {
timeout {puts "TESTING ERROR 5\n";exit}
"logfile.3"
}
expect {
timeout {puts "TESTING ERROR 6\n";exit}
"logfile.4"
}
expect {
timeout {puts "TESTING ERROR 7\n";exit}
"logfile.5"
}
after 100
send -- "rm -f logfile*\r"
send -- "firejail --output=../logfile -- ./output.sh\r"
expect {
timeout {puts "TESTING ERROR 8\n";exit}
"invalid output file"
}
after 100
send -- "firejail --output=/etc -- ./output.sh\r"
expect {
timeout {puts "TESTING ERROR 9\n";exit}
"invalid output file"
}
after 100
send -- "firejail --output=/etc/firejail/zoom.profile -- ./output.sh\r"
expect {
timeout {puts "TESTING ERROR 10\n";exit}
"the output file needs to be owned by the current user"
}
after 100
puts "\nall done\n"
|