puppet-tripleo/spec/classes/tripleo_selinux_spec.rb
Cédric Jeanneret f4e5f1c89f Unmanage SELinux within puppet
Since [1] we manage SELinux state with ansible, at an earlier stage.

[1] https://review.openstack.org/645238

Depends-On: https://review.openstack.org/645238
Change-Id: I1b4cc5c510793d5fc908c8369a2f6a06c4ccd886
Related-Bug: #1821178
Related-Bug: #1821025
2019-03-25 16:34:16 +01:00

74 lines
1.9 KiB
Ruby

# Copyright (C) 2014 eNovance SAS <licensing@enovance.com>
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
#
# Unit tests for tripleo::selinux
#
require 'spec_helper'
describe 'tripleo::selinux' do
shared_examples_for 'tripleo::selinux' do
context 'sebool and semodule management' do
before :each do
facts.merge!({
:selinux => true,
:selinux_current_mode => 'enforcing'
})
end
let :params do
{ :booleans => ['foo', 'bar'],
:modules => ['module1', 'module2'],
:directory => '/path/to/modules'}
end
it 'enables the SELinux boolean' do
is_expected.to contain_selboolean('foo').with(
:persistent => true,
:value => 'on',
)
end
it 'enables the SELinux modules' do
is_expected.to contain_selmodule('module1').with(
:ensure => 'present',
:selmoduledir => '/path/to/modules',
)
end
end
end
context 'on Debian platforms' do
let :facts do
{ :osfamily => 'Debian' }
end
it_raises 'a Puppet::Error', /OS family unsuppored yet \(Debian\), SELinux support is only limited to RedHat family OS/
end
on_supported_os.each do |os, facts|
context "on #{os}" do
let(:facts) do
facts.merge({})
end
it_behaves_like 'tripleo::selinux'
end
end
end