
The log extension is responsible for retrieving logs from the system, if journalctl is present the logs will come from it, otherwise we fallback to getting the logs from the /var/log directory + dmesg logs. In the coreos ramdisk, we need to bind mount /run/log in the container so the IPA service can have access to the journal. For the tinyIPA ramdisk, the logs from IPA are now being redirected to /var/logs/ironic-python-agent.log instead of only going to the default stdout. Inspector now shares the same method of collecting logs, extending its capabilities for non-systemd systems. Partial-Bug: #1587143 Change-Id: Ie507e2e5c58cffa255bbfb2fa5ffb95cb98ed8c4
39 lines
1.3 KiB
Python
39 lines
1.3 KiB
Python
# Copyright 2016 Red Hat, Inc.
|
|
# All Rights Reserved.
|
|
#
|
|
# 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.
|
|
|
|
import mock
|
|
|
|
from ironic_python_agent import utils
|
|
from oslotest import base as test_base
|
|
|
|
from ironic_python_agent.extensions import log
|
|
|
|
|
|
class TestLogExtension(test_base.BaseTestCase):
|
|
|
|
def setUp(self):
|
|
super(TestLogExtension, self).setUp()
|
|
self.agent_extension = log.LogExtension()
|
|
|
|
@mock.patch.object(utils, 'collect_system_logs', autospec=True)
|
|
def test_collect_system_logs(self, mock_collect):
|
|
ret = 'Squidward Tentacles'
|
|
mock_collect.return_value = ret
|
|
|
|
cmd_result = self.agent_extension.collect_system_logs()
|
|
serialized_cmd_result = cmd_result.serialize()
|
|
expected_ret = {'system_logs': ret}
|
|
self.assertEqual(expected_ret, serialized_cmd_result['command_result'])
|