Index: tests/gclient_test.py |
=================================================================== |
--- tests/gclient_test.py (revision 132861) |
+++ tests/gclient_test.py (working copy) |
@@ -210,7 +210,7 @@ |
# auto-fixed. |
d = gclient.Dependency( |
None, 'name', 'proto://host/path/@revision', None, None, None, |
- None, '', True) |
+ None, '', None, True) |
self.assertEquals('proto://host/path@revision', d.url) |
def testStr(self): |
@@ -220,24 +220,24 @@ |
obj.add_dependencies_and_close( |
[ |
gclient.Dependency( |
- obj, 'foo', 'url', None, None, None, None, 'DEPS', True), |
+ obj, 'foo', 'url', None, None, None, None, 'DEPS', None, True), |
gclient.Dependency( |
- obj, 'bar', 'url', None, None, None, None, 'DEPS', True), |
+ obj, 'bar', 'url', None, None, None, None, 'DEPS', None, True), |
], |
[]) |
obj.dependencies[0].add_dependencies_and_close( |
[ |
gclient.Dependency( |
obj.dependencies[0], 'foo/dir1', 'url', None, None, None, None, |
- 'DEPS', True), |
+ 'DEPS', None, True), |
gclient.Dependency( |
obj.dependencies[0], 'foo/dir2', |
gclient.GClientKeywords.FromImpl('bar'), None, None, None, None, |
- 'DEPS', True), |
+ 'DEPS', None, True), |
gclient.Dependency( |
obj.dependencies[0], 'foo/dir3', |
gclient.GClientKeywords.FileImpl('url'), None, None, None, None, |
- 'DEPS', True), |
+ 'DEPS', None, True), |
], |
[]) |
# Make sure __str__() works fine. |
@@ -276,7 +276,42 @@ |
work_queue.flush({}, None, [], options=options) |
self.assertEqual(client.GetHooks(options), [x['action'] for x in hooks]) |
+ def testTargetOS(self): |
+ """Verifies that specifying a target_os pulls in all relevant dependencies. |
+ The target_os variable allows specifying the name of an additional OS which |
+ should be considered when selecting dependencies from a DEPS' deps_os. The |
+ value will be appended to the enforced_os tuple. |
+ """ |
+ |
+ write( |
+ '.gclient', |
+ 'solutions = [\n' |
John Grabowski
2012/04/19 05:29:04
"""
for multi-line strings in python,
prefer tripl
Peter Beverloo
2012/04/19 06:11:03
Only following the file's convention :-). I have u
|
+ ' { "name": "foo",\n' |
+ ' "url": "svn://example.com/foo",\n' |
+ ' "target_os": "baz",\n' |
+ ' }\n' |
+ ']') |
+ write( |
+ os.path.join('foo', 'DEPS'), |
+ 'deps = {\n' |
+ ' "foo/dir1": "/dir1",' |
+ '}\n' |
+ 'deps_os = {\n' |
+ ' "unix": { "foo/dir2": "/dir2", },\n' |
+ ' "baz": { "foo/dir3": "/dir3", },\n' |
+ '}') |
+ |
+ parser = gclient.Parser() |
+ options, args = parser.parse_args(['--jobs', '1']) |
+ options.deps_os = "unix" |
+ |
+ obj = gclient.GClient.LoadCurrentConfig(options) |
+ obj.RunOnDeps('None', args) |
+ |
+ self.assertEqual(4, len(self._get_processed())) |
John Grabowski
2012/04/19 05:29:04
I don't understand this. 1 dep, plus 1 for unix,
Peter Beverloo
2012/04/19 06:11:03
svn://example.com/foo is also being processed (top
|
+ |
+ |
if __name__ == '__main__': |
sys.stdout = gclient_utils.MakeFileAutoFlush(sys.stdout) |
sys.stdout = gclient_utils.MakeFileAnnotated(sys.stdout, include_zero=True) |