Index: tests/gclient_test.py |
diff --git a/tests/gclient_test.py b/tests/gclient_test.py |
index 801f784f1de4edac0db049d2aaf25d29c4e6ec7c..b59ec65e07a09b3cbc8ab595826a4483e8e9bb75 100755 |
--- a/tests/gclient_test.py |
+++ b/tests/gclient_test.py |
@@ -307,6 +307,41 @@ class GclientTest(trial_dir.TestCase): |
obj = gclient.GClient.LoadCurrentConfig(options) |
self.assertEqual(['baz', 'unix'], sorted(obj.enforced_os)) |
+ def testTargetOsInDepsFile(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' |
+ ' { "name": "foo",\n' |
+ ' "url": "svn://example.com/foo",\n' |
+ ' }]\n') |
+ write( |
+ os.path.join('foo', 'DEPS'), |
+ 'deps = {\n' |
+ ' "foo/dir1": "/dir1",' |
+ '}\n' |
+ 'target_os = ["baz", "jaz"]\n' |
+ 'deps_os = {\n' |
+ ' "unix": { "foo/dir2": "/dir2", },\n' |
+ ' "baz": { "foo/dir3": "/dir3", },\n' |
+ ' "jaz": { "foo/dir4": "/dir4", },\n' |
+ ' "maz": { "foo/dir5": "/dir5", },\n' |
+ '}') |
+ |
+ parser = gclient.Parser() |
+ options, _ = parser.parse_args(['--jobs', '1']) |
+ options.deps_os = "unix" |
+ |
+ obj = gclient.GClient.LoadCurrentConfig(options) |
+ obj.RunOnDeps(None, None) |
+ self.assertEqual(['baz', 'jaz', 'unix'], sorted(obj.enforced_os)) |
+ |
def testRecursionOverride(self): |
"""Verifies gclient respects the recursion var syntax. |