summaryrefslogtreecommitdiff
path: root/test/end-to-end/computed-roots
diff options
context:
space:
mode:
authorKlaus Aehlig <klaus.aehlig@huawei.com>2025-01-23 13:02:19 +0100
committerKlaus Aehlig <klaus.aehlig@huawei.com>2025-01-23 16:53:07 +0100
commitbc5eee755cb649e850911c644ba4e55e83c78dd9 (patch)
tree3a97ba74d3931d5e76a13ef506073981136bf79f /test/end-to-end/computed-roots
parente181a0e0639a3904ca4e4f6bded05c429e6f66dd (diff)
downloadjustbuild-bc5eee755cb649e850911c644ba4e55e83c78dd9.tar.gz
Add basic end-to-end test on progress reporting
Diffstat (limited to 'test/end-to-end/computed-roots')
-rw-r--r--test/end-to-end/computed-roots/TARGETS8
-rw-r--r--test/end-to-end/computed-roots/progress.sh137
2 files changed, 145 insertions, 0 deletions
diff --git a/test/end-to-end/computed-roots/TARGETS b/test/end-to-end/computed-roots/TARGETS
index 2963b5e2..36fc4de1 100644
--- a/test/end-to-end/computed-roots/TARGETS
+++ b/test/end-to-end/computed-roots/TARGETS
@@ -97,6 +97,13 @@
, "repos": ["absent base of root (data)", "absent target root (data)"]
, "keep": ["out/build.log"]
}
+, "progress":
+ { "type": ["@", "rules", "shell/test", "script"]
+ , "name": ["progress"]
+ , "test": ["progress.sh"]
+ , "deps": [["", "tool-under-test"]]
+ , "keep": ["out/log"]
+ }
, "TESTS":
{ "type": ["@", "rules", "test", "suite"]
, "stage": ["computed-roots"]
@@ -111,6 +118,7 @@
, "error-reporting"
, "mr_computed_setup"
, "mr_take_over"
+ , "progress"
, "remote sharding"
]
}
diff --git a/test/end-to-end/computed-roots/progress.sh b/test/end-to-end/computed-roots/progress.sh
new file mode 100644
index 00000000..52a0a1cc
--- /dev/null
+++ b/test/end-to-end/computed-roots/progress.sh
@@ -0,0 +1,137 @@
+#!/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 OUT="${ROOT}/out"
+
+
+readonly BASE_ROOT="${ROOT}/base"
+mkdir -p "${BASE_ROOT}"
+cd "${BASE_ROOT}"
+cat > generate.py <<'EOF'
+# A deliberately slow action for generating a root
+import json
+import sys
+import time
+
+COUNT = int(sys.argv[1])
+targets = {}
+for i in range(COUNT):
+ time.sleep(1)
+ targets["%d" % i] = {"type": "generic", "outs": ["%d.txt" %i],
+ "cmds": ["seq 0 %d > %d.txt" % (i, i)]}
+targets[""] = {"type": "generic",
+ "deps": ["%d" % i for i in range(COUNT)],
+ "cmds": [" ".join(["cat"] + ["%d.txt" % i for i in range(COUNT)]
+ + ["> out"])],
+ "outs": ["out"]}
+print (json.dumps(targets, indent=2))
+EOF
+cat > TARGETS <<'EOF'
+{ "": {"type": "export", "flexible_config": ["COUNT"], "target": "generate"}
+, "generate":
+ { "type": "generic"
+ , "arguments_config": ["COUNT"]
+ , "outs": ["TARGETS"]
+ , "deps": ["generate.py"]
+ , "cmds":
+ [ { "type": "join"
+ , "separator": " "
+ , "$1":
+ [ "python3"
+ , "generate.py"
+ , {"type": "var", "name": "COUNT"}
+ , ">"
+ , "TARGETS"
+ ]
+ }
+ ]
+ }
+}
+EOF
+git init 2>&1
+git branch -m stable-1.0 2>&1
+git config user.email "nobody@example.org" 2>&1
+git config user.name "Nobody" 2>&1
+git add . 2>&1
+git commit -m "Initial commit" 2>&1
+GIT_TREE=$(git log -n 1 --format="%T")
+
+
+mkdir -p "${ROOT}/main"
+cd "${ROOT}/main"
+
+cat > repo-config.json <<EOF
+{ "repositories":
+ { "BaSeRooT":
+ {"workspace_root": ["git tree", "${GIT_TREE}", "${BASE_ROOT}/.git"]}
+ , "derived-10":
+ {"workspace_root": ["computed", "BaSeRooT", "", "", {"COUNT": "10"}]}
+ , "derived-11":
+ {"workspace_root": ["computed", "BaSeRooT", "", "", {"COUNT": "11"}]}
+ , "derived-12":
+ {"workspace_root": ["computed", "BaSeRooT", "", "", {"COUNT": "12"}]}
+ , "derived-13":
+ {"workspace_root": ["computed", "BaSeRooT", "", "", {"COUNT": "13"}]}
+ , "":
+ { "workspace_root": ["file", "."]
+ , "bindings":
+ { "a": "derived-10"
+ , "b": "derived-11"
+ , "c": "derived-12"
+ , "d": "derived-13"
+ }
+ }
+ }
+}
+EOF
+cat repo-config.json
+echo
+cat > TARGETS <<'EOF'
+{ "":
+ { "type": "install"
+ , "dirs":
+ [ [["@", "a", "", ""], "a"]
+ , [["@", "b", "", ""], "b"]
+ , [["@", "c", "", ""], "c"]
+ , [["@", "d", "", ""], "d"]
+ ]
+ }
+}
+EOF
+
+echo
+echo Building
+echo
+"${JUST}" install -L '["env", "PATH='"${PATH}"'"]' \
+ --local-build-root "${LBRDIR}" -C repo-config.json \
+ -f "${OUT}/log" -o "${OUT}/out" 2>&1
+echo
+
+# Sanity check for build
+[ "$(cat "${OUT}/out/a/out" | wc -l)" -eq 55 ]
+[ "$(cat "${OUT}/out/b/out" | wc -l)" -eq 66 ]
+[ "$(cat "${OUT}/out/c/out" | wc -l)" -eq 78 ]
+[ "$(cat "${OUT}/out/d/out" | wc -l)" -eq 91 ]
+echo
+
+# Progress should mention at least one target of a computed root
+grep 'PROG.*BaSeRooT' "${OUT}/log"
+
+echo OK