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

Unified Diff: tools/json_schema_compiler/type_manager_test.py

Issue 9114036: Code generation for extensions api (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: some rework 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/type_manager_test.py
diff --git a/tools/json_schema_compiler/type_manager_test.py b/tools/json_schema_compiler/type_manager_test.py
new file mode 100644
index 0000000000000000000000000000000000000000..5656f8921aa4e8fa1c014c440be466d6cdd973ea
--- /dev/null
+++ b/tools/json_schema_compiler/type_manager_test.py
@@ -0,0 +1,135 @@
+import unittest
+import model
+import code
+import json
+import type_manager
+
+class TestTypeManager(unittest.TestCase):
+ def setUp(self):
+ self.model = model.Model()
+ 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):
+ manager = type_manager.TypeManager(self.windows, self.model)
+ self.assertEquals(manager.resolve_generated_includes().code,
+ ['#include "path/to/tabs_api.h"'])
+ manager = type_manager.TypeManager(self.permissions, self.model)
+ self.assertEquals(manager.resolve_generated_includes().code,
+ [])
+
+ def test_get_type_simple(self):
+ manager = type_manager.TypeManager(self.tabs, self.model)
+ self.assertEquals(manager.get_type(
+ self.tabs.types['Tab'].properties['id']),
+ 'int')
+ self.assertEquals(manager.get_type(
+ self.tabs.types['Tab'].properties['status']),
+ 'std::string')
+ self.assertEquals(manager.get_type(
+ self.tabs.types['Tab'].properties['selected']),
+ 'bool')
+
+ def test_get_type_array(self):
+ manager = type_manager.TypeManager(self.windows, self.model)
+ self.assertEquals(manager.get_type(
+ self.windows.functions['getAll'].callback.param),
+ 'std::vector<Window>')
+ manager = type_manager.TypeManager(self.permissions, self.model)
+ self.assertEquals(manager.get_type(
+ self.permissions.types['Permissions'].properties['origins']),
+ 'std::vector<std::string>')
+
+ def test_get_type_local_ref(self):
+ manager = type_manager.TypeManager(self.tabs, self.model)
+ self.assertEquals(manager.get_type(
+ self.tabs.functions['get'].callback.param),
+ 'Tab')
+
+ def test_get_type_included_ref(self):
+ manager = type_manager.TypeManager(self.windows, self.model)
+ self.assertEquals(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'
+ manager = type_manager.TypeManager(self.windows, self.model)
+ self.assertRaises(KeyError, manager.get_type, prop)
+
+ def test_get_type_notimplemented(self):
+ prop = self.windows.types['Window'].properties['tabs'].item_type
+ prop.type = 10
+ manager = type_manager.TypeManager(self.windows, self.model)
+ self.assertRaises(NotImplementedError, manager.get_type, prop)
+
+ def test_get_generic_type(self):
+ manager = type_manager.TypeManager(self.permissions, self.model)
+ self.assertEquals(manager.get_generic_type(
+ self.permissions.types['Permissions'].properties['origins']),
+ 'std::vector<std::string> ')
+ self.assertEquals(manager.get_generic_type(
+ self.permissions.functions['contains'].callback.param),
+ 'bool')
+
+ def test_parameter_declaration(self):
+ manager = type_manager.TypeManager(self.tabs, self.model)
+ self.assertEquals(manager.parameter_declaration(
+ self.tabs.functions['query'].callback.param),
+ "std::vector<Tab> result")
+ modifiers = {model.PropertyType.REF: type_manager.ParamFormat.POINTER,
+ model.PropertyType.OBJECT: type_manager.ParamFormat.REFERENCE,
+ model.PropertyType.ARRAY: '%(name)s %(type)s'}
+ self.assertEquals(manager.parameter_declaration(
+ self.tabs.functions['update'].callback.param,
+ type_modifiers=modifiers),
+ "Tab* tab")
+ self.assertEquals(manager.parameter_declaration(
+ self.tabs.functions['update'].params[1],
+ type_modifiers=modifiers),
+ "UpdateProperties& updateProperties")
+ self.assertEquals(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.render(),
+ '// 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.render(),
+ '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.render(),
+ '// ' + 'x' * 77 + '\n'
+ '// ' + 'x' * 23)
+
+if __name__ == '__main__':
+ unittest.main()

Powered by Google App Engine
This is Rietveld 408576698