From b958c67a9270063ada8d6800e022e3489ff3d205 Mon Sep 17 00:00:00 2001 From: Klaus Aehlig Date: Wed, 6 Mar 2024 10:57:06 +0100 Subject: Add test verifying reporting levels ... in particular, verify that no error is reported on successfull command completion. --- test/end-to-end/just-mr/TARGETS | 11 ++++ test/end-to-end/just-mr/reporting-verbosity.sh | 85 ++++++++++++++++++++++++++ 2 files changed, 96 insertions(+) create mode 100644 test/end-to-end/just-mr/reporting-verbosity.sh (limited to 'test') diff --git a/test/end-to-end/just-mr/TARGETS b/test/end-to-end/just-mr/TARGETS index cdf668f4..203f79c4 100644 --- a/test/end-to-end/just-mr/TARGETS +++ b/test/end-to-end/just-mr/TARGETS @@ -193,6 +193,16 @@ , "deps": [["end-to-end", "mr-tool-under-test"], ["end-to-end", "tool-under-test"]] } +, "reporting-verbosity": + { "type": ["end-to-end", "with remote"] + , "name": ["reporting-verbosity"] + , "test": ["reporting-verbosity.sh"] + , "deps": + [ ["end-to-end", "tool-under-test"] + , ["end-to-end", "mr-tool-under-test"] + , "fetch-absent (data)" + ] + } , "TESTS": { "type": "install" , "tainted": ["test"] @@ -216,6 +226,7 @@ , "defaults" , "absent-roots" , "foreign-file" + , "reporting-verbosity" ] , { "type": "if" , "cond": {"type": "var", "name": "TEST_COMPATIBLE_REMOTE"} diff --git a/test/end-to-end/just-mr/reporting-verbosity.sh b/test/end-to-end/just-mr/reporting-verbosity.sh new file mode 100644 index 00000000..040a68d7 --- /dev/null +++ b/test/end-to-end/just-mr/reporting-verbosity.sh @@ -0,0 +1,85 @@ +#!/bin/sh +# Copyright 2024 Huawei Cloud Computing Technology Co., Ltd. +# +# 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. + + +set -eu + +env + +readonly JUST="${PWD}/bin/tool-under-test" +readonly JUST_MR="${PWD}/bin/mr-tool-under-test" +readonly LBR="${TEST_TMPDIR}/local-build-root" +readonly OUT="${TEST_TMPDIR}/out" +readonly LOG="${TEST_TMPDIR}/log" + +COMPAT="" +if [ "${COMPATIBLE:-}" = "YES" ]; then + COMPAT="--compatible" +fi + +ARCHIVE_CONTENT=$(git hash-object src/data.tar) +echo "Archive has content $ARCHIVE_CONTENT" + +mkdir work +cd work +touch ROOT +cat > repos.json < targets/TARGETS <<'EOF' +{ "": + { "type": "generic" + , "outs": ["archive_id"] + , "cmds": ["git hash-object data.tar > archive_id"] + , "deps": ["data.tar"] + } +} +EOF + +echo +cat repos.json +echo +mkdir -p "${LOG}" +"${JUST_MR}" --norc --just "${JUST}" --local-build-root "${LBR}" \ + -r "${REMOTE_EXECUTION_ADDRESS}" ${COMPAT} \ + -f "${LOG}/log" \ + --distdir ../src \ + install -o "${OUT}" 2>&1 +echo +cat "${OUT}/archive_id" +[ $(cat "${OUT}/archive_id") = "${ARCHIVE_CONTENT}" ] +echo +# As the build succeeded, there should not be any error reported +cat "${LOG}/log" +echo +grep ERROR "${LOG}/log" && exit 1 || : + +echo +echo OK -- cgit v1.2.3