blob: b26564ed9d5b9ac88acd0b12e8f1af539cef31f1 [file] [log] [blame]
#
# Copyright (C) 2019 Codethink Limited
#
# 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.
#
# 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)
@pytest.mark.parametrize("target", ["artifact", "artifact-glob"])
@pytest.mark.parametrize("with_project", [True, False], ids=["with-project", "without-project"])
def test_artifact_log(cli, datafiles, target, with_project):
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"])
result.assert_success()
# Collect the log by running `bst artifact log` on the element name first
result = cli.run(project=project, args=["artifact", "log", "target.bst"])
result.assert_success()
log = result.output
assert log != ""
# Delete the project.conf if we're going to try this without a project
if not with_project:
os.remove(os.path.join(project, "project.conf"))
args = ["artifact", "log"]
if target == "artifact":
args.append("test/target/{}".format(key))
elif target == "artifact-glob":
args.append("test/target/*")
# Run bst artifact log
result = cli.run(project=project, args=args)
result.assert_success()
assert result.output == log
@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", encoding="utf-8") 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", encoding="utf-8") as f:
data = f.read()
assert len(re.findall(pattern, data, re.MULTILINE)) > 0