diff options
author | Klaus Aehlig <klaus.aehlig@huawei.com> | 2025-01-24 10:29:32 +0100 |
---|---|---|
committer | Klaus Aehlig <klaus.aehlig@huawei.com> | 2025-01-24 12:23:22 +0100 |
commit | 0f04838a71b44578fe184d5c95521bb5eeaa1e84 (patch) | |
tree | 3f08f7c5b17f1d03360671fa1be956867359ea10 /test/end-to-end | |
parent | 5e104a526cf76fe75312d2fd288a3c88f506fb0a (diff) | |
download | justbuild-0f04838a71b44578fe184d5c95521bb5eeaa1e84.tar.gz |
Add test verifying the "generic" rule properly detecs staging conflicts
Diffstat (limited to 'test/end-to-end')
-rw-r--r-- | test/end-to-end/built-in-rules/TARGETS | 8 | ||||
-rw-r--r-- | test/end-to-end/built-in-rules/generic_conflict.sh | 77 |
2 files changed, 85 insertions, 0 deletions
diff --git a/test/end-to-end/built-in-rules/TARGETS b/test/end-to-end/built-in-rules/TARGETS index c645ecf7..4613a0e7 100644 --- a/test/end-to-end/built-in-rules/TARGETS +++ b/test/end-to-end/built-in-rules/TARGETS @@ -11,6 +11,13 @@ , "keep": ["null.json", "empty.json", "custom.json"] , "deps": [["", "tool-under-test"]] } +, "generic_conflict": + { "type": ["@", "rules", "shell/test", "script"] + , "name": ["generic_conflict"] + , "test": ["generic_conflict.sh"] + , "keep": ["log"] + , "deps": [["", "mr-tool-under-test"], ["", "tool-under-test"]] + } , "filegen_config": { "type": ["@", "rules", "shell/test", "script"] , "name": ["filegen_config"] @@ -41,6 +48,7 @@ , "deps": [ "export_counting" , "filegen_config" + , "generic_conflict" , "generic_out_dirs" , "generic_sh" , "symlink_config" diff --git a/test/end-to-end/built-in-rules/generic_conflict.sh b/test/end-to-end/built-in-rules/generic_conflict.sh new file mode 100644 index 00000000..fbb8470c --- /dev/null +++ b/test/end-to-end/built-in-rules/generic_conflict.sh @@ -0,0 +1,77 @@ +#!/bin/sh +# Copyright 2025 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 -e + +readonly ROOT="$(pwd)" +readonly LBRDIR="${TMPDIR}/local-build-root" +readonly JUST="${ROOT}/bin/tool-under-test" +readonly JUST_MR="${ROOT}/bin/mr-tool-under-test" +readonly MAIN="${ROOT}/main-repo" +readonly OTHER="${ROOT}/other-repo" + + +mkdir -p "${OTHER}" +cd "${OTHER}" +echo {} > TARGETS +echo other context > data + + +mkdir -p "${MAIN}" +cd "${MAIN}" +touch ROOT +cat > repos.json <<EOF +{ "repositories": + { "": + { "repository": {"type": "file", "path": "${MAIN}"} + , "bindings": {"other": "other"} + } + , "other": {"repository": {"type": "file", "path": "${MAIN}"}} + } +} +EOF +cat repos.json +echo + +echo my content > data +cat > TARGETS <<'EOF' +{ "": + { "type": "generic" + , "outs": ["out"] + , "cmds": ["cat data > out"] + , "deps": [["@", "other", "", "data"], ["TREE", null, "."]] + } +} +EOF + +echo +echo local file should analyse fine +echo +"${JUST_MR}" --just "${JUST}" --local-build-root "${LBRDIR}" \ + analyse data 2>&1 + +echo +echo The default target should detect a staging conflict +echo +"${JUST_MR}" --just "${JUST}" --local-build-root "${LBRDIR}" \ + analyse -f log --dump-actions - 2>&1 && exit 1 || : + +echo +# Verify that the error message is related +grep -i error log +grep -i conflict log + +echo +echo OK |