summaryrefslogtreecommitdiff
path: root/tests/frontend
diff options
context:
space:
mode:
authorChandan Singh <chandan@chandansingh.net>2020-05-07 20:59:47 +0000
committerChandan Singh <chandan@chandansingh.net>2020-05-13 21:32:43 +0000
commit5018a61a1b423ca63cc7bc969a89a8802813a70b (patch)
tree9b099528a3e04e213d366a21942727e12e557bac /tests/frontend
parentf196019a47b27b7a686e3aa1a1e03530fef28ea2 (diff)
downloadbuildstream-5018a61a1b423ca63cc7bc969a89a8802813a70b.tar.gz
_frontend/cli: Support "build" and "run" values for `artifact push --deps`
Diffstat (limited to 'tests/frontend')
-rw-r--r--tests/frontend/push.py35
1 files changed, 23 insertions, 12 deletions
diff --git a/tests/frontend/push.py b/tests/frontend/push.py
index 970885784..26dd6cb4f 100644
--- a/tests/frontend/push.py
+++ b/tests/frontend/push.py
@@ -220,21 +220,31 @@ def test_push_fails_with_on_error_continue(cli, tmpdir, datafiles):
assert error in result.stderr
-# Tests that `bst artifact push --deps all` pushes all dependencies of the given element.
+# Tests that `bst artifact push --deps DEPS` pushes selected dependencies of
+# the given element.
#
@pytest.mark.datafiles(DATA_DIR)
-def test_push_all(cli, tmpdir, datafiles):
+@pytest.mark.parametrize(
+ "deps, expected_states",
+ [
+ ("build", [False, True, False]),
+ ("none", [True, False, False]),
+ ("run", [True, False, True]),
+ ("all", [True, True, True]),
+ ],
+)
+def test_push_deps(cli, tmpdir, datafiles, deps, expected_states):
project = str(datafiles)
+ target = "checkout-deps.bst"
+ build_dep = "import-dev.bst"
+ runtime_dep = "import-bin.bst"
with create_artifact_share(os.path.join(str(tmpdir), "artifactshare")) as share:
# First build it without the artifact cache configured
- result = cli.run(project=project, args=["build", "target.bst"])
+ result = cli.run(project=project, args=["build", target])
result.assert_success()
- # Assert that we are now cached locally
- assert cli.get_element_state(project, "target.bst") == "cached"
-
# Configure artifact share
cli.configure(
{
@@ -252,14 +262,15 @@ def test_push_all(cli, tmpdir, datafiles):
)
# Now try bst artifact push all the deps
- result = cli.run(project=project, args=["artifact", "push", "target.bst", "--deps", "all"])
+ result = cli.run(project=project, args=["artifact", "push", target, "--deps", deps])
result.assert_success()
- # And finally assert that all the artifacts are in the share
- assert_shared(cli, share, project, "target.bst")
- assert_shared(cli, share, project, "import-bin.bst")
- assert_shared(cli, share, project, "import-dev.bst")
- assert_shared(cli, share, project, "compose-all.bst")
+ # And finally assert that the selected artifacts are in the share
+ states = []
+ for element in (target, build_dep, runtime_dep):
+ is_cached = share.get_artifact(cli.get_artifact_name(project, "test", element)) is not None
+ states.append(is_cached)
+ assert states == expected_states
# Tests that `bst artifact push --deps run $artifact_ref` fails