# # Copyright (C) 2019 Codethink Limited # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public # License as published by the Free Software Foundation; either # version 2 of the License, or (at your option) any later version. # # This library is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public # License along with this library. If not, see . # # Pylint doesn't play well with fixtures and dependency injection from pytest # pylint: disable=redefined-outer-name import os import re import pytest from buildstream.testing import cli # pylint: disable=unused-import # Project directory DATA_DIR = os.path.join(os.path.dirname(os.path.realpath(__file__)), "project",) @pytest.mark.datafiles(DATA_DIR) def test_artifact_log(cli, datafiles): project = str(datafiles) # Get the cache key of our test element result = cli.run( project=project, silent=True, args=["--no-colors", "show", "--deps", "none", "--format", "%{full-key}", "target.bst"], ) key = result.output.strip() # Ensure we have an artifact to read result = cli.run(project=project, args=["build", "target.bst"]) assert result.exit_code == 0 # Read the log via the element name result = cli.run(project=project, args=["artifact", "log", "target.bst"]) assert result.exit_code == 0 log = result.output # Assert that there actually was a log file assert log != "" # Read the log via the key result = cli.run(project=project, args=["artifact", "log", "test/target/" + key]) assert result.exit_code == 0 assert log == result.output # Read the log via glob result = cli.run(project=project, args=["artifact", "log", "test/target/*"]) assert result.exit_code == 0 # The artifact is cached under both a strong key and a weak key assert log == result.output @pytest.mark.datafiles(DATA_DIR) def test_artifact_log_files(cli, datafiles): project = str(datafiles) # Ensure we have an artifact to read result = cli.run(project=project, args=["build", "target.bst"]) assert result.exit_code == 0 logfiles = os.path.join(project, "logfiles") target = os.path.join(project, logfiles, "target.log") import_bin = os.path.join(project, logfiles, "import-bin.log") # Ensure the logfile doesn't exist before the command is run assert not os.path.exists(logfiles) assert not os.path.exists(target) assert not os.path.exists(import_bin) # Run the command and ensure the file now exists result = cli.run(project=project, args=["artifact", "log", "--out", logfiles, "target.bst", "import-bin.bst"]) assert result.exit_code == 0 assert os.path.exists(logfiles) assert os.path.exists(target) assert os.path.exists(import_bin) # Ensure the file contains the logs by checking for the LOG line pattern = r"\[..:..:..\] LOG \[.*\] target.bst" with open(target, "r") as f: data = f.read() assert len(re.findall(pattern, data, re.MULTILINE)) > 0 pattern = r"\[..:..:..\] LOG \[.*\] import-bin.bst" with open(import_bin, "r") as f: data = f.read() assert len(re.findall(pattern, data, re.MULTILINE)) > 0