| 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.
|
|
|
|
|