Commit d34a4fd1 authored by Tristan Van Berkom's avatar Tristan Van Berkom

Merge branch 'tristan/organizing-tests' into 'master'

General refactor in tests directory

See merge request !1062
parents 5e9598c5 3bf40cf3
Pipeline #43655189 failed with stages
in 28 minutes and 41 seconds
import os
import pytest
from buildstream._exceptions import ErrorDomain, LoadErrorReason
from tests.testutils import cli
DATA_DIR = os.path.dirname(os.path.realpath(__file__))
#
# Exercising some different ways of loading the dependencies
#
@pytest.mark.datafiles(DATA_DIR)
def test_two_files(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
elements = cli.get_pipeline(project, ['target.bst'])
assert elements == ['firstdep.bst', 'target.bst']
@pytest.mark.datafiles(DATA_DIR)
def test_shared_dependency(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
elements = cli.get_pipeline(project, ['shareddeptarget.bst'])
assert elements == ['firstdep.bst', 'shareddep.bst', 'shareddeptarget.bst']
@pytest.mark.datafiles(DATA_DIR)
def test_dependency_dict(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
elements = cli.get_pipeline(project, ['target-depdict.bst'])
assert elements == ['firstdep.bst', 'target-depdict.bst']
@pytest.mark.datafiles(DATA_DIR)
def test_invalid_dependency_declaration(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
result = cli.run(project=project, args=['show', 'invaliddep.bst'])
result.assert_main_error(ErrorDomain.LOAD, LoadErrorReason.INVALID_DATA)
@pytest.mark.datafiles(DATA_DIR)
def test_invalid_dependency_type(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
result = cli.run(project=project, args=['show', 'invaliddeptype.bst'])
result.assert_main_error(ErrorDomain.LOAD, LoadErrorReason.INVALID_DATA)
@pytest.mark.datafiles(DATA_DIR)
def test_circular_dependency(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
result = cli.run(project=project, args=['show', 'circulartarget.bst'])
result.assert_main_error(ErrorDomain.LOAD, LoadErrorReason.CIRCULAR_DEPENDENCY)
@pytest.mark.datafiles(DATA_DIR)
def test_build_dependency(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
elements = cli.get_pipeline(project, ['builddep.bst'], scope='run')
assert elements == ['builddep.bst']
elements = cli.get_pipeline(project, ['builddep.bst'], scope='build')
assert elements == ['firstdep.bst']
@pytest.mark.datafiles(DATA_DIR)
def test_runtime_dependency(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
elements = cli.get_pipeline(project, ['runtimedep.bst'], scope='build')
# FIXME: The empty line should probably never happen here when there are no results.
assert elements == ['']
elements = cli.get_pipeline(project, ['runtimedep.bst'], scope='run')
assert elements == ['firstdep.bst', 'runtimedep.bst']
@pytest.mark.datafiles(DATA_DIR)
def test_all_dependency(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
elements = cli.get_pipeline(project, ['alldep.bst'], scope='build')
assert elements == ['firstdep.bst']
elements = cli.get_pipeline(project, ['alldep.bst'], scope='run')
assert elements == ['firstdep.bst', 'alldep.bst']
@pytest.mark.datafiles(DATA_DIR)
def test_list_build_dependency(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
# Check that the pipeline includes the build dependency
deps = cli.get_pipeline(project, ['builddep-list.bst'], scope="build")
assert "firstdep.bst" in deps
@pytest.mark.datafiles(DATA_DIR)
def test_list_runtime_dependency(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
# Check that the pipeline includes the runtime dependency
deps = cli.get_pipeline(project, ['runtimedep-list.bst'], scope="run")
assert "firstdep.bst" in deps
@pytest.mark.datafiles(DATA_DIR)
def test_list_dependencies_combined(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
# Check that runtime deps get combined
rundeps = cli.get_pipeline(project, ['list-combine.bst'], scope="run")
assert "firstdep.bst" not in rundeps
assert "seconddep.bst" in rundeps
assert "thirddep.bst" in rundeps
# Check that build deps get combined
builddeps = cli.get_pipeline(project, ['list-combine.bst'], scope="build")
assert "firstdep.bst" in builddeps
assert "seconddep.bst" not in builddeps
assert "thirddep.bst" in builddeps
@pytest.mark.datafiles(DATA_DIR)
def test_list_overlap(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies1')
# Check that dependencies get merged
rundeps = cli.get_pipeline(project, ['list-overlap.bst'], scope="run")
assert "firstdep.bst" in rundeps
builddeps = cli.get_pipeline(project, ['list-overlap.bst'], scope="build")
assert "firstdep.bst" in builddeps
#
# Testing the order of elements reported when iterating through
# Element.dependencies() with various scopes.
#
@pytest.mark.datafiles(DATA_DIR)
def test_scope_all(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies2')
elements = ['target.bst']
element_list = cli.get_pipeline(project, elements, scope='all')
assert(len(element_list) == 7)
assert(element_list[0] == "build-build.bst")
assert(element_list[1] == "run-build.bst")
assert(element_list[2] == "build.bst")
assert(element_list[3] == "dep-one.bst")
assert(element_list[4] == "run.bst")
assert(element_list[5] == "dep-two.bst")
assert(element_list[6] == "target.bst")
@pytest.mark.datafiles(DATA_DIR)
def test_scope_run(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies2')
elements = ['target.bst']
element_list = cli.get_pipeline(project, elements, scope='run')
assert(len(element_list) == 4)
assert(element_list[0] == "dep-one.bst")
assert(element_list[1] == "run.bst")
assert(element_list[2] == "dep-two.bst")
assert(element_list[3] == "target.bst")
@pytest.mark.datafiles(DATA_DIR)
def test_scope_build(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies2')
elements = ['target.bst']
element_list = cli.get_pipeline(project, elements, scope='build')
assert(len(element_list) == 3)
assert(element_list[0] == "dep-one.bst")
assert(element_list[1] == "run.bst")
assert(element_list[2] == "dep-two.bst")
@pytest.mark.datafiles(DATA_DIR)
def test_scope_build_of_child(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies2')
elements = ['target.bst']
element_list = cli.get_pipeline(project, elements, scope='build')
# First pass, lets check dep-two
element = element_list[2]
# Pass two, let's look at these
element_list = cli.get_pipeline(project, [element], scope='build')
assert(len(element_list) == 2)
assert(element_list[0] == "run-build.bst")
assert(element_list[1] == "build.bst")
@pytest.mark.datafiles(DATA_DIR)
def test_no_recurse(cli, datafiles):
project = os.path.join(str(datafiles), 'dependencies2')
elements = ['target.bst']
# We abuse the 'plan' scope here to ensure that we call
# element.dependencies() with recurse=False - currently, no `bst
# show` option does this directly.
element_list = cli.get_pipeline(project, elements, scope='plan')
assert(len(element_list) == 7)
assert(element_list[0] == 'build-build.bst')
assert(element_list[1] in ['build.bst', 'run-build.bst'])
assert(element_list[2] in ['build.bst', 'run-build.bst'])
assert(element_list[3] in ['dep-one.bst', 'run.bst', 'dep-two.bst'])
assert(element_list[4] in ['dep-one.bst', 'run.bst', 'dep-two.bst'])
assert(element_list[5] in ['dep-one.bst', 'run.bst', 'dep-two.bst'])
assert(element_list[6] == 'target.bst')
kind: pony
kind: manual
description: This element has a dependency with type 'all'
depends:
- filename: elements/firstdep.bst
- filename: firstdep.bst
type: all
kind: stack
description: This element has a build-only dependency specified via build-depends
build-depends:
- elements/firstdep.bst
- firstdep.bst
kind: pony
kind: manual
description: This element has a build-only dependency
depends:
- filename: elements/firstdep.bst
- filename: firstdep.bst
type: build
kind: pony
kind: manual
description: Depend on another dep which depends on the target
depends:
- elements/circular-seconddep.bst
- circular-seconddep.bst
kind: pony
kind: manual
description: Depend on the target, creating a circular dependency
depends:
- elements/circulartarget.bst
- circulartarget.bst
kind: pony
kind: stack
description: This is a main target which introduces a circular dependency
depends:
- elements/circular-firstdep.bst
- circular-firstdep.bst
kind: pony
kind: manual
description: This is an invalid dependency type
depends:
- filename: elements/firstdep.bst
- filename: firstdep.bst
type: should be build or runtime
kind: stack
description: This element depends on three elements in different ways
build-depends:
- elements/firstdep.bst
- firstdep.bst
runtime-depends:
- elements/seconddep.bst
- seconddep.bst
depends:
- elements/thirddep.bst
- thirddep.bst
kind: stack
description: This element depends on two elements in different ways
build-depends:
- elements/firstdep.bst
- firstdep.bst
depends:
- filename: elements/firstdep.bst
- filename: firstdep.bst
type: runtime
kind: stack
description: This element has a runtime-only dependency
runtime-depends:
- elements/firstdep.bst
- firstdep.bst
kind: pony
kind: manual
description: This element has a runtime-only dependency
depends:
- filename: elements/firstdep.bst
- filename: firstdep.bst
type: runtime
kind: shareddep
kind: stack
description: This is the first dependency
depends:
- elements/firstdep.bst
- firstdep.bst
kind: pony
kind: stack
description: This is the main target
depends:
- elements/firstdep.bst
- elements/shareddep.bst
- firstdep.bst
- shareddep.bst
kind: pony
kind: manual
description: This is the main target
depends:
- filename: elements/firstdep.bst
- filename: firstdep.bst
kind: pony
kind: stack
description: This is the main target
depends:
- elements/firstdep.bst
- firstdep.bst
This diff is collapsed.
This diff is collapsed.