apparmor/tests/regression/subdomain
Steve Beattie 6d3e74907d Import the rest of the core functionality of the internal apparmor
development tree (trunk branch). From svn repo version 6381.
2006-04-11 21:52:54 +00:00
..
scripts Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
TODO Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
access.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
access.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
AppArmor.rtf Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
capabilities.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat.h Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat_fail.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat_fork.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat_fork.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat_misc.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat_misc.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat_misc2.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat_pthread.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat_twice.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
changehat_wrapper.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
chdir.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
chdir.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
chgrp.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
chmod.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
chown.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
coredump.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
coredump.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
deleted.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
deleted.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
dropprivs_wrapper.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
epilogue.inc Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
exec.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
exec.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
exec_qual.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
exec_qual.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
exec_qual2.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
fork.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
fork.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
i18n.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
link.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
link.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
Makefile Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
mkdir.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
mkdir.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
mkprofile.pl Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
mmap.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
mmap.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
mount.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
mount.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
mult_mount.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
named_pipe.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
named_pipe.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
net_raw.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
net_raw.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
open.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
open.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
owlsm.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
pipe.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
pipe.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
prologue.inc Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
ptrace.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
pwrite.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
pwrite.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
readdir.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
readdir.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
README Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
regex.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
rename.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
rename.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
rw.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
rw.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
sd_flags.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
setattr.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
strace.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
swap.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
swap.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
symlink.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
symlink.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_chroot.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_ioperm.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_iopl.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_mknod.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_mlockall.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_ptrace.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_query_module.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_reboot.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_setdomainname.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_sethostname.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_setpriority.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_setscheduler.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
syscall_sysctl.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
tcp.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
tcp.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
unix_fd_client.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
unix_fd_server.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
unix_fd_server.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
unlink.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
unlink.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
uservars.inc Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
xattrs.c Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00
xattrs.sh Import the rest of the core functionality of the internal apparmor 2006-04-11 21:52:54 +00:00

Running tests
=============

Type "make tests" at the shell prompt, this will make the subprograms
and run the tests.

You must be root to execute make tests (a requirement of subdomain).


Test output
===========

No output is displayed for a passing test.  The makefile will output
	running <testname> for each test.

Output other than this indicates a problem.

There are three typical failure scenarios:
	- Test failed when it was expected to pass
	- Test passed when it was expected to fail
	- Unexpected shell error - the test harness encountered an unexpected
		error.


Changing environment variables
==============================

Common user changeable environment variables are stored in the file
'uservars.inc'.  Currently the path to the tmp directory and the path
to the subdomain_parser executable are specified in this directory.

(Note: the tmp directory specified in uservars.inc will have an added
random string appended to it by the mktemp(1) program.)

Debugging test failures
=======================

In the event of a failure run the individual test harness using the -r (or 
-retain) option.  This will not remove the temporary test directory and will 
display it's path.  Inside the directory is a script called 'runtest' which 
will rerun the last failed command. 

Example:

# sh unlink.sh -r
Files retained in: /tmp/sdtest.25406-19681

#ls -l /tmp/sdtest.25406-19681
total 3
-rw-r--r--    1 root     root            0 Jul  2 11:51 file
-rw-r--r--    1 root     root           25 Jul  2 11:51 output.unlink
-rw-r--r--    1 root     root          182 Jul  2 11:51 profile
-rw-r--r--    1 root     root          292 Jul  2 11:51 runtest


Note that the contents of this directory (when -r is specified) is the output
of the final test contained within the controlling test harness, in this case
unlink.sh.   If the harness passed, then output.unlink will contain the output
from the final run of the executable (which may indicate an expected error).
If there was an unexpected error (failed when pass was expected or passed when
failure was expected, or an unexpected test harness error), the controlling 
test harness will abort processing further tests and the contents of the 
directory will contain the files for the failed subtest.

It may be necessary to create certain temp files in this directory in order to 
have the test function correctly, see the subdomain profile 'profile' in the 
directory in order to determine which files may need to be created to support
the executable.

In order to debug more complicated test failures such as an expected 
shell error (test harness error) it is usually necessary to rerun the test with 
debugging enabled, for example:

# sh -x unlink.sh


Adding new tests
================

The test harness is designed to make adding new tests fairly simply.

Each test consists of one controlling shell script and one or more executable
files.  

The file 'prologue.inc' must be loaded into the shell script.  This file 
contains the controlling logic and supporting shell functions.

By default, prologue.inc assumes the test binary is the same name as the shell
script, with '.sh' removed.  For test scripts with only one executable this 
makes things simple.  You may want to have a single shell script run multiple
executables (syscall.sh for example). In this case, the 'settest' function is
used to select a new binary executable for this test.

The 'genprofile' function generates a profile based on passed arguments.  
The function automatically adds the necessary shared libraries and output 
files necessary to support the execution, it is not necessary to specify 
these manually.  Therefore a call to genprofile without arguments will build 
a profile allowing the executable to run but without any additional access.
Specifying additional arguments to genprofile in the form of <filename>:<perm>
will allow additional access.  

Support for changehat subprofiles is provided by the 'hat:<hatname>'
argument to genprofile. This will create a hat within the profile named
<hatname>. All following rules (file, net, or cap) up to the next "hat:"
argument or the end of the argument list will be included within this hat.

Support for multiple profiles within a single load (for example for
test that want to domain tansition to another profile) is supported by
the "image' argument to genprofile. This keyword preceeded by a '--'
seperator terminates the previous profile and creates a new profile for
the specified executable image.

Together, 'image' and 'hat:' allow complex profiles including subhats and
domain transitions to be specified via a single invocation of genprofile.

[Note: the old "-- subhat=<hatname>" mechanism for specifying hats is
 no longer supported.]

Executing a test is achieved by calling the 'runchecktest' function which
will run either the executable matching the name of the shell script, or 
specified by settest.  The first argument is a brief description of what the
executable does in this mode, which is displayed in the event of an error.
The second argument is either "pass" or "fail" indicating whether the test
is expected to pass or fail.  The executable is expected to output "PASS"
for success and "FAIL: <error message>" in the event of a failure.  If the
executable outputs something other than this, the controlling shell script
will interpret this as a test failure and output "unable to run test sub
executable" and terminate.  Remaining arguments to runchecktest are passed
to the executable as argv[1] .. argv[n].

The runchecktest command executes and checks the test serially.  If a test
requires to be run in the background, so that the shell may do subsequent
operations, such as sending it a signal before checking it's output, this is
accomplished by separately calling 'runtestbg' and 'checktestbg' instead
of calling 'runchecktest'.

Profile loading, replacing and unloading is automatically handled by the 
shell script (via prologue.inc).  Also, cleanup (tempfile removal and 
profile unloading) on exit is automatic.

As an example, the text shell script for exec (exec.sh) is 24 lines and
may be used as a template for creating new simple tests (changehat.sh is
a good template for subprofile tests and rw.sh is a template for tests
requiring signal passing)

	#! /bin/bash
	
	pwd=`dirname $0`
	pwd=`cd $pwd ; pwd`
	
	<bin must be set prior to including prologue.inc. This is the only>
	<requirement placed on the shell script author by prologue.inc>
	bin=$pwd
	
	<prologie.inc must be included before running any tests>
	. $bin/prologue.inc
	
	<variable definitions used by this script?
	file=/bin/true
	okperm=x
	badperm=r
	
	# PASS TEST
	
	<generate a profile allowing x access to /bin/true>
	genprofile $file:$okperm
	
	<run this test (exec) passing /bin/true as argv[1]>
	<check it's output, it is expected to pass>
	runchecktest "EXEC with x" pass $file
	
	# NOLINK PERMTEST
	<generate a new profile allowing only r access to /bin/true>
	<subdomain_parser will automatically be invoked in -r mode>
	genprofile $file:$badperm

	<run this test (exec) passing /bin/true as argv[1]>
	<check it's output, it is expected to FAIL>
	runchecktest "EXEC no x" fail $file

	<Thats it. Exit status $rc is automatically returned by epilogue.inc>

Additional documentation
========================

See the file 'subdomain_test.txt'

Supporting files
================

strace.sh	Not a test harness, used to support strace testing.
mkprofile.sh	Not a test harness, used to generate subdomain profiles.
prologue.inc	Must be dotted (included) into the test harness. Provides
		support routines.
epilogue.inc	Cleanup support, automatically called upon successful or
		unsuccessful exit
uservars.inc	Contains variables that may need to be changed per user.

Makefile	Makefile for building or running tests. Use 'make' to build,
		'make tests' to run.

*.sh		Controlling test harness
*.c		Test executable.

Disabled tests
==============

Symlink mediation (symlink.sh) in AppArmor has been disabled.
It is too easy to defeat by creating a relative symlink and subsequently
moving the link.

Current failures
================

1) Changehat_misc

   THIS IS NOT AN ERROR - per se.
   Two killed messages will be output. 
   This is not an error, rather a sign that bash noticed the kernel had killed 
   a process which was attempting to use a bogus MAGIC number.  Alas, there is 
   no way to get bash to not print this diagnostic

2) Mkdir
	Error: mkdir passed. Test 'MKDIR (confined)' was expected to 'fail'
	Error: mkdir passed. Test 'RMDIR (confined)' was expected to 'fail'

   There is currently no mediation for mkdir.  Whether there should be (and
   this is truly an error) or whether the test should be changed to "pass"
   is an open issue.

3) Ptrace
	Error: open passed. Test 'STRACE OPEN (x confinement)' 
	was expected to 'fail'
 
   Regression from 2.4.18 to 2.4.20. (We aren't sure on the first
   endpoint, and the problem still happens in 2.4.20-20_imnx_10smp.)

4) Open
	Error: open passed. Test 'OPEN W (create)' was expected to 'fail'

   LSM issue.  Flags passed to inode_permission are 0 if O_CREAT is used to
   open file.  Need to submit a patch to inode_create hook to receive the
   O_RDWR flags. See https://bugs.wirex.com/show_bug.cgi?id=2885