diff options
author | Jürg Billeter <j@bitron.ch> | 2018-01-23 16:14:04 +0000 |
---|---|---|
committer | Jürg Billeter <j@bitron.ch> | 2018-01-23 16:18:39 +0000 |
commit | 043d56a62b9e5c71a2b9fac265f7a8a4a437f118 (patch) | |
tree | 0ec31164794bc89a42f02d27d2341165d79e4afd | |
parent | 88187f12568c48b2fb6efeee1fc17914ae53f03e (diff) | |
download | buildstream-043d56a62b9e5c71a2b9fac265f7a8a4a437f118.tar.gz |
tests/frontend/pull.py: Add track+pull test for non-strict build plan
-rw-r--r-- | tests/frontend/pull.py | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/tests/frontend/pull.py b/tests/frontend/pull.py index d101ca891..94f4fe3e7 100644 --- a/tests/frontend/pull.py +++ b/tests/frontend/pull.py @@ -205,3 +205,47 @@ def test_push_pull_non_strict(cli, tmpdir, datafiles): # And assert that the target is again in the local cache, without having built assert cli.get_element_state(project, 'target.bst') == 'cached' + + +@pytest.mark.skipif(not IS_LINUX, reason='Only available on linux') +@pytest.mark.datafiles(DATA_DIR) +def test_push_pull_track_non_strict(cli, tmpdir, datafiles): + project = os.path.join(datafiles.dirname, datafiles.basename) + share = create_artifact_share(os.path.join(str(tmpdir), 'artifactshare')) + + # First build the target element and push to the remote. + cli.configure({ + 'artifacts': {'url': share.repo, 'push': True}, + 'projects': { + 'test': {'strict': False} + } + }) + result = cli.run(project=project, args=['build', 'target.bst']) + result.assert_success() + assert cli.get_element_state(project, 'target.bst') == 'cached' + + # Assert that everything is now cached in the remote. + share.update_summary() + all_elements = ['target.bst', 'import-bin.bst', 'import-dev.bst', 'compose-all.bst'] + for element_name in all_elements: + assert_shared(cli, share, project, element_name) + + # Now we've pushed, delete the user's local artifact cache + # directory and try to redownload it from the share + # + artifacts = os.path.join(cli.directory, 'artifacts') + shutil.rmtree(artifacts) + + # Assert that we are now in a downloadable state, nothing + # is cached locally anymore + for element_name in all_elements: + assert cli.get_element_state(project, element_name) == 'downloadable' + + # Now try bst build with tracking and pulling. + # Tracking will be skipped for target.bst as it doesn't have any sources. + # With the non-strict build plan target.bst immediately enters the pull queue. + # However, pulling has to be deferred until the dependencies have been + # tracked as the strict cache key needs to be calculated before querying + # the caches. + result = cli.run(project=project, args=['build', '--track-all', 'target.bst']) + result.assert_success() |