def generate(**kwargs: Any): """ Generate code from xml schemas, webservice definitions and any xml or json document. The input source can be either a filepath, uri or a directory containing xml, json, xsd and wsdl files. """ if kwargs["print"]: logger.setLevel(logging.ERROR) config_file = Path(kwargs["config"]) if config_file.exists(): config = GeneratorConfig.read(config_file) if kwargs["package"] != "generated": config.output.package = kwargs["package"] else: config = GeneratorConfig() config.output.format = kwargs["output"] config.output.package = kwargs["package"] config.output.compound_fields = kwargs["compound_fields"] config.output.docstring_style = DocstringStyle( kwargs["docstring_style"]) if kwargs["ns_struct"]: config.output.structure = OutputStructure.NAMESPACES uris = resolve_source(kwargs["source"]) transformer = SchemaTransformer(config=config, print=kwargs["print"]) transformer.process(list(uris))
def cli(source: str, package: str, output: str, print: bool): """ Convert schema definitions to code. SOURCE can be either a filepath, directory or url """ if print: logger.setLevel(logging.ERROR) uris = resolve_source(source) transformer = SchemaTransformer(output=output, print=print) transformer.process(list(uris), package)
def generate(**kwargs: Any): """ Convert schema definitions to code. SOURCE can be either a filepath, directory or url """ if kwargs["print"]: logger.setLevel(logging.ERROR) config_file = Path(kwargs["config"]) if config_file.exists(): config = GeneratorConfig.read(config_file) else: config = GeneratorConfig() config.output.format = OutputFormat(kwargs["output"]) config.output.package = kwargs["package"] config.output.wsdl = kwargs["wsdl"] config.output.compound_fields = kwargs["compound_fields"] config.output.docstring_style = DocstringStyle( kwargs["docstring_style"]) if kwargs["ns_struct"]: config.output.structure = OutputStructure.NAMESPACES uris = resolve_source(kwargs["source"], wsdl=config.output.wsdl) transformer = SchemaTransformer(config=config, print=kwargs["print"]) if config.output.wsdl: transformer.process_definitions(next(uris)) else: transformer.process_schemas(list(uris))
def generate_schema(schema_filename, config_filename, outloc ): from xsdata.codegen.transformer import SchemaTransformer from xsdata.exceptions import CodeGenerationError from xsdata.logger import logger from xsdata.models.config import GeneratorConfig from xsdata.models.config import OutputFormat from xsdata.models.config import OutputStructure def to_uri(filename): return Path(filename).absolute().as_uri() subpackage_name = 'ismrmrdschema' logger.setLevel(logging.INFO) config = GeneratorConfig.read(Path(config_filename)) config.output.format = OutputFormat("pydata") config.output.package = subpackage_name transformer = SchemaTransformer(config=config,print=False) transformer.process_schemas([to_uri(schema_filename)]) fix_init_file(subpackage_name,f"{subpackage_name}/__init__.py") shutil.rmtree(os.path.join(outloc,subpackage_name),ignore_errors=True) shutil.move(subpackage_name,outloc)
def setUp(self): config = GeneratorConfig() self.transformer = SchemaTransformer(print=True, config=config) super().setUp()
class SchemaTransformerTests(FactoryTestCase): def setUp(self): config = GeneratorConfig() self.transformer = SchemaTransformer(print=True, config=config) super().setUp() @mock.patch.object(SchemaTransformer, "process_classes") @mock.patch.object(SchemaTransformer, "convert_schema") @mock.patch.object(SchemaTransformer, "convert_definitions") @mock.patch.object(SchemaTransformer, "parse_definitions") def test_process_definitions( self, mock_parse_definitions, mock_convert_definitions, mock_convert_schema, mock_process_classes, ): uri = "http://xsdata/services.xsd" definitions = Definitions(types=Types(schemas=[Schema(), Schema()])) mock_parse_definitions.return_value = definitions self.transformer.process_definitions(uri) mock_convert_schema.assert_has_calls( [mock.call(x) for x in definitions.schemas] ) mock_parse_definitions.assert_called_once_with(uri, namespace=None) mock_convert_definitions.assert_called_once_with(definitions) mock_process_classes.assert_called_once_with() @mock.patch.object(SchemaTransformer, "process_classes") @mock.patch.object(SchemaTransformer, "process_schema") def test_process_schemas(self, mock_process_schema, mock_process_classes): uris = ["http://xsdata/foo.xsd", "http://xsdata/bar.xsd"] self.transformer.process_schemas(uris) mock_process_schema.assert_has_calls([mock.call(uri) for uri in uris]) mock_process_classes.assert_called_once_with() @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(CodeWriter, "print") @mock.patch.object(SchemaTransformer, "analyze_classes") @mock.patch.object(SchemaTransformer, "assign_packages") def test_process_classes_with_print_true( self, mock_assign_packages, mock_analyze_classes, mock_writer_print, mock_logger_into, ): package = "test" schema_classes = ClassFactory.list(3) analyzer_classes = ClassFactory.list(2) mock_analyze_classes.return_value = analyzer_classes self.transformer.class_map = { "http://xsdata/foo.xsd": schema_classes[:1], "http://xsdata/bar.xsd": schema_classes[1:], } self.transformer.process_classes() mock_assign_packages.assert_called_once_with() mock_analyze_classes.assert_called_once_with(schema_classes) mock_writer_print.assert_called_once_with(analyzer_classes) mock_logger_into.assert_has_calls( [ mock.call("Analyzer input: %d main and %d inner classes", 3, 0), mock.call("Analyzer output: %d main and %d inner classes", 2, 0), ] ) @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(CodeWriter, "write") @mock.patch.object(SchemaTransformer, "analyze_classes") @mock.patch.object(SchemaTransformer, "assign_packages") def test_process_classes_with_print_false( self, mock_assign_packages, mock_analyze_classes, mock_writer_write, mock_logger_into, ): package = "test" schema_classes = ClassFactory.list(3) analyzer_classes = ClassFactory.list(2) mock_analyze_classes.return_value = analyzer_classes self.transformer.print = False self.transformer.class_map = { "http://xsdata/foo.xsd": schema_classes[:1], "http://xsdata/bar.xsd": schema_classes[1:], } self.transformer.process_classes() mock_assign_packages.assert_called_once_with() mock_analyze_classes.assert_called_once_with(schema_classes) mock_writer_write.assert_called_once_with(analyzer_classes) mock_logger_into.assert_has_calls( [ mock.call("Analyzer input: %d main and %d inner classes", 3, 0), mock.call("Analyzer output: %d main and %d inner classes", 2, 0), ] ) def test_process_classes_with_zero_classes_after_analyze(self): with self.assertRaises(CodeGenerationError) as cm: self.transformer.process_classes() self.assertEqual("Nothing to generate.", str(cm.exception)) @mock.patch("xsdata.codegen.transformer.logger.debug") @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(SchemaTransformer, "convert_schema") @mock.patch.object(SchemaTransformer, "parse_schema") def test_process_schema( self, mock_parse_schema, mock_convert_schema, mock_logger_info, mock_logger_debug, ): schema = Schema() mock_parse_schema.return_value = schema uri = "http://xsdata/services.xsd" namespace = "fooNS" self.transformer.process_schema(uri, namespace) self.transformer.process_schema(uri, namespace) self.assertEqual([uri], self.transformer.processed) mock_convert_schema.assert_called_once_with(schema) mock_logger_info.assert_called_once_with("Parsing schema %s", "services.xsd") mock_logger_debug.assert_called_once_with( "Skipping already processed: %s", "services.xsd" ) @mock.patch.object(SchemaTransformer, "convert_schema") @mock.patch.object(SchemaTransformer, "parse_schema") def test_process_schema_ignores_empty_schema( self, mock_parse_schema, mock_convert_schema, ): mock_parse_schema.return_value = None uri = "http://xsdata/services.xsd" namespace = "fooNS" self.transformer.process_schema(uri, namespace) self.assertEqual([uri], self.transformer.processed) self.assertEqual(0, mock_convert_schema.call_count) @mock.patch.object(SchemaTransformer, "generate_classes") @mock.patch.object(SchemaTransformer, "process_schema") def test_convert_schema(self, mock_process_schema, mock_generate_classes): schema = Schema(target_namespace="thug", location="main") schema.includes.append(Include(location="foo")) schema.overrides.append(Override()) schema.imports.append(Import(location="bar")) schema.imports.append(Import(location="fails")) mock_generate_classes.return_value = ClassFactory.list(2) self.transformer.convert_schema(schema) self.assertEqual(1, len(self.transformer.class_map)) self.assertEqual(2, len(self.transformer.class_map["main"])) mock_process_schema.assert_has_calls( [ mock.call("bar", "thug"), mock.call("fails", "thug"), mock.call("foo", "thug"), ] ) @mock.patch.object(DefinitionsMapper, "map") def test_convert_definitions(self, mock_definitions_map): classes = ClassFactory.list(2) mock_definitions_map.return_value = classes definitions = Definitions(location="foo") self.transformer.convert_definitions(definitions) self.assertEqual(classes, self.transformer.class_map[definitions.location]) @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(SchemaTransformer, "count_classes") @mock.patch.object(SchemaMapper, "map") def test_generate_classes( self, mock_mapper_map, mock_count_classes, mock_logger_info ): schema = Schema(location="edo.xsd") classes = ClassFactory.list(2) mock_mapper_map.return_value = classes mock_count_classes.return_value = 2, 4 self.transformer.generate_classes(schema) mock_mapper_map.assert_called_once_with(schema) mock_logger_info.assert_has_calls( [ mock.call("Compiling schema %s", schema.location), mock.call("Builder: %d main and %d inner classes", 2, 4), ] ) def test_parse_schema(self): path = Path(__file__).parent.joinpath("../fixtures/books/schema.xsd").as_uri() schema = self.transformer.parse_schema(path, "foo.bar") self.assertIsInstance(schema, Schema) self.assertEqual(2, len(schema.complex_types)) @mock.patch("xsdata.codegen.transformer.logger.warning") @mock.patch("xsdata.codegen.transformer.urlopen") def test_parse_schema_with_os_exception(self, mock_urlopen, mock_logger_warning): mock_urlopen.side_effect = FileNotFoundError path = Path(__file__).parent.joinpath("fixtures/books/schema.xsd").as_uri() schema = self.transformer.parse_schema(path, "foo") self.assertIsNone(schema) mock_logger_warning.assert_called_once_with("Schema not found %s", path) @mock.patch.object(SchemaTransformer, "process_schema") @mock.patch.object(Definitions, "merge") @mock.patch.object(DefinitionsParser, "from_bytes") @mock.patch.object(SchemaTransformer, "load_resource") def test_parse_definitions( self, mock_load_resource, mock_definitions_parser, mock_definitions_merge, mock_process_schema, ): def_one = Definitions( imports=[ Import(), Import(location="file://sub.wsdl"), Import(location="file://types.xsd"), ] ) def_two = Definitions() mock_load_resource.side_effect = ["a", "b"] mock_definitions_parser.side_effect = [def_one, def_two] actual = self.transformer.parse_definitions("main.wsdl", "fooNS") self.assertEqual(def_one, actual) mock_definitions_merge.assert_called_once_with(def_two) mock_process_schema.assert_called_once_with("file://types.xsd") def test_load_resource(self): path = Path(__file__).as_uri() result = self.transformer.load_resource(path) self.assertTrue(len(result) > 0) def test_count_classes(self): classes = ClassFactory.list( 2, inner=ClassFactory.list(2, inner=ClassFactory.list(3)) ) self.assertEqual((2, 16), self.transformer.count_classes(classes)) def test_assign_packages(self): core = "file://HL7V3/NE2008/coreschemas/voc.xsd" multi_one = "file://HL7V3/NE2008/multicacheschemas/PRPA_MT201307UV02.xsd" multi_two = "file://HL7V3/NE2008/multicacheschemas/COCT_MT080000UV.xsd" http_one = "http://xsdata/foo/bar/schema.xsd" http_two = "http://xsdata/foo/common.xsd" local_one = Namespace.XSI.location local_two = Namespace.XLINK.location class_map = { core: ClassFactory.list(1, inner=[ClassFactory.create()]), multi_one: ClassFactory.list(2), multi_two: ClassFactory.list(1), http_one: ClassFactory.list(1), http_two: ClassFactory.list(1), local_one: ClassFactory.list(1), local_two: ClassFactory.list(1), } self.transformer.class_map = class_map self.transformer.config.output.package = "foo.bar" self.transformer.assign_packages() self.assertEqual("foo.bar.coreschemas", class_map[core][0].package) self.assertEqual("foo.bar.coreschemas", class_map[core][0].inner[0].package) self.assertEqual("foo.bar.multicacheschemas", class_map[multi_one][0].package) self.assertEqual("foo.bar.multicacheschemas", class_map[multi_one][1].package) self.assertEqual("foo.bar.multicacheschemas", class_map[multi_two][0].package) self.assertEqual("foo.bar.bar", class_map[http_one][0].package) self.assertEqual("foo.bar", class_map[http_two][0].package) self.assertEqual("foo.bar", class_map[local_one][0].package) self.assertEqual("foo.bar", class_map[local_two][0].package) @mock.patch.object(ClassAnalyzer, "process") def test_analyze_classes(self, mock_process): classes = ClassFactory.list(2) mock_process.return_value = classes[1:] result = self.transformer.analyze_classes(classes) self.assertEqual(1, len(result)) mock_process.assert_called_once_with(classes, self.transformer.config)
os.system("git pull") os.chdir(current_path) else: # fresh (sparse) checkout os.chdir(sdf_location) os.system(f"git clone {sdf_repo} --no-checkout . --depth 1") os.system("git sparse-checkout init --cone") os.system("git sparse-checkout set sdf") os.chdir(current_path) # convert the SDF templates to XSD xsd_location = Path("skbot/ignition/sdformat/schema/") for version in sdf_versions: source_path = sdf_location / "sdf" / version out_dir = xsd_location / version out_dir.mkdir(exist_ok=True, parents=True) gen_bindings(source_path, out_dir, ns_prefix=f"sdformat/v{version}") # build python bindings from XSD config = GeneratorConfig.read( Path(__file__).parent / "sdf_bindings_config.xml") for version in sdf_versions: config.output.package = ( f"skbot.ignition.sdformat.bindings.v{version.replace('.', '')}") source_path = xsd_location / version uris = [x.absolute().as_uri() for x in source_path.iterdir()] if uris: tf = SchemaTransformer(print=False, config=config) tf.process(uris)
def setUp(self): self.transformer = SchemaTransformer(print=True, output="pydata")
class SchemaTransformerTests(FactoryTestCase): def setUp(self): self.transformer = SchemaTransformer(print=True, output="pydata") @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(CodeWriter, "print") @mock.patch.object(CodeWriter, "designate") @mock.patch.object(SchemaTransformer, "analyze_classes") @mock.patch.object(SchemaTransformer, "assign_packages") @mock.patch.object(SchemaTransformer, "process_schema") def test_process_with_print_true( self, mock_process_schema, mock_assign_packages, mock_analyze_classes, mock_writer_designate, mock_writer_print, mock_logger_into, ): urls = ["http://xsdata/foo.xsd", "http://xsdata/bar.xsd"] package = "test" schema_classes = ClassFactory.list(3) analyzer_classes = ClassFactory.list(2) mock_analyze_classes.return_value = analyzer_classes self.transformer.class_map = { "http://xsdata/foo.xsd": schema_classes[:1], "http://xsdata/bar.xsd": schema_classes[1:], } self.transformer.process(urls, package) mock_process_schema.assert_has_calls(list(map(mock.call, urls))) mock_assign_packages.assert_called_once_with(package) mock_analyze_classes.assert_called_once_with(schema_classes) mock_writer_designate.assert_called_once_with(analyzer_classes, "pydata") mock_writer_print.assert_called_once_with(analyzer_classes, "pydata") mock_logger_into.assert_has_calls( [ mock.call("Analyzer input: %d main and %d inner classes", 3, 0), mock.call("Analyzer output: %d main and %d inner classes", 2, 0), ] ) @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(CodeWriter, "write") @mock.patch.object(CodeWriter, "designate") @mock.patch.object(SchemaTransformer, "analyze_classes") @mock.patch.object(SchemaTransformer, "assign_packages") @mock.patch.object(SchemaTransformer, "process_schema") def test_process_with_print_false( self, mock_process_schema, mock_assign_packages, mock_analyze_classes, mock_writer_designate, mock_writer_write, mock_logger_into, ): urls = ["http://xsdata/foo.xsd", "http://xsdata/bar.xsd"] package = "test" schema_classes = ClassFactory.list(3) analyzer_classes = ClassFactory.list(2) mock_analyze_classes.return_value = analyzer_classes self.transformer.print = False self.transformer.class_map = { "http://xsdata/foo.xsd": schema_classes[:1], "http://xsdata/bar.xsd": schema_classes[1:], } self.transformer.process(urls, package) mock_process_schema.assert_has_calls(list(map(mock.call, urls))) mock_assign_packages.assert_called_once_with(package) mock_analyze_classes.assert_called_once_with(schema_classes) mock_writer_designate.assert_called_once_with(analyzer_classes, "pydata") mock_writer_write.assert_called_once_with(analyzer_classes, "pydata") mock_logger_into.assert_has_calls( [ mock.call("Analyzer input: %d main and %d inner classes", 3, 0), mock.call("Analyzer output: %d main and %d inner classes", 2, 0), ] ) @mock.patch("xsdata.codegen.transformer.logger.warning") @mock.patch.object(SchemaTransformer, "analyze_classes") @mock.patch.object(SchemaTransformer, "assign_packages") @mock.patch.object(SchemaTransformer, "process_schema") def test_process_with_zero_classes_after_analyze( self, mock_process_schema, mock_assign_packages, mock_analyze_classes, mock_logger_warning, ): urls = ["http://xsdata/foo.xsd", "http://xsdata/bar.xsd"] package = "test" self.transformer.process(urls, package) self.assertEqual(0, mock_analyze_classes.call_count) self.assertEqual(0, mock_assign_packages.call_count) mock_process_schema.assert_has_calls(list(map(mock.call, urls))) mock_logger_warning.assert_called_once_with("Analyzer returned zero classes!") @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(SchemaTransformer, "generate_classes") @mock.patch.object(SchemaTransformer, "parse_schema") def test_process_schema( self, mock_parse_schema, mock_generate_classes, mock_logger_info, ): schema = Schema(target_namespace="thug") schema.includes.append(Include(location="foo")) schema.overrides.append(Override()) schema.imports.append(Import(location="bar")) schema.imports.append(Import(location="fails")) schema_foo = Schema() schema_bar = Schema() mock_generate_classes.side_effect = [ ClassFactory.list(1), ClassFactory.list(2), ClassFactory.list(3), ] mock_parse_schema.side_effect = [schema, schema_bar, None, schema_foo] self.transformer.process_schema("main", "foo-bar") self.assertEqual(["main", "bar", "fails", "foo"], self.transformer.processed) self.assertEqual(3, len(self.transformer.class_map)) self.assertEqual(3, len(self.transformer.class_map["main"])) self.assertEqual(2, len(self.transformer.class_map["foo"])) self.assertEqual(1, len(self.transformer.class_map["bar"])) mock_logger_info.assert_has_calls( [ mock.call("Parsing schema %s", "main"), mock.call("Parsing schema %s", "bar"), mock.call("Parsing schema %s", "fails"), mock.call("Parsing schema %s", "foo"), ] ) @mock.patch("xsdata.codegen.transformer.logger.debug") @mock.patch.object(SchemaTransformer, "parse_schema") def test_process_schema_avoid_circular_imports( self, mock_parse_schema, mock_logger_debug ): path = Path(__file__).as_uri() self.transformer.processed.append(path) self.transformer.process_schema(path, None) self.assertEqual(0, mock_parse_schema.call_count) mock_logger_debug.assert_called_once_with( "Already processed skipping: %s", path ) @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(SchemaTransformer, "count_classes") @mock.patch.object(ClassBuilder, "build") @mock.patch.object(ClassBuilder, "__init__", return_value=None) def test_generate_classes( self, mock_builder_init, mock_builder_build, mock_count_classes, mock_logger_info, ): schema = Schema(location="edo.xsd") classes = ClassFactory.list(2) mock_builder_build.return_value = classes mock_count_classes.return_value = 2, 4 self.transformer.generate_classes(schema) mock_builder_init.assert_called_once_with(schema=schema) mock_builder_build.assert_called_once_with() mock_logger_info.assert_has_calls( [ mock.call("Compiling schema %s", schema.location), mock.call("Builder: %d main and %d inner classes", 2, 4), ] ) def test_parse_schema(self): path = Path(__file__).parent.joinpath("../fixtures/books.xsd").as_uri() schema = self.transformer.parse_schema(path, "foo.bar") self.assertIsInstance(schema, Schema) self.assertEqual(2, len(schema.complex_types)) @mock.patch("xsdata.codegen.transformer.logger.warning") @mock.patch("xsdata.codegen.transformer.urlopen") def test_parse_schema_with_os_exception(self, mock_urlopen, mock_logger_warning): mock_urlopen.side_effect = FileNotFoundError path = Path(__file__).parent.joinpath("fixtures/books.xsd").as_uri() schema = self.transformer.parse_schema(path, "foo") self.assertIsNone(schema) mock_logger_warning.assert_called_once_with("Schema not found %s", path) def test_count_classes(self): classes = ClassFactory.list( 2, inner=ClassFactory.list(2, inner=ClassFactory.list(3)) ) self.assertEqual((2, 16), self.transformer.count_classes(classes)) def test_assign_packages(self): core = "file://HL7V3/NE2008/coreschemas/voc.xsd" multi_one = "file://HL7V3/NE2008/multicacheschemas/PRPA_MT201307UV02.xsd" multi_two = "file://HL7V3/NE2008/multicacheschemas/COCT_MT080000UV.xsd" http_one = "http://xsdata/foo/bar/schema.xsd" http_two = "http://xsdata/foo/common.xsd" local_one = Namespace.XSI.location local_two = Namespace.XLINK.location class_map = { core: ClassFactory.list(1, inner=[ClassFactory.create()]), multi_one: ClassFactory.list(2), multi_two: ClassFactory.list(1), http_one: ClassFactory.list(1), http_two: ClassFactory.list(1), local_one: ClassFactory.list(1), local_two: ClassFactory.list(1), } self.transformer.class_map = class_map self.transformer.assign_packages("foo.bar") self.assertEqual("foo.bar.coreschemas", class_map[core][0].package) self.assertEqual("foo.bar.coreschemas", class_map[core][0].inner[0].package) self.assertEqual("foo.bar.multicacheschemas", class_map[multi_one][0].package) self.assertEqual("foo.bar.multicacheschemas", class_map[multi_one][1].package) self.assertEqual("foo.bar.multicacheschemas", class_map[multi_two][0].package) self.assertEqual("foo.bar.bar", class_map[http_one][0].package) self.assertEqual("foo.bar", class_map[http_two][0].package) self.assertEqual("foo.bar", class_map[local_one][0].package) self.assertEqual("foo.bar", class_map[local_two][0].package) @mock.patch.object(ClassAnalyzer, "process") def test_analyze_classes(self, mock_process): classes = ClassFactory.list(2) mock_process.return_value = classes[1:] result = self.transformer.analyze_classes(classes) self.assertEqual(1, len(result))
def setUp(self): self.transformer = SchemaTransformer(print=True, output="pydata", ns_struct=False) super().setUp()
class SchemaTransformerTests(FactoryTestCase): def setUp(self): config = GeneratorConfig() self.transformer = SchemaTransformer(print=True, config=config) super().setUp() @mock.patch.object(SchemaTransformer, "process_classes") @mock.patch.object(SchemaTransformer, "process_json_documents") @mock.patch.object(SchemaTransformer, "process_xml_documents") @mock.patch.object(SchemaTransformer, "process_schemas") @mock.patch.object(SchemaTransformer, "process_definitions") def test_process( self, mock_process_definitions, mock_process_schemas, process_xml_documents, process_json_documents, mock_process_classes, ): uris = [ "a.wsdl", "b.wsdl", "c.xsd", "d.xsd", "e.xml", "f.xml", "g.json", "h.json", ] self.transformer.process(uris) mock_process_definitions.assert_called_once_with(uris[:2]) mock_process_schemas.assert_called_once_with(uris[2:4]) process_xml_documents.assert_called_once_with(uris[4:6]) process_json_documents.assert_called_once_with(uris[6:]) mock_process_classes.assert_called_once_with() @mock.patch.object(SchemaTransformer, "convert_schema") @mock.patch.object(SchemaTransformer, "convert_definitions") @mock.patch.object(SchemaTransformer, "parse_definitions") def test_process_definitions( self, mock_parse_definitions, mock_convert_definitions, mock_convert_schema, ): uris = [ "http://xsdata/services.wsdl", "http://xsdata/abstractServices.wsdl", "http://xsdata/notfound.wsdl", ] fist_def = Definitions(types=Types(schemas=[Schema(), Schema()])) second_def = Definitions(bindings=[Binding()]) mock_parse_definitions.side_effect = [fist_def, second_def, None] self.transformer.process_definitions(uris) mock_convert_schema.assert_has_calls( [mock.call(x) for x in fist_def.schemas]) mock_parse_definitions.assert_has_calls([ mock.call(uris[0], namespace=None), mock.call(uris[1], namespace=None) ]) mock_convert_definitions.assert_called_once_with(fist_def) @mock.patch.object(SchemaTransformer, "process_schema") def test_process_schemas(self, mock_process_schema): uris = ["http://xsdata/foo.xsd", "http://xsdata/bar.xsd"] self.transformer.process_schemas(uris) mock_process_schema.assert_has_calls([mock.call(uri) for uri in uris]) @mock.patch.object(ClassUtils, "reduce") @mock.patch.object(ElementMapper, "map") @mock.patch.object(TreeParser, "from_bytes") @mock.patch.object(SchemaTransformer, "load_resource") def test_process_xml_documents(self, mock_load_resource, mock_from_bytes, mock_map, mock_reduce): uris = ["foo/a.xml", "foo/b.xml", "foo/c.xml"] resources = [b"a", None, b"c"] elements = [AnyElement(), AnyElement()] classes_a = ClassFactory.list(2) classes_c = ClassFactory.list(3) mock_load_resource.side_effect = resources mock_from_bytes.side_effect = elements mock_map.side_effect = [classes_a, classes_c] mock_reduce.return_value = classes_a + classes_c self.transformer.process_xml_documents(uris) self.assertIn("foo", self.transformer.class_map) self.assertEqual(5, len(self.transformer.class_map["foo"])) mock_from_bytes.assert_has_calls( [mock.call(resources[0]), mock.call(resources[2])]) mock_map.assert_has_calls([mock.call(x) for x in elements]) mock_reduce.assert_called_once_with(classes_a + classes_c) @mock.patch.object(ClassUtils, "reduce") @mock.patch.object(DictMapper, "map") @mock.patch.object(SchemaTransformer, "load_resource") def test_process_json_documents(self, mock_load_resource, mock_map, mock_reduce): uris = ["foo/a.json", "foo/b.json", "foo/c.json"] resources = [b'{"foo": 1}', None, b'{"foo": true}'] classes_a = ClassFactory.list(2) classes_c = ClassFactory.list(3) mock_load_resource.side_effect = resources mock_map.side_effect = [classes_a, classes_c] mock_reduce.return_value = classes_a + classes_c self.transformer.config.output.package = "some.books" self.transformer.process_json_documents(uris) self.assertIn("foo", self.transformer.class_map) self.assertEqual(5, len(self.transformer.class_map["foo"])) mock_map.assert_has_calls([ mock.call({"foo": 1}, "books"), mock.call({"foo": True}, "books"), ]) mock_reduce.assert_called_once_with(classes_a + classes_c) @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(CodeWriter, "print") @mock.patch.object(SchemaTransformer, "analyze_classes") @mock.patch.object(SchemaTransformer, "assign_packages") def test_process_classes_with_print_true( self, mock_assign_packages, mock_analyze_classes, mock_writer_print, mock_logger_into, ): schema_classes = ClassFactory.list(3) analyzer_classes = ClassFactory.list(2) mock_analyze_classes.return_value = analyzer_classes self.transformer.class_map = { "http://xsdata/foo.xsd": schema_classes[:1], "http://xsdata/bar.xsd": schema_classes[1:], } self.transformer.process_classes() mock_assign_packages.assert_called_once_with() mock_analyze_classes.assert_called_once_with(schema_classes) mock_writer_print.assert_called_once_with(analyzer_classes) mock_logger_into.assert_has_calls([ mock.call("Analyzer input: %d main and %d inner classes", 3, 0), mock.call("Analyzer output: %d main and %d inner classes", 2, 0), ]) @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(CodeWriter, "write") @mock.patch.object(SchemaTransformer, "analyze_classes") @mock.patch.object(SchemaTransformer, "assign_packages") def test_process_classes_with_print_false( self, mock_assign_packages, mock_analyze_classes, mock_writer_write, mock_logger_into, ): schema_classes = ClassFactory.list(3) analyzer_classes = ClassFactory.list(2) mock_analyze_classes.return_value = analyzer_classes self.transformer.print = False self.transformer.class_map = { "http://xsdata/foo.xsd": schema_classes[:1], "http://xsdata/bar.xsd": schema_classes[1:], } self.transformer.process_classes() mock_assign_packages.assert_called_once_with() mock_analyze_classes.assert_called_once_with(schema_classes) mock_writer_write.assert_called_once_with(analyzer_classes) mock_logger_into.assert_has_calls([ mock.call("Analyzer input: %d main and %d inner classes", 3, 0), mock.call("Analyzer output: %d main and %d inner classes", 2, 0), ]) def test_process_classes_with_zero_classes_after_analyze(self): with self.assertRaises(CodeGenerationError) as cm: self.transformer.process_classes() self.assertEqual("Nothing to generate.", str(cm.exception)) @mock.patch.object(SchemaTransformer, "convert_schema") @mock.patch.object(SchemaTransformer, "parse_schema") def test_process_schema( self, mock_parse_schema, mock_convert_schema, ): schema = Schema() mock_parse_schema.return_value = schema uri = "http://xsdata/services.xsd" namespace = "fooNS" self.transformer.process_schema(uri, namespace) mock_convert_schema.assert_called_once_with(schema) @mock.patch.object(SchemaTransformer, "convert_schema") @mock.patch.object(SchemaTransformer, "parse_schema") def test_process_schema_ignores_empty_schema( self, mock_parse_schema, mock_convert_schema, ): mock_parse_schema.return_value = None uri = "http://xsdata/services.xsd" namespace = "fooNS" self.transformer.process_schema(uri, namespace) self.assertEqual(0, mock_convert_schema.call_count) @mock.patch.object(SchemaTransformer, "generate_classes") @mock.patch.object(SchemaTransformer, "process_schema") def test_convert_schema(self, mock_process_schema, mock_generate_classes): schema = Schema(target_namespace="thug", location="main") schema.includes.append(Include(location="foo")) schema.overrides.append(Override()) schema.imports.append(Import(location="bar")) schema.imports.append(Import(location="fails")) mock_generate_classes.return_value = ClassFactory.list(2) self.transformer.convert_schema(schema) self.assertEqual(1, len(self.transformer.class_map)) self.assertEqual(2, len(self.transformer.class_map["main"])) mock_process_schema.assert_has_calls([ mock.call("bar", "thug"), mock.call("fails", "thug"), mock.call("foo", "thug"), ]) @mock.patch.object(DefinitionsMapper, "map") def test_convert_definitions(self, mock_definitions_map): classes = ClassFactory.list(2) mock_definitions_map.return_value = classes definitions = Definitions(location="foo") self.transformer.convert_definitions(definitions) self.assertEqual(classes, self.transformer.class_map[definitions.location]) @mock.patch("xsdata.codegen.transformer.logger.info") @mock.patch.object(SchemaTransformer, "count_classes") @mock.patch.object(SchemaMapper, "map") def test_generate_classes(self, mock_mapper_map, mock_count_classes, mock_logger_info): schema = Schema(location="edo.xsd") classes = ClassFactory.list(2) mock_mapper_map.return_value = classes mock_count_classes.return_value = 2, 4 self.transformer.generate_classes(schema) mock_mapper_map.assert_called_once_with(schema) mock_logger_info.assert_has_calls([ mock.call("Compiling schema %s", schema.location), mock.call("Builder: %d main and %d inner classes", 2, 4), ]) def test_parse_schema(self): uri = Path(__file__).parent.joinpath( "../fixtures/books/schema.xsd").as_uri() schema = self.transformer.parse_schema(uri, "foo.bar") self.assertIsInstance(schema, Schema) self.assertEqual(2, len(schema.complex_types)) self.assertIsNone(self.transformer.parse_schema(uri, None)) # Once @mock.patch.object(SchemaTransformer, "process_schema") @mock.patch.object(Definitions, "merge") @mock.patch.object(DefinitionsParser, "from_bytes") @mock.patch.object(SchemaTransformer, "load_resource") def test_parse_definitions( self, mock_load_resource, mock_definitions_parser, mock_definitions_merge, mock_process_schema, ): def_one = Definitions(imports=[ Import(), Import(location="file://sub.wsdl"), Import(location="file://sub.wsdl"), Import(location="file://types.xsd"), ]) def_two = Definitions() mock_load_resource.side_effect = ["a", "b", None] mock_definitions_parser.side_effect = [def_one, def_two] actual = self.transformer.parse_definitions("main.wsdl", "fooNS") self.assertEqual(def_one, actual) mock_definitions_merge.assert_called_once_with(def_two) mock_process_schema.assert_called_once_with("file://types.xsd") @mock.patch("xsdata.codegen.transformer.logger.debug") def test_load_resource(self, mock_debug): path = Path(__file__).as_uri() result = self.transformer.load_resource(path) self.assertIn(path, self.transformer.processed) self.assertTrue(len(result) > 0) result = self.transformer.load_resource(path) self.assertIsNone(result) mock_debug.assert_called_once_with("Skipping already processed: %s", "test_transformer.py") def test_classify_resource(self): self.assertEqual( 0, self.transformer.classify_resource("file://notexists")) self.assertEqual(1, self.transformer.classify_resource("a.xsd")) self.assertEqual(2, self.transformer.classify_resource("a.wsdl")) self.assertEqual(2, self.transformer.classify_resource("a?wsdl")) self.assertEqual(3, self.transformer.classify_resource("a.xml")) self.assertEqual(4, self.transformer.classify_resource("a.json")) file_path = Path(tempfile.mktemp()) file_path.write_bytes(b"</xs:schema> \n") self.assertEqual( 1, self.transformer.classify_resource(file_path.as_uri())) file_path.write_bytes(b"</xs:definitions> \n") self.transformer.preloaded.clear() self.assertEqual( 2, self.transformer.classify_resource(file_path.as_uri())) file_path.write_bytes(b"</foobar> \n") self.transformer.preloaded.clear() self.assertEqual( 3, self.transformer.classify_resource(file_path.as_uri())) file_path.write_bytes(b"\n} \n") self.transformer.preloaded.clear() self.assertEqual( 4, self.transformer.classify_resource(file_path.as_uri())) file_path.write_bytes(b"aaa\n") self.transformer.preloaded.clear() self.assertEqual( 0, self.transformer.classify_resource(file_path.as_uri())) file_path.unlink() @mock.patch("xsdata.codegen.transformer.logger.warning") def test_load_resource_missing(self, mock_warning): uri = "file://foo/bar.xsd" result = self.transformer.load_resource(uri) self.assertIsNone(result) mock_warning.assert_called_once_with("Resource not found %s", uri) def test_count_classes(self): classes = ClassFactory.list(2, inner=ClassFactory.list( 2, inner=ClassFactory.list(3))) self.assertEqual((2, 16), self.transformer.count_classes(classes)) def test_assign_packages(self): core = "file://HL7V3/NE2008/coreschemas/voc.xsd" multi_one = "file://HL7V3/NE2008/multicacheschemas/PRPA_MT201307UV02.xsd" multi_two = "file://HL7V3/NE2008/multicacheschemas/COCT_MT080000UV.xsd" http_one = "http://xsdata/foo/bar/schema.xsd" http_two = "http://xsdata/foo/common.xsd" local_one = Namespace.XSI.location local_two = Namespace.XLINK.location class_map = { core: ClassFactory.list(1, inner=[ClassFactory.create()]), multi_one: ClassFactory.list(2), multi_two: ClassFactory.list(1), http_one: ClassFactory.list(1), http_two: ClassFactory.list(1), local_one: ClassFactory.list(1), local_two: ClassFactory.list(1), } self.transformer.class_map = class_map self.transformer.config.output.package = "foo.bar" self.transformer.assign_packages() self.assertEqual("foo.bar.coreschemas", class_map[core][0].package) self.assertEqual("foo.bar.coreschemas", class_map[core][0].inner[0].package) self.assertEqual("foo.bar.multicacheschemas", class_map[multi_one][0].package) self.assertEqual("foo.bar.multicacheschemas", class_map[multi_one][1].package) self.assertEqual("foo.bar.multicacheschemas", class_map[multi_two][0].package) self.assertEqual("foo.bar.bar", class_map[http_one][0].package) self.assertEqual("foo.bar", class_map[http_two][0].package) self.assertEqual("foo.bar", class_map[local_one][0].package) self.assertEqual("foo.bar", class_map[local_two][0].package) @mock.patch.object(ClassAnalyzer, "process") def test_analyze_classes(self, mock_process): classes = ClassFactory.list(2) mock_process.return_value = classes[1:] result = self.transformer.analyze_classes(classes) self.assertEqual(1, len(result)) actual = mock_process.call_args[0][0] self.assertIsInstance(actual, ClassContainer) self.assertEqual(2, len(actual.data)) self.assertEqual(self.transformer.config, actual.config)