summaryrefslogtreecommitdiff
path: root/test/end-to-end
diff options
context:
space:
mode:
authorKlaus Aehlig <klaus.aehlig@huawei.com>2025-01-24 10:29:32 +0100
committerKlaus Aehlig <klaus.aehlig@huawei.com>2025-01-24 12:23:22 +0100
commit0f04838a71b44578fe184d5c95521bb5eeaa1e84 (patch)
tree3f08f7c5b17f1d03360671fa1be956867359ea10 /test/end-to-end
parent5e104a526cf76fe75312d2fd288a3c88f506fb0a (diff)
downloadjustbuild-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/TARGETS8
-rw-r--r--test/end-to-end/built-in-rules/generic_conflict.sh77
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