summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--test/end-to-end/git-import/TARGETS12
-rw-r--r--test/end-to-end/git-import/absent.sh135
2 files changed, 146 insertions, 1 deletions
diff --git a/test/end-to-end/git-import/TARGETS b/test/end-to-end/git-import/TARGETS
index ce95b578..b8715443 100644
--- a/test/end-to-end/git-import/TARGETS
+++ b/test/end-to-end/git-import/TARGETS
@@ -38,6 +38,16 @@
]
, "keep": ["repos.json"]
}
+, "absent":
+ { "type": ["@", "rules", "shell/test", "script"]
+ , "name": ["absent"]
+ , "test": ["absent.sh"]
+ , "deps":
+ [ ["end-to-end", "git-import-under-test"]
+ , ["end-to-end", "deduplicate-tool-under-test"]
+ ]
+ , "keep": ["repos.json", "deduplicated.json"]
+ }
, "TESTS":
{ "type": "install"
, "arguments_config": ["TEST_BOOTSTRAP_JUST_MR"]
@@ -45,7 +55,7 @@
, "deps":
{ "type": "++"
, "$1":
- [ ["deduplicate"]
+ [ ["deduplicate", "absent"]
, { "type": "if"
, "cond": {"type": "var", "name": "TEST_BOOTSTRAP_JUST_MR"}
, "then": []
diff --git a/test/end-to-end/git-import/absent.sh b/test/end-to-end/git-import/absent.sh
new file mode 100644
index 00000000..0bd260b6
--- /dev/null
+++ b/test/end-to-end/git-import/absent.sh
@@ -0,0 +1,135 @@
+#!/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
+
+readonly GIT_IMPORT="${PWD}/bin/git-import-under-test"
+readonly DEDUPLICATE="${PWD}/bin/deduplicate-tool-under-test"
+readonly REPO_DIRS="${TEST_TMPDIR}/repos"
+readonly WRKDIR="${PWD}"
+
+mkdir -p "${REPO_DIRS}/foo/"
+cd "${REPO_DIRS}/foo"
+cat > repos.json <<'EOF'
+{ "repositories":
+ { "":
+ {"repository": {"type": "file", "path": "src"}, "bindings": {"bar": "bar"}}
+ , "bar":
+ { "repository":
+ { "type": "archive"
+ , "content": "4d86bdf4d07535db3754e6cbf30a6fc81aaa2cc1"
+ , "fetch": "https://example.org/v1.2.3"
+ }
+ }
+ }
+}
+EOF
+git init 2>&1
+git checkout --orphan foomaster 2>&1
+git config user.name 'N.O.Body' 2>&1
+git config user.email 'nobody@example.org' 2>&1
+git add . 2>&1
+git commit -m 'Add foo' 2>&1
+
+mkdir -p "${WRKDIR}"
+cd "${WRKDIR}"
+touch ROOT
+cat > repos.template.json <<'EOF'
+{ "repositories":
+ { "":
+ { "repository": {"type": "file", "path": "."}
+ , "bindings":
+ { "foo": "foo"
+ , "bar": "my/internal/bar/version"
+ , "file-foo": "file-foo"
+ , "file-bar": "file-bar"
+ }
+ }
+ , "my/internal/bar/version":
+ { "repository":
+ { "type": "archive"
+ , "content": "4d86bdf4d07535db3754e6cbf30a6fc81aaa2cc1"
+ , "fetch": "https://example.org/v1.2.3"
+ }
+ }
+ , "file-foo":
+ { "repository":
+ {"type": "file", "path": "third_party", "pragma": {"to_git": true}}
+ }
+ , "file-bar": {"repository": {"type": "file", "path": "third_party"}}
+ }
+}
+EOF
+
+echo
+echo Import
+echo
+
+"${GIT_IMPORT}" -C repos.template.json \
+ --absent \
+ --as foo -b foomaster \
+ --mirror http://primary.example.org/foo \
+ --inherit-env AUTH_VAR_FOO \
+ "${REPO_DIRS}/foo" \
+ > repos.json
+echo
+cat repos.json
+echo
+
+# Take repository foo
+jq '.repositories.foo' repos.json > foo.json
+# - repository should be absent
+[ $(jq '.repository.pragma.absent' foo.json) = "true" ]
+# - get repository name of binding "bar"
+BAR=$(jq '.bindings.bar' foo.json)
+echo "Name of binding bar of foo: $BAR"
+# - ... this repo should be absent as well
+jq '.repositories.'"$BAR" repos.json > bar.json
+cat bar.json
+[ $(jq '.repository.pragma.absent' bar.json) = "true" ]
+
+echo
+echo Deduplicate
+echo
+
+cat repos.json | "${DEDUPLICATE}" > deduplicated.json
+echo
+cat deduplicated.json
+echo
+# Both bar repos should be unified now
+FOO_BAR=$(jq '.repositories.foo.bindings.bar' deduplicated.json)
+echo "Bar repo of foo: ${FOO_BAR}"
+INTERNAL_BAR=$(jq '.repositories."".bindings.bar' deduplicated.json)
+echo "Internal bar repo: ${INTERNAL_BAR}"
+[ "${FOO_BAR}" = "${INTERNAL_BAR}" ]
+jq '.repositories.'"$FOO_BAR" deduplicated.json > bar.json
+cat bar.json
+# ... and the pargma empty, as the internal bar is part of the merge
+# and that repository cannot be absent.
+[ $(jq '.pragma?' bar.json) = "null" ]
+
+# Also, both file repositories should be unified
+FILE_FOO=$(jq '.repositories."".bindings."file-foo"' deduplicated.json)
+echo "file-foo of '' is now ${FILE_FOO}"
+FILE_BAR=$(jq '.repositories."".bindings."file-bar"' deduplicated.json)
+echo "file-bar of '' is now ${FILE_BAR}"
+[ "${FILE_FOO}" = "${FILE_BAR}" ]
+jq '.repositories.'"$FILE_FOO" deduplicated.json > local.json
+cat local.json
+# The to_git pragma should be preserved
+[ $(jq '.repository.pragma."to_git"' local.json) = "true" ]
+
+echo OK