psss / tests / selinux

Forked from tests/selinux 6 years ago
Clone

Blame selinux-policy/rrdcached-service-and-related/runtest.sh

b453e34
#!/bin/bash
b453e34
# vim: dict+=/usr/share/beakerlib/dictionary.vim cpt=.,w,b,u,t,i,k
b453e34
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
b453e34
#
b453e34
#   runtest.sh of /CoreOS/selinux-policy/Regression/rrdcached-service-and-related
b453e34
#   Description: Basic test for rrdcached service
b453e34
#   Author: Patrik Koncity <pkoncity@redhat.com>
b453e34
#
b453e34
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
b453e34
#
b453e34
#   Copyright (c) 2019 Red Hat, Inc.
b453e34
#
b453e34
#   This program is free software: you can redistribute it and/or
b453e34
#   modify it under the terms of the GNU General Public License as
b453e34
#   published by the Free Software Foundation, either version 2 of
b453e34
#   the License, or (at your option) any later version.
b453e34
#
b453e34
#   This program is distributed in the hope that it will be
b453e34
#   useful, but WITHOUT ANY WARRANTY; without even the implied
b453e34
#   warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
b453e34
#   PURPOSE.  See the GNU General Public License for more details.
b453e34
#
b453e34
#   You should have received a copy of the GNU General Public License
b453e34
#   along with this program. If not, see http://www.gnu.org/licenses/.
b453e34
#
b453e34
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
b453e34
b453e34
# Include Beaker environment
b453e34
. /usr/bin/rhts-environment.sh || exit 1
b453e34
. /usr/share/beakerlib/beakerlib.sh || exit 1
b453e34
b453e34
PACKAGE="selinux-policy"
b453e34
SERVICE_NAME="rrdcached"
b453e34
SERVICE_PACKAGE="rrdtool"
b453e34
PROCESS_NAME="rrdcached"
b453e34
PROCESS_CONTEXT="rrdcached_t"
b453e34
VAR_RUN_CONTEXT="rrdcached_var_run_t"
b453e34
TMP_CONTEXT="rrdcached_tmp_t"
b453e34
b453e34
rlJournalStart
b453e34
    rlPhaseStartSetup
b453e34
        rlRun "rlImport 'selinux-policy/common'"
b453e34
        rlAssertRpm $PACKAGE
b453e34
        rlAssertRpm $SERVICE_PACKAGE
b453e34
        rlSESetEnforce
b453e34
        rlSEStatus
b453e34
        rlSESetTimestamp
b453e34
    rlPhaseEnd
b453e34
b453e34
    rlPhaseStartTest "bz#1726255"
b453e34
        rlSEMatchPathCon "/usr/bin/rrdcached" "rrdcached_exec_t"
b453e34
        rlSEMatchPathCon "/var/run/rrdcached.*" "rrdcached_var_run_t"
b453e34
        rlSESearchRule "type_transition init_t rrdcached_exec_t : process ${PROCESS_CONTEXT}"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} self:capability { chown setgid setuid }"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} self:fifo_file { append create getattr ioctl link lock open read rename setattr unlink write } "
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} self:unix_stream_socket { accept append bind connect create getattr getopt ioctl listen lock read setattr setopt shutdown write } "
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} ${VAR_RUN_CONTEXT}:dir { add_name create getattr ioctl link lock open read remove_name rename reparent rmdir search setattr unlink write } "
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} ${VAR_RUN_CONTEXT}:file { append create getattr ioctl link lock open read rename setattr unlink write }"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} ${VAR_RUN_CONTEXT}:lnk_file { append create getattr ioctl link lock read rename setattr unlink write }"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} var_t:dir { getattr open search }"
b453e34
        rlSESearchRule "type_transition rrdcached_t var_run_t:dir rrdcached_var_run_t "
b453e34
        rlSESearchRule "type_transition rrdcached_t var_run_t:file rrdcached_var_run_t "
b453e34
        rlSESearchRule "type_transition rrdcached_t var_run_t:lnk_file rrdcached_var_run_t "
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} ${TMP_CONTEXT}:dir { add_name create getattr ioctl link lock open read remove_name rename reparent rmdir search setattr unlink write }"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} ${TMP_CONTEXT}:file { append create getattr ioctl link lock open read rename setattr unlink write }"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} ${TMP_CONTEXT}:sock_file { append create getattr ioctl link lock open read rename setattr unlink write }"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} tmp_t:dir { add_name getattr ioctl lock open read remove_name search write }"
b453e34
        rlSESearchRule "type_transition rrdcached_t tmp_t:dir ${TMP_CONTEXT} "
b453e34
        rlSESearchRule "type_transition rrdcached_t tmp_t:file ${TMP_CONTEXT} "
b453e34
        rlSESearchRule "type_transition rrdcached_t tmp_t:sock_file ${TMP_CONTEXT} "
b453e34
        rlSESearchRule "typeattribute ${PROCESS_CONTEXT} nsswitch_domain"
b453e34
        rlSESearchRule "typeattribute ${PROCESS_CONTEXT} netlabel_peer_type"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} privfd:fd use "
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} etc_t:dir { getattr ioctl lock open read search }"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} etc_t:file { getattr ioctl lock open read }"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} etc_t:lnk_file { getattr read }"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} etc_runtime_t:file { getattr ioctl lock open read }"
b453e34
        rlSESearchRule "allow ${PROCESS_CONTEXT} etc_runtime_t:lnk_file { getattr read }"
b453e34
        rlSESearchRule "typeattribute ${PROCESS_CONTEXT} syslog_client_type"
b453e34
    rlPhaseEnd
b453e34
b453e34
    rlPhaseStartTest "real scenario"
b453e34
        rlSEService - ${SERVICE_NAME} ${PROCESS_NAME} ${PROCESS_CONTEXT} "start status" 2
b453e34
        rlRun "restorecon -Rv /run /var"
b453e34
        rlSEService - ${SERVICE_NAME} ${PROCESS_NAME} ${PROCESS_CONTEXT} "restart status stop status" 2
b453e34
    rlPhaseEnd
b453e34
b453e34
    # TODO: add test scenario for rrdcached.socket
b453e34
b453e34
    rlPhaseStartCleanup
b453e34
        sleep 2
b453e34
        rlSECheckAVC
b453e34
    rlPhaseEnd
b453e34
rlJournalPrintText
b453e34
rlJournalEnd
b453e34