diff options
author | Klaus Aehlig <klaus.aehlig@huawei.com> | 2024-07-23 10:18:41 +0200 |
---|---|---|
committer | Klaus Aehlig <klaus.aehlig@huawei.com> | 2024-07-24 10:18:58 +0200 |
commit | bdd5df3bcf10ac5fc8ba4d2082562fab792a0d37 (patch) | |
tree | 8474079849f4efe61f671aaef69e514216f7497a | |
parent | a442a2ec00e181f1354f9613d785dd090617b132 (diff) | |
download | justbuild-bdd5df3bcf10ac5fc8ba4d2082562fab792a0d37.tar.gz |
Extend gc-repo test to also verify that git-tree repositories are taken from older generations
-rw-r--r-- | test/end-to-end/just-mr/gc-repo.sh | 43 |
1 files changed, 42 insertions, 1 deletions
diff --git a/test/end-to-end/just-mr/gc-repo.sh b/test/end-to-end/just-mr/gc-repo.sh index e9611700..96f7ce14 100644 --- a/test/end-to-end/just-mr/gc-repo.sh +++ b/test/end-to-end/just-mr/gc-repo.sh @@ -27,6 +27,7 @@ mkdir -p "${DISTDIR}" readonly ARCHIVE_CONTENT="${TEST_TMPDIR}/archive" readonly SCRATCH_LBR="${TEST_TMPDIR}/throw-away-build-root" readonly SCRATCH_FF="${TEST_TMPDIR}/scratch-space-for-foreign-file" +readonly SCRATCH_TREE="${TEST_TMPDIR}/scratch-space-for-git-tree" readonly LBR="${TEST_TMPDIR}/local-build-root" readonly OUT="${TEST_TMPDIR}/out" mkdir -p "${OUT}" @@ -89,6 +90,24 @@ echo echo "Foreign file ${FOREIGN} creating tree ${FOREIGN_TREE}" echo +# Set up a "git tree" +cat > "${BIN}/mock-foreign-vcs" <<'EOF' +#!/bin/sh + +mkdir -p foo/bar/baz +echo foo data > foo/data.txt +echo bar data > foo/bar/data.txt +echo baz data > foo/bar/baz/data.txt +EOF +chmod 755 "${BIN}/mock-foreign-vcs" +rm -rf "${SCRATCH_TREE}" +mkdir -p "${SCRATCH_TREE}" +(cd "${SCRATCH_TREE}" && "${BIN}/mock-foreign-vcs") +FOREIGN_GIT_TREE=$("${JUST}" add-to-cas --local-build-root "${SCRATCH_LBR}" "${SCRATCH_TREE}") +echo +echo "Git tree ${FOREIGN_GIT_TREE}" +echo + # Create workspace with just-mr repository configuration mkdir -p "${WORK}" cd "${WORK}" @@ -98,7 +117,11 @@ cat > repos.json <<EOF { "": { "repository": {"type": "file", "path": "."} , "bindings": - {"git": "git", "archive": "archive", "foreign": "foreign_file"} + { "git": "git" + , "archive": "archive" + , "foreign": "foreign_file" + , "tree": "git_tree" + } } , "git": { "repository": @@ -123,6 +146,13 @@ cat > repos.json <<EOF , "name": "data.txt" } } + , "git_tree": + { "repository": + { "type": "git tree" + , "id": "${FOREIGN_GIT_TREE}" + , "cmd": ["${BIN}/mock-foreign-vcs"] + } + } } } EOF @@ -154,9 +184,15 @@ TREE_FOUND="$(jq -r '.repositories.foreign_file.workspace_root[1]' "${CONFIG}")" [ "${TREE_FOUND}" = "${FOREIGN_TREE}" ] FOREIGN_LOCATION="$(jq -r '.repositories.foreign_file.workspace_root[2]' "${CONFIG}")" +## Sanity check for git tree +TREE_FOUND="$(jq -r '.repositories.git_tree.workspace_root[1]' "${CONFIG}")" +[ "${TREE_FOUND}" = "${FOREIGN_GIT_TREE}" ] +GIT_TREE_LOCATION="$(jq -r '.repositories.git_tree.workspace_root[2]' "${CONFIG}")" + # Clean up original repositories rm -rf "${GIT_REPO}" rm -rf "${DISTDIR}" +rm -f "${BIN}/mock-foreign-vcs" # Fully clean the non-repo cache "${JUST}" gc --local-build-root "${LBR}" 2>&1 @@ -169,6 +205,7 @@ rm -rf "${DISTDIR}" [ -e "${GIT_LOCATION}" ] && exit 1 || : [ -e "${ARCHIVE_LOCATION}" ] && exit 1 || : [ -e "${FOREIGN_LOCATION}" ] && exit 1 || : +[ -e "${GIT_TREE_LOCATION}" ] && exit 1 || : # Setup repos again "${JUST_MR}" --local-build-root "${LBR}" \ @@ -191,4 +228,8 @@ TREE_FOUND="$(jq -r '.repositories.archive.workspace_root[1]' "${CONFIG}")" TREE_FOUND="$(jq -r '.repositories.foreign_file.workspace_root[1]' "${CONFIG}")" [ "${TREE_FOUND}" = "${FOREIGN_TREE}" ] +## Sanity check for git tree +TREE_FOUND="$(jq -r '.repositories.git_tree.workspace_root[1]' "${CONFIG}")" +[ "${TREE_FOUND}" = "${FOREIGN_GIT_TREE}" ] + echo OK |