Skip to content

Commit

Permalink
Fix space_left/admin_space_left as percentages\n\nFixes simp#199
Browse files Browse the repository at this point in the history
  • Loading branch information
silug committed Jul 16, 2024
1 parent 21d2df7 commit 801520c
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 18 deletions.
16 changes: 10 additions & 6 deletions functions/validate_init_params.pp
Original file line number Diff line number Diff line change
Expand Up @@ -7,19 +7,23 @@
# @return [None]
#
function auditd::validate_init_params {
if (( '%' in $auditd::space_left ) or ( '%' in $auditd::admin_space_left ))
{
if (( '%' in $auditd::space_left ) or ( '%' in $auditd::admin_space_left )) {
if $facts['auditd_version'] and ( versioncmp($facts['auditd_version'], '2.8.5') < 0 ) {
fail('$space_left and $admin_space_left cannot contain "%" in auditd < 2.8.5')
}
}

if $auditd::space_left.type('generalized') == $auditd::admin_space_left.type('generalized') {
if $auditd::admin_space_left > $auditd::space_left {
fail('Auditd requires $space_left to be greater than $admin_space_left, otherwise it will not start')
if $auditd::admin_space_left =~ String {
if Integer($auditd::admin_space_left.regsubst(/%$/, '')) > Integer($auditd::space_left.regsubst(/%$/, '')) {
fail('Auditd requires $space_left to be greater than $admin_space_left, otherwise it will not start')
}
} else {
if $auditd::admin_space_left > $auditd::space_left {
fail('Auditd requires $space_left to be greater than $admin_space_left, otherwise it will not start')
}
}
}
else {
} else {
debug('$auditd::space_left and $auditd::admin_space_left are not of the same data type, cannot compare for sanity')
}
}
39 changes: 27 additions & 12 deletions spec/classes/init_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -85,13 +85,11 @@
end

context 'auditd 2.8.5' do
context 'with space_left as a percentage' do
let(:facts) do
base_facts.merge({
:auditd_version => '2.8.5'
})
end
let(:facts) do
base_facts.merge(auditd_version: '2.8.5')
end

context 'with space_left as a percentage' do
let(:params) do
{
:space_left => '20%'
Expand All @@ -102,12 +100,6 @@
end

context 'with admin_space_left as a percentage' do
let(:facts) do
base_facts.merge({
:auditd_version => '2.8.5'
})
end

let(:params) do
{
:admin_space_left => '20%'
Expand All @@ -117,6 +109,29 @@
it { is_expected.to compile.with_all_deps }
it { is_expected.to contain_class('auditd').with_space_left('21%') }
end

context 'auditd with space_left < admin_space_left as percentages' do
let(:params) do
{
space_left: '5%',
admin_space_left: '25%',
}
end

it { is_expected.to compile.and_raise_error(%r{Auditd requires \$space_left to be greater than \$admin_space_left, otherwise it will not start}) }
end

context 'auditd with space_left > admin_space_left as percentages' do
let(:params) do
{
space_left: '25%',
admin_space_left: '5%',
}
end

it { is_expected.to compile.with_all_deps }
it { is_expected.to contain_class('auditd').with_space_left('25%').with_admin_space_left('5%') }
end
end

context 'auditd with auditing disabled' do
Expand Down

0 comments on commit 801520c

Please sign in to comment.