Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(218)

Unified Diff: tools/json_schema_compiler/code_test.py

Issue 9114036: Code generation for extensions api (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: added generated files, removed trailing whitespace Created 8 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: tools/json_schema_compiler/code_test.py
diff --git a/tools/json_schema_compiler/code_test.py b/tools/json_schema_compiler/code_test.py
new file mode 100644
index 0000000000000000000000000000000000000000..99ce057c6bb4b8e676da82867d3514fa72350b60
--- /dev/null
+++ b/tools/json_schema_compiler/code_test.py
@@ -0,0 +1,241 @@
+# Copyright (c) 2011 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.
+
+import unittest
+import model
+import code
+import json
+
+class TestTypeManager(unittest.TestCase):
+ def setUp(self):
+ self.model = model.ModelT()
+ self.permissions_json = json.loads(open('test/permissions.json').read())
+ self.model.add_namespace(self.permissions_json[0], 'extensions',
+ 'path/to/permissions.json', '_api')
+ self.permissions = self.model.namespaces.get('permissions')
+ self.windows_json = json.loads(open('test/windows.json').read())
+ self.model.add_namespace(self.windows_json[0], 'extensions',
+ 'path/to/window.json', '_api')
+ self.windows = self.model.namespaces.get('windows')
+ self.tabs_json = json.loads(open('test/tabs.json').read())
+ self.model.add_namespace(self.tabs_json[0], 'extensions',
+ 'path/to/tabs.json', '_api')
+ self.tabs = self.model.namespaces.get('tabs')
+
+ def test_resolve_generated_includes(self):
+ type_manager = code.TypeManager(self.windows, self.model)
+ self.assertEquals(type_manager.resolve_generated_includes().code,
+ ['#include "path/to/tabs_api.h"'])
+ type_manager = code.TypeManager(self.permissions, self.model)
+ self.assertEquals(type_manager.resolve_generated_includes().code,
+ [])
+
+ def test_get_type_simple(self):
+ type_manager = code.TypeManager(self.tabs, self.model)
+ self.assertEquals(type_manager.get_type(
+ self.tabs.types['Tab'].properties['id']),
+ 'int')
+ self.assertEquals(type_manager.get_type(
+ self.tabs.types['Tab'].properties['status']),
+ 'std::string')
+ self.assertEquals(type_manager.get_type(
+ self.tabs.types['Tab'].properties['selected']),
+ 'bool')
+
+ def test_get_type_array(self):
+ type_manager = code.TypeManager(self.windows, self.model)
+ self.assertEquals(type_manager.get_type(
+ self.windows.functions['getAll'].callback.param),
+ 'std::vector<Window>')
+ type_manager = code.TypeManager(self.permissions, self.model)
+ self.assertEquals(type_manager.get_type(
+ self.permissions.types['Permissions'].properties['origins']),
+ 'std::vector<std::string>')
+
+ def test_get_type_local_ref(self):
+ type_manager = code.TypeManager(self.tabs, self.model)
+ self.assertEquals(type_manager.get_type(
+ self.tabs.functions['get'].callback.param),
+ 'Tab')
+
+ def test_get_type_included_ref(self):
+ type_manager = code.TypeManager(self.windows, self.model)
+ self.assertEquals(type_manager.get_type(
+ self.windows.types['Window'].properties['tabs']),
+ 'std::vector<tabs_api::Tab>')
+
+ def test_get_type_notfound(self):
+ prop = self.windows.types['Window'].properties['tabs'].item_type
+ prop.json_type = 'Something'
+ type_manager = code.TypeManager(self.windows, self.model)
+ self.assertRaises(KeyError, type_manager.get_type, prop)
+
+ def test_get_type_notimplemented(self):
+ prop = self.windows.types['Window'].properties['tabs'].item_type
+ prop.type = 10
+ type_manager = code.TypeManager(self.windows, self.model)
+ self.assertRaises(NotImplementedError, type_manager.get_type, prop)
+
+ def test_get_generic_type(self):
+ type_manager = code.TypeManager(self.permissions, self.model)
+ self.assertEquals(type_manager.get_generic_type(
+ self.permissions.types['Permissions'].properties['origins']),
+ 'std::vector<std::string> ')
+ self.assertEquals(type_manager.get_generic_type(
+ self.permissions.functions['contains'].callback.param),
+ 'bool')
+
+ def test_parameter_declaration(self):
+ type_manager = code.TypeManager(self.tabs, self.model)
+ self.assertEquals(type_manager.parameter_declaration(
+ self.tabs.functions['query'].callback.param),
+ "std::vector<Tab> result")
+ modifiers = {model.PropertyType.REF: code.ParamFormat.POINTER,
+ model.PropertyType.OBJECT: code.ParamFormat.REFERENCE,
+ model.PropertyType.ARRAY: '%(name)s %(type)s'}
+ self.assertEquals(type_manager.parameter_declaration(
+ self.tabs.functions['update'].callback.param,
+ type_modifiers=modifiers),
+ "Tab* tab")
+ self.assertEquals(type_manager.parameter_declaration(
+ self.tabs.functions['update'].params[1],
+ type_modifiers=modifiers),
+ "UpdateProperties& updateProperties")
+ self.assertEquals(type_manager.parameter_declaration(
+ self.tabs.functions['query'].callback.param,
+ type_modifiers=modifiers),
+ "result std::vector<Tab>")
+
+ def test_comment(self):
+ long_comment = ('This comment is eighty nine characters in longness, '
+ 'that is, to use another word, length')
+ c = code.Code()
+ c.comment(long_comment)
+ self.assertEquals(c.to_string(),
+ '// This comment is eighty nine characters in longness, that is, to use another\n'
+ '// word, length')
+ c = code.Code()
+ c.sblock('sblock')
+ c.comment(long_comment)
+ c.eblock('eblock')
+ c.comment(long_comment)
+ self.assertEquals(c.to_string(),
+ 'sblock\n'
+ ' // This comment is eighty nine characters in longness, that is, to use\n'
+ ' // another word, length\n'
+ 'eblock\n'
+ '// This comment is eighty nine characters in longness, that is, to use another\n'
+ '// word, length')
+ long_word = 'x' * 100
+ c = code.Code()
+ c.comment(long_word)
+ self.assertEquals(c.to_string(),
+ '// ' + 'x' * 77 + '\n'
+ '// ' + 'x' * 23)
+
+class TestCppName(unittest.TestCase):
+ def test_cpp_name(self):
+ self.assertEquals(code.cpp_name('permissions'), 'Permissions')
+ self.assertEquals(code.cpp_name('updateAllTheThings'), 'UpdateAllTheThings')
+ self.assertEquals(code.cpp_name('aa.bb.cc'), 'Aa_Bb_Cc')
+
+class TestCode(unittest.TestCase):
+ def test_append(self):
+ c = code.Code()
+ c.append('line')
+ self.assertEquals(c.to_string(), 'line')
+
+ def test_block(self):
+ c = code.Code()
+ c.append('line')
+ c.sblock('sblock')
+ c.append('inner')
+ c.append('moreinner')
+ c.sblock('moresblock')
+ c.append('inner')
+ c.eblock('out')
+ c.append('inner')
+ c.eblock('out')
+ self.assertEquals(c.to_string(),
+ 'line\n'
+ 'sblock\n'
+ ' inner\n'
+ ' moreinner\n'
+ ' moresblock\n'
+ ' inner\n'
+ ' out\n'
+ ' inner\n'
+ 'out')
+
+ def test_add(self):
+ b = code.Code()
+ b.sblock('2')
+ b.append('2')
+ b.eblock('2')
+ c = code.Code()
+ c.sblock('1')
+ c.add(b)
+ c.append('1')
+ c.eblock('1')
+ self.assertEquals(c.to_string(),
+ '1\n'
+ ' 2\n'
+ ' 2\n'
+ ' 2\n'
+ ' 1\n'
+ '1')
+ d = code.Code()
+ a = code.Code()
+ a.add(d)
+ self.assertEquals(a.to_string(), '')
+ a.add(c)
+ self.assertEquals(a.to_string(),
+ '1\n'
+ ' 2\n'
+ ' 2\n'
+ ' 2\n'
+ ' 1\n'
+ '1')
+
+ def test_add_errors(self):
+ c = code.Code()
+ d = code.Code()
+ d.append('%s')
+ self.assertRaises(TypeError, c.add, d)
+ d = code.Code()
+ d.append('%(classname)s')
+ self.assertRaises(TypeError, c.add, d)
+ d = 'line of code'
+ self.assertRaises(TypeError, c.add, d)
+
+ def test_substitute(self):
+ c = code.Code()
+ c.append('%(var1)s %(var2)s %(var1)s')
+ c.substitute({'var1': 'one', 'var2': 'two'})
+ self.assertEquals(c.to_string(), 'one two one')
+ c.append('%(var1)s %(var2)s %(var3)s')
+ c.append('%(var1)s %(var2)s %(var3)s')
+ c.substitute({'var1': 'one', 'var2': 'two', 'var3': 'three'})
+ self.assertEquals(c.to_string(),
+ 'one two one\n'
+ 'one two three\n'
+ 'one two three')
+
+ def test_substitute_errors(self):
+ # No unnamed placeholders allowed when substitute is run
+ c = code.Code()
+ c.append('%s %s')
+ self.assertRaises(TypeError, c.substitute, ('var1', 'one'))
+ c = code.Code()
+ c.append('%s %(var1)s')
+ self.assertRaises(TypeError, c.substitute, {'var1': 'one'})
+ c = code.Code()
+ c.append('%s %(var1)s')
+ self.assertRaises(TypeError, c.substitute, {'var1': 'one'})
+ c = code.Code()
+ c.append('%(var1)s')
+ self.assertRaises(KeyError, c.substitute, {'clearlynotvar1': 'one'})
+
+if __name__ == '__main__':
+ unittest.main()

Powered by Google App Engine
This is Rietveld 408576698