| Index: tools/mb/mb_unittest.py
|
| diff --git a/tools/mb/mb_unittest.py b/tools/mb/mb_unittest.py
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..abfcb38fa9c611c63df20bfa12a5ff8b2b4653e1
|
| --- /dev/null
|
| +++ b/tools/mb/mb_unittest.py
|
| @@ -0,0 +1,130 @@
|
| +# Copyright 2015 The Chromium Authors. All rights reserved.
|
| +# Use of this source code is governed by a BSD-style license that can be
|
| +# found in the LICENSE file.
|
| +
|
| +"""Tests for mb.py."""
|
| +
|
| +import sys
|
| +import unittest
|
| +
|
| +import mb
|
| +
|
| +
|
| +class FakeMB(mb.MetaBuildWrapper):
|
| + def __init__(self):
|
| + self.files = {}
|
| + self.calls = []
|
| + self.out = []
|
| + self.err = []
|
| + self.chromium_src_dir = '/fake_src'
|
| + self.default_config = '/fake_src/tools/mb/mb_config.pyl'
|
| +
|
| + def ExpandUser(self, path):
|
| + return '$HOME/%s' % path
|
| +
|
| + def Exists(self, path):
|
| + return self.files.get(path) is not None
|
| +
|
| + def ReadFile(self, path):
|
| + return self.files[path]
|
| +
|
| + def Call(self, cmd):
|
| + self.calls.append(cmd)
|
| + return 0, '', ''
|
| +
|
| + def Print(self, *args, sep=' ', end='\n', stream=None):
|
| + if stream == sys.stderr:
|
| + self.err.append(sep.join(args) + end)
|
| + else:
|
| + self.out.append(sep.join(args) + end)
|
| +
|
| +class IntegrationTest(unittest.TestCase):
|
| + def test_validate(self):
|
| + # Note that this validates that the actual mb_config.pyl is valid.
|
| + ret = mb.main(['validate', '--quiet'])
|
| + self.assertEqual(ret, 0)
|
| +
|
| +
|
| +TEST_CONFIG = """\
|
| +{
|
| + 'common_dev_configs': ['gn_debug'],
|
| + 'configs': {
|
| + 'gyp_rel_bot': ['gyp', 'rel', 'goma'],
|
| + 'gn_debug': ['gn', 'debug'],
|
| + 'private': ['gyp', 'fake_feature1'],
|
| + 'unsupported': ['gn', 'fake_feature2'],
|
| + },
|
| + 'masters': {
|
| + 'fake_master': {
|
| + 'fake_builder': 'gyp_rel_bot',
|
| + },
|
| + },
|
| + 'mixins': {
|
| + 'fake_feature1': {
|
| + 'gn_args': 'enable_doom_melon=true',
|
| + 'gyp_defines': 'doom_melon=1',
|
| + },
|
| + 'fake_feature2': {
|
| + 'gn_args': 'enable_doom_melon=false',
|
| + 'gyp_defaults': 'doom_melon=0',
|
| + },
|
| + 'gyp': {'type': 'gyp'},
|
| + 'gn': {'type': 'gn'},
|
| + 'goma': {
|
| + 'gn_args': 'use_goma=true goma_dir="$(goma_dir)"',
|
| + 'gyp_defines': 'goma=1 gomadir="$(goma_dir)"',
|
| + },
|
| + 'rel': {
|
| + 'gn_args': 'is_debug=false',
|
| + 'gyp_config': 'Release',
|
| + },
|
| + 'debug': {
|
| + 'gn_args': 'is_debug=true',
|
| + },
|
| + },
|
| + 'private_configs': ['private'],
|
| + 'unsupported_configs': ['unsupported'],
|
| +}
|
| +"""
|
| +
|
| +
|
| +
|
| +class UnitTest(unittest.TestCase):
|
| + def check(self, args, files=None, cmds=None, out=None, err=None, ret=None):
|
| + mb = FakeMB()
|
| + if not files:
|
| + files = {}
|
| + files[mb.default_config] = TEST_CONFIG
|
| + mb.files = files
|
| + mb.ParseArgs(args)
|
| + actual_ret = mb.args.func()
|
| + if ret is not None:
|
| + self.assertEqual(actual_ret, ret)
|
| + if out is not None:
|
| + self.assertEqual(mb.out, out)
|
| + if err is not None:
|
| + self.assertEqual(mb.err, err)
|
| + if cmds is not None:
|
| + self.assertEqual(mb.cmds, cmds)
|
| +
|
| + def disabled_test_analyze(self):
|
| + self.fail() # TODO: implement me.
|
| +
|
| + def test_gen(self):
|
| + self.check(['gen', '-c', 'gn_debug', '//out/Default'], ret=0)
|
| +
|
| + def test_help(self):
|
| + return
|
| + self.check(['-h'], ret=0)
|
| + self.check(['help'], ret=0)
|
| + self.check(['help', 'gen'], ret=0)
|
| +
|
| + def test_lookup(self):
|
| + self.check(['lookup', '-c', 'gn_debug'], ret=0)
|
| +
|
| + def test_validate(self):
|
| + self.check(['validate'], ret=0)
|
| +
|
| +
|
| +if __name__ == '__main__':
|
| + unittest.main()
|
|
|