#!/bin/sh # # Copyright (c) 2009 Casey Schaufler under the terms of the # GNU General Public License version 2, as published by the # Free Software Foundation # # Test setting access rules # # Environment: # CAP_MAC_ADMIN # # "%-23s %-23s %4s" # # 1 2 llllCCCCccccCCCCcccc 5 6 # 123456789012345678901234567890123456789012345678901234567890123456789 export TCID=smack_set_cipso export TST_TOTAL=1 . test.sh . smack_common.sh rule_a="TheOne 2 0 " rule_b="TheOne 3 1 55 " rule_c="TheOne 4 2 17 33 " old_rule=$(grep "^TheOne" "$smackfsdir/cipso" 2>/dev/null) echo -n "$rule_a" 2>/dev/null > "$smackfsdir/cipso" new_rule=$(grep "^TheOne" "$smackfsdir/cipso" 2>/dev/null) if [ "$new_rule" = "" ]; then tst_brkm TFAIL "Rule did not get set." fi right=$(echo "$new_rule" | grep ' 2') if [ "$right" = "" ]; then tst_brkm TFAIL "Rule \"$new_rule\" is not set correctly." fi echo -n "$rule_b" 2>/dev/null > "$smackfsdir/cipso" new_rule=$(grep "^TheOne" "$smackfsdir/cipso" 2>/dev/null) if [ "$new_rule" = "" ]; then tst_brkm TFAIL "Rule did not get set." fi right=$(echo $new_rule | grep '/55') if [ "$right" = "" ]; then tst_brkm TFAIL "Rule \"$new_rule\" is not set correctly." fi echo -n "$rule_c" 2>/dev/null > "$smackfsdir/cipso" new_rule=$(grep "^TheOne" "$smackfsdir/cipso" 2>/dev/null) if [ "$new_rule" = "" ]; then tst_brkm TFAIL "Rule did not get set." fi right=$(echo "$new_rule" | grep '/17,33') if [ "$right" = "" ]; then tst_brkm TFAIL "Rule \"$new_rule\" is not set correctly." fi if [ "$old_rule" != "$new_rule" ]; then tst_resm TINFO "Notice: Test access rule changed from \"$old_rule\"" \ "to \"$new_rule\"." fi tst_resm TPASS "Test \"$TCID\" success." tst_exit