summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonathan Maw <jonathan.maw@codethink.co.uk>2018-02-27 13:11:44 +0000
committerJonathan Maw <jonathan.maw@codethink.co.uk>2018-03-01 13:28:44 +0000
commitb29615032ecf116879291bd97a805cec012bc476 (patch)
tree7e080c4512df80790cd784ade12bf945dfdc775a
parent63069e9da45ffe611d8a6ba691f77db555f8f6bd (diff)
downloadbuildstream-214-we-need-a-way-to-make-elements-depend-on-a-subset-of-an-element-s-output.tar.gz
-rw-r--r--tests/plugins/filter.py87
-rw-r--r--tests/plugins/filter/basic/elements/deps-permitted.bst11
-rw-r--r--tests/plugins/filter/basic/elements/forbidden-also-rdep.bst8
-rw-r--r--tests/plugins/filter/basic/elements/forbidden-multi-bdep.bst8
-rw-r--r--tests/plugins/filter/basic/elements/forbidden-no-bdep.bst8
-rw-r--r--tests/plugins/filter/basic/elements/forbidden-source.bst10
-rw-r--r--tests/plugins/filter/basic/elements/input.bst11
-rw-r--r--tests/plugins/filter/basic/elements/output-exclude.bst7
-rw-r--r--tests/plugins/filter/basic/elements/output-include.bst7
-rw-r--r--tests/plugins/filter/basic/elements/output-orphans.bst9
-rw-r--r--tests/plugins/filter/basic/files/bar0
-rw-r--r--tests/plugins/filter/basic/files/baz0
-rw-r--r--tests/plugins/filter/basic/files/foo0
-rw-r--r--tests/plugins/filter/basic/project.conf2
14 files changed, 168 insertions, 0 deletions
diff --git a/tests/plugins/filter.py b/tests/plugins/filter.py
new file mode 100644
index 000000000..a8e7257c3
--- /dev/null
+++ b/tests/plugins/filter.py
@@ -0,0 +1,87 @@
+import os
+import pytest
+from tests.testutils.runcli import cli
+from buildstream._exceptions import ErrorDomain
+
+DATA_DIR = os.path.join(
+ os.path.dirname(os.path.realpath(__file__)),
+ 'filter',
+)
+
+
+@pytest.mark.datafiles(os.path.join(DATA_DIR, 'basic'))
+def test_filter_include(datafiles, cli, tmpdir):
+ project = os.path.join(datafiles.dirname, datafiles.basename)
+ result = cli.run(project=project, args=['build', 'output-include.bst'])
+ result.assert_success()
+
+ checkout = os.path.join(tmpdir.dirname, tmpdir.basename, 'checkout')
+ result = cli.run(project=project, args=['checkout', 'output-include.bst', checkout])
+ result.assert_success()
+ assert os.path.exists(os.path.join(checkout, "foo"))
+
+
+@pytest.mark.datafiles(os.path.join(DATA_DIR, 'basic'))
+def test_filter_exclude(datafiles, cli, tmpdir):
+ project = os.path.join(datafiles.dirname, datafiles.basename)
+ result = cli.run(project=project, args=['build', 'output-exclude.bst'])
+ result.assert_success()
+
+ checkout = os.path.join(tmpdir.dirname, tmpdir.basename, 'checkout')
+ result = cli.run(project=project, args=['checkout', 'output-exclude.bst', checkout])
+ result.assert_success()
+ assert os.path.exists(os.path.join(checkout, "bar"))
+
+
+@pytest.mark.datafiles(os.path.join(DATA_DIR, 'basic'))
+def test_filter_orphans(datafiles, cli, tmpdir):
+ project = os.path.join(datafiles.dirname, datafiles.basename)
+ result = cli.run(project=project, args=['build', 'output-orphans.bst'])
+ result.assert_success()
+
+ checkout = os.path.join(tmpdir.dirname, tmpdir.basename, 'checkout')
+ result = cli.run(project=project, args=['checkout', 'output-orphans.bst', checkout])
+ result.assert_success()
+ assert os.path.exists(os.path.join(checkout, "baz"))
+
+
+@pytest.mark.datafiles(os.path.join(DATA_DIR, 'basic'))
+def test_filter_deps_ok(datafiles, cli):
+ project = os.path.join(datafiles.dirname, datafiles.basename)
+ result = cli.run(project=project, args=['build', 'deps-permitted.bst'])
+ result.assert_success()
+
+ result = cli.run(project=project,
+ args=['show', '--deps=run', "--format='%{name}'", 'deps-permitted.bst'])
+ result.assert_success()
+
+ assert 'output-exclude.bst' in result.output
+ assert 'output-orphans.bst' in result.output
+
+
+@pytest.mark.datafiles(os.path.join(DATA_DIR, 'basic'))
+def test_filter_forbid_sources(datafiles, cli):
+ project = os.path.join(datafiles.dirname, datafiles.basename)
+ result = cli.run(project=project, args=['build', 'forbidden-source.bst'])
+ result.assert_main_error(ErrorDomain.PIPELINE, 'element-forbidden-sources')
+
+
+@pytest.mark.datafiles(os.path.join(DATA_DIR, 'basic'))
+def test_filter_forbid_multi_bdep(datafiles, cli):
+ project = os.path.join(datafiles.dirname, datafiles.basename)
+ result = cli.run(project=project, args=['build', 'forbidden-multi-bdep.bst'])
+ result.assert_main_error(ErrorDomain.PIPELINE, 'filter-bdepend-wrong-count')
+
+
+@pytest.mark.datafiles(os.path.join(DATA_DIR, 'basic'))
+def test_filter_forbid_no_bdep(datafiles, cli):
+ project = os.path.join(datafiles.dirname, datafiles.basename)
+ result = cli.run(project=project, args=['build', 'forbidden-no-bdep.bst'])
+ result.assert_main_error(ErrorDomain.PIPELINE, 'filter-bdepend-wrong-count')
+
+
+@pytest.mark.datafiles(os.path.join(DATA_DIR, 'basic'))
+def test_filter_forbid_also_rdep(datafiles, cli):
+ project = os.path.join(datafiles.dirname, datafiles.basename)
+ result = cli.run(project=project, args=['build', 'forbidden-also-rdep.bst'])
+ result.assert_main_error(ErrorDomain.PIPELINE, 'filter-bdepend-also-rdepend')
diff --git a/tests/plugins/filter/basic/elements/deps-permitted.bst b/tests/plugins/filter/basic/elements/deps-permitted.bst
new file mode 100644
index 000000000..00883b1f8
--- /dev/null
+++ b/tests/plugins/filter/basic/elements/deps-permitted.bst
@@ -0,0 +1,11 @@
+kind: filter
+depends:
+- filename: output-include.bst
+ type: build
+- filename: output-exclude.bst
+ type: runtime
+- filename: output-orphans.bst
+ type: runtime
+config:
+ include:
+ - foo
diff --git a/tests/plugins/filter/basic/elements/forbidden-also-rdep.bst b/tests/plugins/filter/basic/elements/forbidden-also-rdep.bst
new file mode 100644
index 000000000..aa996a649
--- /dev/null
+++ b/tests/plugins/filter/basic/elements/forbidden-also-rdep.bst
@@ -0,0 +1,8 @@
+kind: filter
+depends:
+- filename: output-include.bst
+ type: all
+- filename: output-exclude.bst
+ type: runtime
+- filename: output-orphans.bst
+ type: runtime
diff --git a/tests/plugins/filter/basic/elements/forbidden-multi-bdep.bst b/tests/plugins/filter/basic/elements/forbidden-multi-bdep.bst
new file mode 100644
index 000000000..2d5d0a2ca
--- /dev/null
+++ b/tests/plugins/filter/basic/elements/forbidden-multi-bdep.bst
@@ -0,0 +1,8 @@
+kind: filter
+depends:
+- filename: output-include.bst
+ type: build
+- filename: output-exclude.bst
+ type: build
+- filename: output-orphans.bst
+ type: runtime
diff --git a/tests/plugins/filter/basic/elements/forbidden-no-bdep.bst b/tests/plugins/filter/basic/elements/forbidden-no-bdep.bst
new file mode 100644
index 000000000..a7d405458
--- /dev/null
+++ b/tests/plugins/filter/basic/elements/forbidden-no-bdep.bst
@@ -0,0 +1,8 @@
+kind: filter
+depends:
+- filename: output-include.bst
+ type: runtime
+- filename: output-exclude.bst
+ type: runtime
+- filename: output-orphans.bst
+ type: runtime
diff --git a/tests/plugins/filter/basic/elements/forbidden-source.bst b/tests/plugins/filter/basic/elements/forbidden-source.bst
new file mode 100644
index 000000000..d9eb07921
--- /dev/null
+++ b/tests/plugins/filter/basic/elements/forbidden-source.bst
@@ -0,0 +1,10 @@
+kind: filter
+depends:
+- filename: output-include.bst
+ type: build
+config:
+ include:
+ - foo
+sources:
+- kind: local
+ path: files
diff --git a/tests/plugins/filter/basic/elements/input.bst b/tests/plugins/filter/basic/elements/input.bst
new file mode 100644
index 000000000..fb3f5d194
--- /dev/null
+++ b/tests/plugins/filter/basic/elements/input.bst
@@ -0,0 +1,11 @@
+kind: import
+sources:
+- kind: local
+ path: files
+public:
+ bst:
+ split-rules:
+ foo:
+ - /foo
+ bar:
+ - /bar
diff --git a/tests/plugins/filter/basic/elements/output-exclude.bst b/tests/plugins/filter/basic/elements/output-exclude.bst
new file mode 100644
index 000000000..c1ec17a45
--- /dev/null
+++ b/tests/plugins/filter/basic/elements/output-exclude.bst
@@ -0,0 +1,7 @@
+kind: filter
+depends:
+- filename: input.bst
+ type: build
+config:
+ exclude:
+ - foo
diff --git a/tests/plugins/filter/basic/elements/output-include.bst b/tests/plugins/filter/basic/elements/output-include.bst
new file mode 100644
index 000000000..c05cbdb83
--- /dev/null
+++ b/tests/plugins/filter/basic/elements/output-include.bst
@@ -0,0 +1,7 @@
+kind: filter
+depends:
+- filename: input.bst
+ type: build
+config:
+ include:
+ - foo
diff --git a/tests/plugins/filter/basic/elements/output-orphans.bst b/tests/plugins/filter/basic/elements/output-orphans.bst
new file mode 100644
index 000000000..e682fca7a
--- /dev/null
+++ b/tests/plugins/filter/basic/elements/output-orphans.bst
@@ -0,0 +1,9 @@
+kind: filter
+depends:
+- filename: input.bst
+ type: build
+config:
+ exclude:
+ - foo
+ - bar
+ include-orphans: True
diff --git a/tests/plugins/filter/basic/files/bar b/tests/plugins/filter/basic/files/bar
new file mode 100644
index 000000000..e69de29bb
--- /dev/null
+++ b/tests/plugins/filter/basic/files/bar
diff --git a/tests/plugins/filter/basic/files/baz b/tests/plugins/filter/basic/files/baz
new file mode 100644
index 000000000..e69de29bb
--- /dev/null
+++ b/tests/plugins/filter/basic/files/baz
diff --git a/tests/plugins/filter/basic/files/foo b/tests/plugins/filter/basic/files/foo
new file mode 100644
index 000000000..e69de29bb
--- /dev/null
+++ b/tests/plugins/filter/basic/files/foo
diff --git a/tests/plugins/filter/basic/project.conf b/tests/plugins/filter/basic/project.conf
new file mode 100644
index 000000000..627522526
--- /dev/null
+++ b/tests/plugins/filter/basic/project.conf
@@ -0,0 +1,2 @@
+name: test
+element-path: elements