summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRaoul Hidalgo Charman <raoul.hidalgocharman@codethink.co.uk>2019-03-05 17:32:48 +0000
committerRaoul Hidalgo Charman <raoul.hidalgocharman@codethink.co.uk>2019-03-22 16:00:37 +0000
commiteb9446fdb4e1d6dfabb1722b4a80c0c5a0e1e94b (patch)
treec3e381a29e0ab3a61981a783b057678fc9ded5b7
parentcffe7aa720bf794a9eb681c6dcdd0930542b5cdc (diff)
downloadbuildstream-eb9446fdb4e1d6dfabb1722b4a80c0c5a0e1e94b.tar.gz
tests: Add source cache fetch test
Part of #440
-rw-r--r--tests/sourcecache/fetch.py111
1 files changed, 111 insertions, 0 deletions
diff --git a/tests/sourcecache/fetch.py b/tests/sourcecache/fetch.py
new file mode 100644
index 000000000..9043430c8
--- /dev/null
+++ b/tests/sourcecache/fetch.py
@@ -0,0 +1,111 @@
+#
+# Copyright (C) 2019 Bloomberg Finance LP
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library. If not, see <http://www.gnu.org/licenses/>.
+#
+# Authors:
+# Raoul Hidalgo Charman <raoul.hidalgocharman@codethink.co.uk>
+#
+# Pylint doesn't play well with fixtures and dependency injection from pytest
+# pylint: disable=redefined-outer-name
+import os
+import shutil
+import pytest
+
+from buildstream._context import Context
+from buildstream._project import Project
+from buildstream import _yaml
+from buildstream.plugintestutils import cli # pylint: disable=unused-import
+
+from tests.testutils import create_artifact_share, create_repo
+
+DATA_DIR = os.path.join(os.path.dirname(os.path.realpath(__file__)), "project")
+
+
+def message_handler(message, context):
+ pass
+
+
+@pytest.mark.datafiles(DATA_DIR)
+def test_source_fetch(cli, tmpdir, datafiles):
+ project_dir = str(datafiles)
+
+ # use artifact cache for sources for now, they should work the same
+ with create_artifact_share(os.path.join(str(tmpdir), 'sourceshare')) as share:
+ # configure using this share
+ cache_dir = os.path.join(str(tmpdir), 'cache')
+ user_config_file = str(tmpdir.join('buildstream.conf'))
+ user_config = {
+ 'scheduler': {
+ 'pushers': 1
+ },
+ 'source-caches': {
+ 'url': share.repo,
+ },
+ 'cachedir': cache_dir,
+ }
+ _yaml.dump(_yaml.node_sanitize(user_config), filename=user_config_file)
+ cli.configure(user_config)
+
+ repo = create_repo('git', str(tmpdir))
+ ref = repo.create(os.path.join(project_dir, 'files'))
+ element_path = os.path.join(project_dir, 'elements')
+ element_name = 'fetch.bst'
+ element = {
+ 'kind': 'import',
+ 'sources': [repo.source_config(ref=ref)]
+ }
+ _yaml.dump(element, os.path.join(element_path, element_name))
+
+ context = Context()
+ context.load(config=user_config_file)
+ context.set_message_handler(message_handler)
+
+ project = Project(project_dir, context)
+ project.ensure_fully_loaded()
+
+ element = project.load_elements(['fetch.bst'])[0]
+ assert not element._source_cached()
+ source = list(element.sources())[0]
+
+ cas = context.get_cascache()
+ assert not cas.contains(source._get_source_name())
+
+ # Just check that we sensibly fetch and build the element
+ res = cli.run(project=project_dir, args=['build', 'fetch.bst'])
+ res.assert_success()
+
+ assert os.listdir(os.path.join(str(tmpdir), 'cache', 'sources', 'git')) != []
+
+ # Move source in local cas to repo
+ shutil.rmtree(os.path.join(str(tmpdir), 'sourceshare', 'repo', 'cas'))
+ shutil.move(
+ os.path.join(str(tmpdir), 'cache', 'cas'),
+ os.path.join(str(tmpdir), 'sourceshare', 'repo'))
+ shutil.rmtree(os.path.join(str(tmpdir), 'cache', 'sources'))
+
+ digest = share.cas.resolve_ref(source._get_source_name())
+ assert share.has_object(digest)
+
+ state = cli.get_element_state(project_dir, 'fetch.bst')
+ assert state == 'fetch needed'
+
+ # Now fetch the source and check
+ res = cli.run(project=project_dir, args=['source', 'fetch', 'fetch.bst'])
+ res.assert_success()
+ assert "Pulled source" in res.stderr
+
+ # check that we have the source in the cas now and it's not fetched
+ assert element._source_cached()
+ assert os.listdir(os.path.join(str(tmpdir), 'cache', 'sources', 'git')) == []