From patchwork Tue Jan 7 13:46:06 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Christian_G=C3=B6ttsche?= X-Patchwork-Id: 13928924 X-Patchwork-Delegate: omosnacek@gmail.com Received: from server02.seltendoof.de (server02.seltendoof.de [168.119.48.163]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id F15401F0E59 for ; Tue, 7 Jan 2025 13:46:27 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=168.119.48.163 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736257591; cv=none; b=q8k0koec3Ir9CD+kK7tYiTTLHkEr+zgk/ZlyciRkXKqEsbblwhMTSOCViHoxI6Sl6q2G2nX9WhYcfsXW7t1LWhjLutU58gvelLmgUiS5NkVyNd5yaRnJunZopmZfn9Jo7BaQAi6zl7uWGruyhUQnOHEjuU7GIBLiUAFVfYdf8BQ= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736257591; c=relaxed/simple; bh=uDLj7v25cYNZR9YM1c4uXYrX9DP3lAUZRCi4xvSynCI=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=pwCI8sWQbMDzjbnoLvLb/OXPN1Qio6WnjOi7ar82iEinUI/pD5IBcz8OEy6PFoyaZt6iJhuq/nFeua7oefXOGgp4u3VOSmWpRRVhOOcGnbOiJz96vJJ6OwEXJIhs5k5V2zmabK57cFbAXMxS3m/VJn0PAo0RLPnoOuOoj/RuSYA= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=seltendoof.de; spf=pass smtp.mailfrom=seltendoof.de; dkim=pass (2048-bit key) header.d=seltendoof.de header.i=@seltendoof.de header.b=dOGStlON; arc=none smtp.client-ip=168.119.48.163 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=seltendoof.de Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=seltendoof.de Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=seltendoof.de header.i=@seltendoof.de header.b="dOGStlON" From: =?utf-8?q?Christian_G=C3=B6ttsche?= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=seltendoof.de; s=2023072701; t=1736257577; h=from:from:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=1WHrCvwXb+AXpp9oAC417Xb3lJyRJi6TaS/MlY9Bt4Q=; b=dOGStlONtzVJ8MZ9OnT0u2Bg+qDw3KQLWb3nhqm3EZ8me+Ye9b2stiW4y/inAMoXYj6m4y yRlwV2oWKD/o5WuO2svISE6oDTe10cWh/rpD0g4t2ARkUC5RVciD/tXteBOhnLoJafTDri 4hvSAvQI1/wcBHXI6hlqyZ3ZSic0ZChWz+5wd/f2pLVtmrB6Ito+dbrn0CxsgP9AniUEW5 0pprAJ/rKFW2AX+nH5EQmgU0wx0TNBu1kEgxiYVohJ7xEvIapcKTm7oJrrHlWKkMcDOxbH NAOhzz5quaufVom8Gk4KVn+/acm4L2eoswM2ZE8tfubjfTMDN8mEwDrYpkxJBg== To: selinux@vger.kernel.org Cc: =?utf-8?q?Christian_G=C3=B6ttsche?= Subject: [RFC PATCH v2 00/17] testsuite: misc fixes and virtme-ng support Date: Tue, 7 Jan 2025 14:46:06 +0100 Message-ID: <20250107134606.37260-18-cgoettsche@seltendoof.de> In-Reply-To: <20250107134606.37260-1-cgoettsche@seltendoof.de> References: <20250107134606.37260-1-cgoettsche@seltendoof.de> Reply-To: cgzones@googlemail.com Precedence: bulk X-Mailing-List: selinux@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 From: Christian Göttsche With the following patches the testsuite runs successfully in a virtme-ng environment. A minimal virtme-ng default kernel configuration was used combined with the testsuite's included *defconfig*. Also while working on failed testcases I tweaked some scripts and test code. Test result: ``` Running as user root with context unconfined_u:unconfined_r:unconfined_t domain_trans/test ........... ok entrypoint/test ............. ok execshare/test .............. ok exectrace/test .............. ok execute_no_trans/test ....... ok fdreceive/test .............. ok inherit/test ................ ok link/test ................... ok mkdir/test .................. ok msg/test .................... ok open/test ................... ok ptrace/test ................. ok readlink/test ............... ok relabel/test ................ ok rename/test ................. ok rxdir/test .................. ok sem/test .................... ok setattr/test ................ ok setnice/test ................ ok shm/test .................... ok sigkill/test ................ ok stat/test ................... ok sysctl/test ................. ok task_create/test ............ ok task_setnice/test ........... ok task_setscheduler/test ...... ok task_getscheduler/test ...... ok task_getsid/test ............ ok task_getpgid/test ........... ok task_setpgid/test ........... ok file/test ................... ok ioctl/test .................. ok capable_file/test ........... ok capable_net/test ............ ok capable_sys/test ............ ok dyntrans/test ............... ok dyntrace/test ............... ok bounds/test ................. ok nnp_nosuid/test ............. ok mmap/test ................... ok unix_socket/test ............ ok inet_socket/tcp/test ........ ok inet_socket/udp/test ........ ok overlay/test ................ skipped: overlayfs upperdir not supported on NFS and OverlayFS checkreqprot/test ........... ok mqueue/test ................. skipped: mqueue filesystem not supported/mounted mac_admin/test .............. ok atsecure/test ............... ok infiniband_endport/test ..... skipped: test not configured infiniband_pkey/test ........ skipped: test not configured cap_userns/test ............. skipped: CLONE_NEWUSER not supported extended_socket_class/test .. ok sctp/test ................... skipped: SCTP not supported netlink_socket/test ......... ok prlimit/test ................ ok binder/test ................. ok bpf/test .................... ok keys/test ................... ok key_socket/test ............. ok glblub/test ................. ok cgroupfs_label/test ......... ok notify/test ................. ok module_load/test ............ ok tun_tap/test ................ skipped: No TUN/TAP support perf_event/test ............. ok filesystem/xfs/test ......... ok filesystem/vfat/test ........ ok fs_filesystem/xfs/test ...... ok fs_filesystem/vfat/test ..... ok watchkey/test ............... ok userfaultfd/test ............ skipped: SELinux support for userfaultfd not present vsock_socket/test ........... skipped: vsock socket family not supported secretmem/test .............. ok inet_socket/mptcp/test ...... skipped: protocol mptcp not supported All tests successful. Files=74, Tests=673, 75 wallclock secs ( 0.24 usr 0.41 sys + 3.39 cusr 15.81 csys = 19.85 CPU) Result: PASS ``` The included policy needs to be tweaked (not included in this pull request): ``` ``` Also to speed up the development cycle I used the following two scripts: *tools/vng_stage1.sh* ```sh #!/bin/sh set -eux SCRIPTDIR=$(dirname "$0") cd / load_policy -i setenforce 0 restorecon -RF -T0 /dev # transition out of initial kernel sid runcon -u unconfined_u -r unconfined_r -t unconfined_t /bin/bash "${SCRIPTDIR}/vng_stage2.sh" ``` *tools/vng_stage2.sh* ```sh #!/bin/sh set -eux SCRIPTDIR=$(dirname "$0") cd / setenforce 1 # display some system status information dmesg | tail -n 40 id sestatus cd "${SCRIPTDIR}/../" make test -j"$(nproc)" || true /bin/bash -i ``` v2: - fix ioctl tests on NFS - rebase onto latest changes v1: https://lore.kernel.org/selinux/20241118150256.135432-1-cgoettsche@seltendoof.de/ Christian Göttsche (17): Fix typos Makefile: use $(MAKE) to pass options tools: quote command to prevent word splitting tests: port scripts to sh and please shellcheck tests: enable strictness for perl scripts Makefile: add PHONY targets test: overlayfs related tweaks tests/notify: work with CONFIG_FANOTIFY disabled tests/extended_socket_class: work with CONFIG_CRYPTO_USER_API disabled tests/tun_tap: skip if not supported tests/inet_socket: skip mptcp if not supported tests/filesystem: improve fsnotify check and preload loop module defconfig: enable CONFIG_XFRM_USER defconfig: enable CONFIG_NETFILTER_NETLINK_LOG tests: test code tweaks tests: fail on compiler warnings and enable Wextra tests: drop headers from Makefile dependencies Makefile | 10 +- defconfig | 4 + doc/tests/Makefile | 2 +- doc/tests/socket.sgml | 2 +- policy/Makefile | 2 + policy/test_capable_file.te | 2 +- policy/test_capable_net.te | 2 +- policy/test_capable_sys.te | 2 +- policy/test_mqueue.te | 2 +- tests/Makefile | 2 +- tests/binder/Makefile | 4 +- tests/binder/client.c | 2 +- tests/binder/manager.c | 2 +- tests/binder/service_provider.c | 14 ++- tests/bounds/test | 4 +- tests/bpf/Makefile | 2 +- tests/bpf/bpf_test.c | 2 +- tests/cap_userns/userns_child_exec.c | 6 +- tests/capable_net/test | 2 +- tests/capable_sys/test | 4 +- tests/execshare/parent.c | 2 +- tests/extended_socket_class/test | 28 +++-- tests/fdreceive/Makefile | 2 +- tests/fdreceive/server.c | 3 +- tests/file/test | 2 +- tests/file/test_nofcntl.c | 2 +- tests/file/test_sigiotask.c | 2 +- tests/filesystem/Filesystem.pm | 2 +- tests/filesystem/fs_relabel.c | 2 +- tests/filesystem/grim_reaper.c | 2 +- tests/filesystem/test | 3 + tests/inet_socket/bind.c | 1 + tests/inet_socket/connect.c | 1 + tests/inet_socket/test | 5 +- tests/inherit/parent.c | 2 +- tests/ioctl/test | 4 +- tests/ioctl/test_ioctl.c | 16 ++- tests/ioctl/test_noioctl.c | 13 +- tests/key_socket/key_sock.c | 2 +- tests/keys/Makefile | 2 - tests/kvercmp | 16 +-- tests/loop.pl | 9 +- tests/module_load/init_load.c | 2 +- tests/mqueue/mqmgr.c | 2 +- tests/mqueue/test | 2 +- tests/nfsruntests.pl | 6 +- tests/nnp_nosuid/execnnp.c | 2 +- tests/notify/test | 172 ++++++++++++++++----------- tests/notify/test_fanotify.c | 22 +++- tests/os_detect | 10 +- tests/overlay/setup-overlay | 2 +- tests/overlay/test | 7 +- tests/pol_detect | 12 +- tests/prlimit/parent.c | 2 + tests/runtests.pl | 16 ++- tests/sctp/sctp_common.c | 4 +- tests/task_setscheduler/test | 2 +- tests/tun_tap/Makefile | 2 +- tests/tun_tap/test | 10 +- tests/tun_tap/tun_common.c | 2 +- tests/tun_tap/tun_tap.c | 10 +- tests/unix_socket/client.c | 1 + tests/unix_socket/server.c | 1 + tests/unix_socket/socketpair.c | 1 + tests/userfaultfd/userfaultfd.c | 2 +- tools/check-syntax | 2 +- 66 files changed, 304 insertions(+), 183 deletions(-) diff --git a/policy/test_global.te b/policy/test_global.te index 0078485..7125036 100644 --- a/policy/test_global.te +++ b/policy/test_global.te @@ -189,3 +189,26 @@ ifdef(`lockdown_defined', `allow $1 self:lockdown confidentiality;') define(`allow_userns_create', ifdef(`user_namespace_defined', `allow $1 self:user_namespace create;') ) + + +# virtme +gen_require(` + type kernel_t, unconfined_t, unlabeled_t, virtiofs_t; +') + +# tty since virtme starts with kernel_t after load_policy +kernel_use_fds(testsuite_domain) + +fs_search_tmpfs(testsuite_domain) +allow testsuite_domain virtiofs_t:dir search_dir_perms; +allow testsuite_domain virtiofs_t:file { entrypoint execute execute_no_trans map read_file_perms }; +allow testsuite_domain virtiofs_t:lnk_file read_lnk_file_perms; + +fs_getattr_tmpfs(test_filesystem_t) +# fs_manage_tmpfs_dirs +allow test_overlay_mounter_t tmpfs_t:dir { read write }; + +allow kernel_t self:capability2 mac_admin; +allow { kernel_t unconfined_t } virtiofs_t:system module_load; + +fs_associate_tmpfs(unlabeled_t)