|
|
#!/bin/sh |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src |
|
|
print_ver_ chcon |
|
|
require_root_ |
|
|
require_selinux_ |
|
|
skip_if_mcstransd_is_running_ |
|
|
mls_enabled_ || skip_ 'MLS is disabled' |
|
|
|
|
|
mkdir -p d/sub/s2 || framework_failure_ |
|
|
touch f g d/sub/1 d/sub/2 || framework_failure_ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
u1=root |
|
|
r1=object_r |
|
|
t1=tmp_t |
|
|
range=s0 |
|
|
ctx=$u1:$r1:$t1:$range |
|
|
chcon $ctx f || skip_ "Failed to set context: $ctx" |
|
|
stat --printf='f|%C\n' f > out || fail=1 |
|
|
|
|
|
|
|
|
chcon --ref=f g || fail=1 |
|
|
stat --printf='g|%C\n' g >> out || fail=1 |
|
|
|
|
|
|
|
|
u2=user_u |
|
|
r2=object_r |
|
|
t2=unlabeled_t |
|
|
for i in --user=$u2 --role=$r2 --type=$t2 --range=$range; do |
|
|
chcon $i f || fail=1 |
|
|
stat --printf="f|$i|"'%C\n' f >> out || fail=1 |
|
|
done |
|
|
|
|
|
|
|
|
for i in -u$u1 -r$r1 -t$t1; do |
|
|
chcon $i f || fail=1 |
|
|
stat --printf="f|$i|"'%C\n' f >> out || fail=1 |
|
|
done |
|
|
|
|
|
cat <<EOF > exp || framework_failure_ |
|
|
f|$ctx |
|
|
g|$ctx |
|
|
f|--user=$u2|$u2:$r1:$t1:$range |
|
|
f|--role=$r2|$u2:$r2:$t1:$range |
|
|
f|--type=$t2|$u2:$r2:$t2:$range |
|
|
f|--range=$range|$u2:$r2:$t2:$range |
|
|
f|-uroot|root:object_r:$t2:$range |
|
|
f|-robject_r|root:object_r:$t2:$range |
|
|
f|-ttmp_t|root:object_r:tmp_t:$range |
|
|
EOF |
|
|
|
|
|
compare exp out || fail=1 |
|
|
|
|
|
chcon --verbose -u$u1 f > out || fail=1 |
|
|
echo "changing security context of 'f'" > exp || framework_failure_ |
|
|
compare exp out || fail=1 |
|
|
|
|
|
Exit $fail |
|
|
|