puppet-tripleo/spec/classes/tripleo_profile_base_logging_fluentd_spec.rb
Juan Badia Payno bfba3ad7ac Fix fluentd multifile problem.
There is a problem on the current implementation.
Currently the new_source variable is an Array of hashes,
not a hash of hashes. The current impletation is wrong,
as it can be seen for the following error at the log gate:
http://logs.openstack.org/09/563009/7/check/tripleo-ci-centos-7-containers-multinode/aa4faf9/logs/undercloud/home/zuul/overcloud_deploy.log.txt.gz#_2018-09-03_15_17_39
[search for fluentd_service.pp] as there are too many lines at the same timestamp.

Error: Evaluation Error: Error while evaluating a Resource
Statement, Evaluation Error: Error while evaluating a Function
Call, comparison of Hash with Hash failed at
/etc/puppet/modules/fluentd/manifests/config.pp:6:16  at
/etc/puppet/modules/tripleo/manifests/profile/base/logging/fluentd/fluentd_service.pp:47
on node centos-7-rax-iad-0001722758.localdomain

Change-Id: Ifd5fbf6509addf4a564ff83c4551525c9a139ff4
2018-09-20 12:14:19 +02:00

327 lines
12 KiB
Ruby

#
# Copyright (C) 2017 Red Hat, Inc.
#
# 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.
#
require 'spec_helper'
describe 'tripleo::profile::base::logging::fluentd' do
shared_examples_for 'tripleo::profile::base::logging::fluentd' do
before :each do
facts.merge!({ :step => params[:step] })
end
context 'with step less than 4' do
let(:params) { { :step => 3 } }
it 'should do nothing' do
is_expected.to_not contain_class('fluentd')
is_expected.to_not contain_class('systemd::systemctl::daemon_reload')
is_expected.to_not contain_fluentd__plugin('rubygem-fluent-plugin-add')
end
end
context 'with defaults and step greater than 3' do
let(:params) { { :step => 4 } }
it { is_expected.to contain_class('fluentd') }
it { is_expected.to contain_class('systemd::systemctl::daemon_reload') }
it { is_expected.to contain_fluentd__plugin('rubygem-fluent-plugin-add').with(
:plugin_provider => 'yum',
) }
it { is_expected.to contain_fluentd__config('110-monitoring-agent.conf') }
it { is_expected.to contain_file('/etc/fluentd/config.d/110-monitoring-agent.conf').with_content(
"# This file is managed by Puppet, do not edit manually.
<source>
bind 127.0.0.1
port 24220
@type monitor_agent
</source>
"
) }
it { is_expected.to contain_fluentd__config('110-system-sources.conf') }
it { is_expected.to contain_file('/etc/rsyslog.d/fluentd.conf').with_content(
"*.* @127.0.0.1:42185"
) }
it { is_expected.to contain_file('/etc/fluentd/config.d/110-system-sources.conf').with_content(
"# This file is managed by Puppet, do not edit manually.
<source>
port 42185
tag system.messages
@type syslog
</source>
"
) }
end
context 'step greater than 3 and a fluentd source' do
let(:params) { {
:step => 4,
:fluentd_sources => [ {
'format' => '/(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/',
'path' => '/var/log/keystone/keystone.log',
'pos_file' => '/var/cache/fluentd/openstack.keystone.pos',
'tag' => 'openstack.keystone',
'type' => 'tail'
} ],
} }
it { is_expected.to contain_class('fluentd') }
it { is_expected.to contain_class('systemd::systemctl::daemon_reload') }
it { is_expected.to contain_fluentd__plugin('rubygem-fluent-plugin-add').with(
:plugin_provider => 'yum',
) }
it { is_expected.to contain_fluentd__config('100-openstack-sources.conf').with(
:config => {
'source' => params[:fluentd_sources]
}
) }
it { is_expected.to contain_file('/etc/fluentd/config.d/100-openstack-sources.conf').with_content(
/^\s*path \/var\/log\/keystone\/keystone\.log$/
) }
end
context 'step greater than 3 and a fluentd source with transformation' do
let(:params) { {
:step => 4,
:fluentd_sources => [ {
'format' => '/(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/',
'path' => '/var/log/keystone/keystone.log',
'pos_file' => '/var/cache/fluentd/openstack.keystone.pos',
'tag' => 'openstack.keystone',
'type' => 'tail'
} ],
:fluentd_path_transform => [
'/var/log/',
'/var/log/containers/',
]
} }
it { is_expected.to contain_class('fluentd') }
it { is_expected.to contain_fluentd__plugin('rubygem-fluent-plugin-add').with(
:plugin_provider => 'yum',
) }
it { is_expected.to contain_fluentd__config('100-openstack-sources.conf').with(
:config => {
'source' => [ {
'format' => '/(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/',
'path' => '/var/log/containers/keystone/keystone.log',
'pos_file' => '/var/cache/fluentd/openstack.keystone.pos',
'tag' => 'openstack.keystone',
'type' => 'tail'
} ]
}
) }
end
context 'Config by service -- ceilometer_agent_central' do
let(:params) { {
:step => 4,
:fluentd_default_format => '/(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/',
:fluentd_manage_groups => false,
:fluentd_pos_file_path => '/var/cache/fluentd/',
:service_names => [ 'ceilometer_agent_central' ]
} }
it { is_expected.to contain_class('fluentd') }
it { is_expected.to contain_file('/var/cache/fluentd/') }
it { is_expected.to contain_tripleo__profile__base__logging__fluentd__fluentd_service('ceilometer_agent_central').with(
:pos_file_path => '/var/cache/fluentd/',
:default_format => '/(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/'
) }
it { is_expected.to contain_fluentd__config('100-openstack-ceilometer_agent_central.conf') }
it { is_expected.to contain_file('/etc/fluentd/config.d/100-openstack-ceilometer_agent_central.conf').with_content(
"# This file is managed by Puppet, do not edit manually.
<source>
format /(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/
path /var/log/ceilometer/central.log
pos_file /var/cache/fluentd//openstack.ceilometer.agent.central.pos
tag openstack.ceilometer.agent.central
@type tail
</source>
"
) }
end
context 'Config by service -- ceilometer_agent_central with path trasnformation' do
let(:params) { {
:step => 4,
:fluentd_default_format => '/(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/',
:fluentd_manage_groups => false,
:fluentd_pos_file_path => '/var/cache/fluentd/',
:service_names => [ 'ceilometer_agent_central' ],
:fluentd_path_transform => [
'/var/log/',
'/var/log/containers/',
]
} }
it { is_expected.to contain_class('fluentd') }
it { is_expected.to contain_file('/var/cache/fluentd/') }
it { is_expected.to contain_tripleo__profile__base__logging__fluentd__fluentd_service('ceilometer_agent_central').with(
:pos_file_path => '/var/cache/fluentd/',
:default_format => '/(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/'
) }
it { is_expected.to contain_file('/etc/fluentd/config.d/100-openstack-ceilometer_agent_central.conf').with_content (
"# This file is managed by Puppet, do not edit manually.
<source>
format /(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/
path /var/log/containers/ceilometer/central.log
pos_file /var/cache/fluentd//openstack.ceilometer.agent.central.pos
tag openstack.ceilometer.agent.central
@type tail
</source>
"
) }
end
context 'Multifiles -- horizon' do
let(:params) { {
:step => 4,
:fluentd_default_format => '/(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/',
:fluentd_manage_groups => false,
:fluentd_pos_file_path => '/var/cache/fluentd/',
:service_names => [ 'horizon' ],
:fluentd_path_transform => [
'/var/log/',
'/var/log/containers/'
]
} }
it { is_expected.to contain_file('/etc/fluentd/config.d/100-openstack-horizon.conf').with_content (
"# This file is managed by Puppet, do not edit manually.
<source>
format /(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/
path /var/log/containers/horizon/test.log
pos_file /var/cache/fluentd/horizon-test.pos
tag openstack.horizon.test
@type tail
</source>
<source>
format /(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/
path /var/log/containers/horizon/access.log
pos_file /var/cache/fluentd//openstack.horizon.access.pos
tag openstack.horizon.access
@type tail
</source>
"
) }
end
context 'Multifiles -- horizon no transformation' do
let(:params) { {
:step => 4,
:fluentd_default_format => '/(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/',
:fluentd_manage_groups => false,
:fluentd_pos_file_path => '/var/cache/fluentd/',
:service_names => [ 'horizon' ],
} }
it { is_expected.to contain_file('/etc/fluentd/config.d/100-openstack-horizon.conf').with_content (
"# This file is managed by Puppet, do not edit manually.
<source>
format /(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/
path /var/log/horizon/test.log
pos_file /var/cache/fluentd/horizon-test.pos
tag openstack.horizon.test
@type tail
</source>
<source>
format /(?<time>\\d{4}-\\d{2}-\\d{2} \\d{2} =>\\d{2}:\\d{2}.\\d+) (?<pid>\\d+) (?<priority>\\S+) (?<message>.*)$/
path /var/log/horizon/access.log
pos_file /var/cache/fluentd//openstack.horizon.access.pos
tag openstack.horizon.access
@type tail
</source>
"
) }
end
context 'Groups by service -- ceilometer_agent_central added ceilometer' do
let(:params) { {
:step => 4,
:fluentd_manage_groups => true,
:fluentd_groups => [ 'fluentd' ]
} }
it { is_expected.to contain_class('fluentd') }
it { is_expected.to contain_user('fluentd').with(
:ensure =>'present',
:groups => [ 'fluentd', 'ceilometer', 'horizon' ],
:membership => 'minimum'
) }
end
context 'fluentd user and managed groups' do
let(:params) { {
:step => 4,
:fluentd_service_user => 'fluentd',
:fluentd_manage_groups => true,
:fluentd_groups => [ 'fluentd' ]
} }
it { is_expected.to contain_class('fluentd') }
it { is_expected.to contain_class('systemd::systemctl::daemon_reload') }
it { is_expected.to contain_service('fluentd') }
it { is_expected.to contain_file('/etc/systemd/system/fluentd.service.d/fluentd_user.conf')
.with( {
:ensure => 'file',
:content => [ "# This file is maintained by puppet.\n[Service]\nUser=fluentd\n" ]
} ) }
it { is_expected.to contain_user('fluentd').with(
:ensure =>'present',
:groups => [ 'fluentd','ceilometer','horizon' ],
:membership => 'minimum'
) }
end
context 'root user, no matter about groups' do
let(:params) { {
:step => 4,
:fluentd_service_user => 'root',
:fluentd_manage_groups => true,
:fluentd_groups => [ 'fluentd' ]
} }
it { is_expected.to contain_class('fluentd') }
it { is_expected.to contain_class('systemd::systemctl::daemon_reload') }
it { is_expected.to contain_service('fluentd') }
it { is_expected.to contain_file('/etc/systemd/system/fluentd.service.d/fluentd_user.conf')
.with( {
:ensure => 'file',
:content => [ "# This file is maintained by puppet.\n[Service]\nUser=root\n" ]
} ) }
it { is_expected.to_not contain_user('fluentd') }
end
end
on_supported_os.each do |os, facts|
context "on #{os}" do
let (:facts) {
facts
}
it_behaves_like 'tripleo::profile::base::logging::fluentd'
end
end
end