Skip to content

Commit

Permalink
Address post-merge comments on PR #224
Browse files Browse the repository at this point in the history
	Removes declaration of Class[splunk::params] since it should
	already be in scope and declared by either
	Class[splunk::enterprise] or Class[splunk::forwarder] and
	removes an unnecessary test of an empty hash. Modifies
	Splunk::Addon spec test to address the removal of
	Class[splunk::params].
  • Loading branch information
ody committed Apr 17, 2019
1 parent 820a15b commit d7ee7df
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 26 deletions.
50 changes: 24 additions & 26 deletions manifests/addon.pp
Original file line number Diff line number Diff line change
Expand Up @@ -43,18 +43,18 @@
Hash $inputs = {},
) {

include splunk::params

if defined(Class['splunk::forwarder']) {
$mode = 'forwarder'
} else {
} elsif defined(Class['splunk::enterprise']) {
$mode = 'enterprise'
} else {
fail('Instances of Splunk::Addon require the declaration of one of either Class[splunk::enterprise] or Class[splunk::forwarder]')
}


if $splunk_home {
$_splunk_home = $splunk_home
}
else {
} else {
case $mode {
'forwarder': { $_splunk_home = $splunk::params::forwarder_homedir }
'enterprise': { $_splunk_home = $splunk::params::enterprise_homedir }
Expand Down Expand Up @@ -84,30 +84,28 @@

file { "${_splunk_home}/etc/apps/${name}/local": ensure => directory }

unless $inputs.empty {
$inputs.each |$section, $attributes| {
$attributes.each |$setting, $value| {
case $mode {
'forwarder': {
splunkforwarder_input { "${name}_${section}_${setting}":
section => $section,
setting => $setting,
value => $value,
context => "apps/${name}/local",
require => File["${_splunk_home}/etc/apps/${name}/local"],
}
$inputs.each |$section, $attributes| {
$attributes.each |$setting, $value| {
case $mode {
'forwarder': {
splunkforwarder_input { "${name}_${section}_${setting}":
section => $section,
setting => $setting,
value => $value,
context => "apps/${name}/local",
require => File["${_splunk_home}/etc/apps/${name}/local"],
}
'enterprise': {
splunk_input { "${name}_${section}_${setting}":
section => $section,
setting => $setting,
value => $value,
context => "apps/${name}/local",
require => File["${_splunk_home}/etc/apps/${name}/local"],
}
}
'enterprise': {
splunk_input { "${name}_${section}_${setting}":
section => $section,
setting => $setting,
value => $value,
context => "apps/${name}/local",
require => File["${_splunk_home}/etc/apps/${name}/local"],
}
default: { fail('Instances of Splunk::Addon require the declaration of one of either Class[splunk::enterprise] or Class[splunk::forwarder]') }
}
default: { fail('Instances of Splunk::Addon require the declaration of one of either Class[splunk::enterprise] or Class[splunk::forwarder]') }
}
}
}
Expand Down
22 changes: 22 additions & 0 deletions spec/defines/addon_spec.rb
Original file line number Diff line number Diff line change
@@ -1,7 +1,29 @@
require 'spec_helper'

describe 'splunk::addon' do
context 'fail if class prerequisit not declared' do
on_supported_os.each do |os, facts|
if os.start_with?('windows')
# Splunk Server not used supported on windows
else
context "on #{os}" do
let(:facts) do
facts
end
let(:title) { 'Splunk_TA' }
let(:params) { { 'splunkbase_source' => 'puppet:///modules/profiles/splunk-add-on.tgz' } }

it { is_expected.to raise_error(Puppet::Error, /Instances of Splunk::Addon require the declaration of one of either/)}
end
end
end
end

context 'supported operating systems' do
let(:pre_condition) do
'include splunk::forwarder'
end

on_supported_os.each do |os, facts|
if os.start_with?('windows')
# Splunk Server not used supported on windows
Expand Down

0 comments on commit d7ee7df

Please sign in to comment.