1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
#
# 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 pytest
from buildstream.testing.runcli import cli # pylint: disable=unused-import
from buildstream import _yaml
DATA_DIR = os.path.join(os.path.dirname(os.path.realpath(__file__)), "project")
@pytest.mark.datafiles(DATA_DIR)
def test_patch_sources_cached_1(cli, datafiles):
project_dir = str(datafiles)
res = cli.run(project=project_dir, args=["build", "source-with-patches-1.bst"])
res.assert_success()
# as we have a local, patch, local config, the first local and patch should
# be cached together, and the last local on it's own
source_protos = os.path.join(project_dir, 'cache', 'source_protos')
assert len(os.listdir(os.path.join(source_protos, 'patch'))) == 1
assert len(os.listdir(os.path.join(source_protos, 'local'))) == 2
@pytest.mark.datafiles(DATA_DIR)
def test_patch_sources_cached_2(cli, datafiles):
project_dir = str(datafiles)
res = cli.run(project=project_dir, args=["build", "source-with-patches-2.bst"])
res.assert_success()
# As everything is before the patch it should all be cached together
source_protos = os.path.join(project_dir, 'cache', 'source_protos')
assert len(os.listdir(os.path.join(source_protos, 'patch'))) == 1
@pytest.mark.datafiles(DATA_DIR)
def test_sources_without_patch(cli, datafiles):
project_dir = str(datafiles)
res = cli.run(project=project_dir, args=["build", "source-without-patches.bst"])
res.assert_success()
# No patches so everything should be cached seperately
source_protos = os.path.join(project_dir, 'cache', 'source_protos')
assert len(os.listdir(os.path.join(source_protos, 'local'))) == 3
@pytest.mark.datafiles(DATA_DIR)
def test_source_cache_key(cli, datafiles):
project_dir = str(datafiles)
file_path = os.path.join(project_dir, 'files')
file_url = 'file://' + file_path
element_path = os.path.join(project_dir, 'elements')
element_name = 'key_check.bst'
element = {
'kind': 'import',
'sources': [
{
'kind': 'remote',
'url': os.path.join(file_url, 'bin-files', 'usr', 'bin', 'hello'),
'directory': 'usr/bin'
}, {
'kind': 'remote',
'url': os.path.join(file_url, 'dev-files', 'usr', 'include', 'pony.h'),
'directory': 'usr/include'
}, {
'kind': 'patch',
'path': 'files/hello-patch.diff'
}
]
}
_yaml.dump(element, os.path.join(element_path, element_name))
res = cli.run(project=project_dir, args=["source", "track", element_name])
res.assert_success()
res = cli.run(project=project_dir, args=["build", element_name])
res.assert_success()
# Should have one source ref
patch_protos = os.path.join(project_dir, 'cache', 'source_protos', 'patch')
assert len(os.listdir(patch_protos)) == 1
# modify hello-patch file and check tracking updates refs
with open(os.path.join(file_path, 'dev-files', 'usr', 'include', 'pony.h'), 'a') as f:
f.write("\nappending nonsense")
res = cli.run(project=project_dir, args=["source", "track", element_name])
res.assert_success()
assert "Found new revision: " in res.stderr
res = cli.run(project=project_dir, args=["source", "fetch", element_name])
res.assert_success()
# We should have a new source ref
assert len(os.listdir(patch_protos)) == 2
|