aboutsummaryrefslogtreecommitdiffstats
path: root/test/capabilities/caps-join.exp
blob: ecb43d943ae1ba6ac4f6447a024a64e53155bdf2 (plain) (blame)
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
91
92
93
94
95
96
#!/usr/bin/expect -f
# This file is part of Firejail project
# Copyright (C) 2014-2023 Firejail Authors
# License GPL v2

set timeout 10
match_max 100000
spawn $env(SHELL)
set id1 $spawn_id
spawn $env(SHELL)
set id2 $spawn_id

send -- "stty -echo\r"
after 100

#
# regular run
#
set spawn_id $id1
send --  "firejail --name=jointesting\r"
expect {
	timeout {puts "TESTING ERROR 0\n";exit}
	-re "Child process initialized in \[0-9\]+.\[0-9\]+ ms"
}
sleep 1

set spawn_id $id2

send --  "firejail --join=jointesting cat /proc/self/status\r"
expect {
	timeout {puts "TESTING ERROR 1\n";exit}
	"CapBnd:	0000000000000000"
}
sleep 1

set spawn_id $id1
send -- "exit\r"
sleep 1

#
# no caps
#
set spawn_id $id1
send --  "firejail --name=jointesting --noprofile\r"
expect {
	timeout {puts "TESTING ERROR 10\n";exit}
	-re "Child process initialized in \[0-9\]+.\[0-9\]+ ms"
}
sleep 1

set spawn_id $id2

send --  "firejail --join=jointesting cat /proc/self/status\r"
expect {
	timeout {puts "TESTING ERROR 11\n";exit}
	"CapBnd:"
}
expect {
	timeout {puts "TESTING ERROR 12\n";exit}
	"fffffffff"
}
expect {
	timeout {puts "TESTING ERROR 13\n";exit}
	"CapAmb:"
}
sleep 1

set spawn_id $id1
send -- "exit\r"
after 500

#
# no caps
#
set spawn_id $id1
send --  "firejail --name=jointesting --noprofile --caps.keep=chown,fowner\r"
expect {
	timeout {puts "TESTING ERROR20\n";exit}
	-re "Child process initialized in \[0-9\]+.\[0-9\]+ ms"
}
sleep 1

set spawn_id $id2

send --  "firejail --join=jointesting cat /proc/self/status\r"
expect {
	timeout {puts "TESTING ERROR 21\n";exit}
	"CapBnd:	0000000000000009"
}
sleep 1

set spawn_id $id1
send -- "exit\r"
after 500

puts "all done\n"