summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDor Askayo <dor.askayo@gmail.com>2019-01-26 01:53:42 +0200
committerDor Askayo <dor.askayo@gmail.com>2019-01-29 21:03:06 +0200
commit41e91ab5ff635affe2977c78e15587c08475952b (patch)
treef4e30ea20294d657b3e64f475ed2923d26fb40b2
parenta2140d748ee4552034a0424b39c79ce6192695a8 (diff)
downloadbuildstream-doraskayo/filter-indirect-deps-fix.tar.gz
filter.py: don't recurse when staging dependenciesdoraskayo/filter-indirect-deps-fix
Also bump the element's version so cached artifacts would be invalidated. Fixes #883
-rw-r--r--buildstream/plugins/elements/filter.py4
-rw-r--r--tests/elements/filter.py20
-rw-r--r--tests/elements/filter/basic/elements/input-with-deps.bst14
-rw-r--r--tests/elements/filter/basic/elements/output-include-with-indirect-deps.bst5
4 files changed, 42 insertions, 1 deletions
diff --git a/buildstream/plugins/elements/filter.py b/buildstream/plugins/elements/filter.py
index 672325304..b2c292261 100644
--- a/buildstream/plugins/elements/filter.py
+++ b/buildstream/plugins/elements/filter.py
@@ -47,6 +47,8 @@ from buildstream import Element, ElementError, Scope
class FilterElement(Element):
# pylint: disable=attribute-defined-outside-init
+ BST_ARTIFACT_VERSION = 1
+
# The filter element's output is its dependencies, so
# we must rebuild if the dependencies change even when
# not in strict build plans.
@@ -102,7 +104,7 @@ class FilterElement(Element):
def assemble(self, sandbox):
with self.timed_activity("Staging artifact", silent_nested=True):
- for dep in self.dependencies(Scope.BUILD):
+ for dep in self.dependencies(Scope.BUILD, recurse=False):
dep.stage_artifact(sandbox, include=self.include,
exclude=self.exclude, orphans=self.include_orphans)
return ""
diff --git a/tests/elements/filter.py b/tests/elements/filter.py
index a63ef29e1..8ff642c64 100644
--- a/tests/elements/filter.py
+++ b/tests/elements/filter.py
@@ -464,3 +464,23 @@ def test_filter_track_multi_exclude(datafiles, cli, tmpdir):
assert "ref" not in new_input["sources"][0]
new_input2 = _yaml.load(input2_file)
assert new_input2["sources"][0]["ref"] == ref
+
+
+@pytest.mark.datafiles(os.path.join(DATA_DIR, 'basic'))
+def test_filter_include_with_indirect_deps(datafiles, cli, tmpdir):
+ project = os.path.join(datafiles.dirname, datafiles.basename)
+ result = cli.run(project=project, args=[
+ 'build', 'output-include-with-indirect-deps.bst'])
+ result.assert_success()
+
+ checkout = os.path.join(tmpdir.dirname, tmpdir.basename, 'checkout')
+ result = cli.run(project=project, args=[
+ 'artifact', 'checkout', 'output-include-with-indirect-deps.bst', '--directory', checkout])
+ result.assert_success()
+
+ # direct dependencies should be staged and filtered
+ assert os.path.exists(os.path.join(checkout, "baz"))
+
+ # indirect dependencies shouldn't be staged and filtered
+ assert not os.path.exists(os.path.join(checkout, "foo"))
+ assert not os.path.exists(os.path.join(checkout, "bar"))
diff --git a/tests/elements/filter/basic/elements/input-with-deps.bst b/tests/elements/filter/basic/elements/input-with-deps.bst
new file mode 100644
index 000000000..50aab573c
--- /dev/null
+++ b/tests/elements/filter/basic/elements/input-with-deps.bst
@@ -0,0 +1,14 @@
+kind: import
+
+depends:
+- filename: input.bst
+
+sources:
+- kind: local
+ path: files
+
+public:
+ bst:
+ split-rules:
+ baz:
+ - /baz
diff --git a/tests/elements/filter/basic/elements/output-include-with-indirect-deps.bst b/tests/elements/filter/basic/elements/output-include-with-indirect-deps.bst
new file mode 100644
index 000000000..8325853e2
--- /dev/null
+++ b/tests/elements/filter/basic/elements/output-include-with-indirect-deps.bst
@@ -0,0 +1,5 @@
+kind: filter
+
+depends:
+- filename: input-with-deps.bst
+ type: build