From 8f6c405408a40c5d6c28e93d81b4595327f9f052 Mon Sep 17 00:00:00 2001 From: Honza Dvorsky Date: Mon, 6 Jan 2025 13:16:32 +0100 Subject: [PATCH 1/2] [Cleanup] Make Config's namingStrategy and accessModifier params consistent --- Sources/_OpenAPIGeneratorCore/Config.swift | 2 +- .../CompatabilityTest.swift | 4 ++-- .../SnippetBasedReferenceTests.swift | 15 ++++++++++----- 3 files changed, 13 insertions(+), 8 deletions(-) diff --git a/Sources/_OpenAPIGeneratorCore/Config.swift b/Sources/_OpenAPIGeneratorCore/Config.swift index 8aa16af5..b4953742 100644 --- a/Sources/_OpenAPIGeneratorCore/Config.swift +++ b/Sources/_OpenAPIGeneratorCore/Config.swift @@ -79,7 +79,7 @@ public struct Config: Sendable { access: AccessModifier, additionalImports: [String] = [], filter: DocumentFilter? = nil, - namingStrategy: NamingStrategy = Config.defaultNamingStrategy, + namingStrategy: NamingStrategy, nameOverrides: [String: String] = [:], featureFlags: FeatureFlags = [] ) { diff --git a/Tests/OpenAPIGeneratorReferenceTests/CompatabilityTest.swift b/Tests/OpenAPIGeneratorReferenceTests/CompatabilityTest.swift index e8b9b357..5b96751b 100644 --- a/Tests/OpenAPIGeneratorReferenceTests/CompatabilityTest.swift +++ b/Tests/OpenAPIGeneratorReferenceTests/CompatabilityTest.swift @@ -254,7 +254,7 @@ fileprivate extension CompatibilityTest { for mode in GeneratorMode.allCases { group.addTask { let generator = makeGeneratorPipeline( - config: Config(mode: mode, access: .public), + config: Config(mode: mode, access: .public, namingStrategy: .defensive), diagnostics: diagnosticsCollector ) return try assertNoThrowWithValue(generator.run(input)) @@ -265,7 +265,7 @@ fileprivate extension CompatibilityTest { } else { outputs = try GeneratorMode.allCases.map { mode in let generator = makeGeneratorPipeline( - config: Config(mode: mode, access: .public), + config: Config(mode: mode, access: .public, namingStrategy: .defensive), diagnostics: diagnosticsCollector ) return try assertNoThrowWithValue(generator.run(input)) diff --git a/Tests/OpenAPIGeneratorReferenceTests/SnippetBasedReferenceTests.swift b/Tests/OpenAPIGeneratorReferenceTests/SnippetBasedReferenceTests.swift index 64b30763..0ddd7b5e 100644 --- a/Tests/OpenAPIGeneratorReferenceTests/SnippetBasedReferenceTests.swift +++ b/Tests/OpenAPIGeneratorReferenceTests/SnippetBasedReferenceTests.swift @@ -5868,7 +5868,7 @@ extension SnippetBasedReferenceTests { func makeTypesTranslator(openAPIDocumentYAML: String) throws -> TypesFileTranslator { let document = try YAMLDecoder().decode(OpenAPI.Document.self, from: openAPIDocumentYAML) return TypesFileTranslator( - config: Config(mode: .types, access: .public), + config: Config(mode: .types, access: .public, namingStrategy: .defensive), diagnostics: XCTestDiagnosticCollector(test: self), components: document.components ) @@ -5901,7 +5901,12 @@ extension SnippetBasedReferenceTests { components: OpenAPI.Components = .noComponents ) throws -> TypesFileTranslator { TypesFileTranslator( - config: Config(mode: .types, access: accessModifier, featureFlags: featureFlags), + config: Config( + mode: .types, + access: accessModifier, + namingStrategy: .defensive, + featureFlags: featureFlags + ), diagnostics: XCTestDiagnosticCollector(test: self, ignoredDiagnosticMessages: ignoredDiagnosticMessages), components: components ) @@ -5915,17 +5920,17 @@ extension SnippetBasedReferenceTests { let collector = XCTestDiagnosticCollector(test: self, ignoredDiagnosticMessages: ignoredDiagnosticMessages) return ( TypesFileTranslator( - config: Config(mode: .types, access: .public, featureFlags: featureFlags), + config: Config(mode: .types, access: .public, namingStrategy: .defensive, featureFlags: featureFlags), diagnostics: collector, components: components ), ClientFileTranslator( - config: Config(mode: .client, access: .public, featureFlags: featureFlags), + config: Config(mode: .client, access: .public, namingStrategy: .defensive, featureFlags: featureFlags), diagnostics: collector, components: components ), ServerFileTranslator( - config: Config(mode: .server, access: .public, featureFlags: featureFlags), + config: Config(mode: .server, access: .public, namingStrategy: .defensive, featureFlags: featureFlags), diagnostics: collector, components: components ) From b2018c49e8d06d80c4d73b8731d5105024ee8edc Mon Sep 17 00:00:00 2001 From: Honza Dvorsky Date: Mon, 6 Jan 2025 14:08:32 +0100 Subject: [PATCH 2/2] Fixup tests --- .../Parser/Test_YamsParser.swift | 6 +++++- .../Parser/Test_validateDoc.swift | 20 +++++++++++++++++-- .../Test_isSchemaSupported.swift | 6 +++++- 3 files changed, 28 insertions(+), 4 deletions(-) diff --git a/Tests/OpenAPIGeneratorCoreTests/Parser/Test_YamsParser.swift b/Tests/OpenAPIGeneratorCoreTests/Parser/Test_YamsParser.swift index f7638d87..f7e73d81 100644 --- a/Tests/OpenAPIGeneratorCoreTests/Parser/Test_YamsParser.swift +++ b/Tests/OpenAPIGeneratorCoreTests/Parser/Test_YamsParser.swift @@ -165,7 +165,11 @@ final class Test_YamsParser: Test_Core { try YamsParser() .parseOpenAPI( .init(absolutePath: URL(fileURLWithPath: "/foo.yaml"), contents: Data(yaml.utf8)), - config: .init(mode: .types, access: Config.defaultAccessModifier), + config: .init( + mode: .types, + access: Config.defaultAccessModifier, + namingStrategy: Config.defaultNamingStrategy + ), diagnostics: PrintingDiagnosticCollector() ) } diff --git a/Tests/OpenAPIGeneratorCoreTests/Parser/Test_validateDoc.swift b/Tests/OpenAPIGeneratorCoreTests/Parser/Test_validateDoc.swift index c1e92cd3..ea194aed 100644 --- a/Tests/OpenAPIGeneratorCoreTests/Parser/Test_validateDoc.swift +++ b/Tests/OpenAPIGeneratorCoreTests/Parser/Test_validateDoc.swift @@ -31,7 +31,14 @@ final class Test_validateDoc: Test_Core { paths: [:], components: .init(schemas: ["myImperfectSchema": schemaWithWarnings]) ) - let diagnostics = try validateDoc(doc, config: .init(mode: .types, access: Config.defaultAccessModifier)) + let diagnostics = try validateDoc( + doc, + config: .init( + mode: .types, + access: Config.defaultAccessModifier, + namingStrategy: Config.defaultNamingStrategy + ) + ) XCTAssertEqual(diagnostics.count, 1) } @@ -53,7 +60,16 @@ final class Test_validateDoc: Test_Core { ], components: .noComponents ) - XCTAssertThrowsError(try validateDoc(doc, config: .init(mode: .types, access: Config.defaultAccessModifier))) + XCTAssertThrowsError( + try validateDoc( + doc, + config: .init( + mode: .types, + access: Config.defaultAccessModifier, + namingStrategy: Config.defaultNamingStrategy + ) + ) + ) } func testValidateContentTypes_validContentTypes() throws { diff --git a/Tests/OpenAPIGeneratorCoreTests/Translator/TypeAssignment/Test_isSchemaSupported.swift b/Tests/OpenAPIGeneratorCoreTests/Translator/TypeAssignment/Test_isSchemaSupported.swift index 0eec0b9e..d429a30c 100644 --- a/Tests/OpenAPIGeneratorCoreTests/Translator/TypeAssignment/Test_isSchemaSupported.swift +++ b/Tests/OpenAPIGeneratorCoreTests/Translator/TypeAssignment/Test_isSchemaSupported.swift @@ -19,7 +19,11 @@ class Test_isSchemaSupported: XCTestCase { var translator: any FileTranslator { TypesFileTranslator( - config: .init(mode: .types, access: Config.defaultAccessModifier), + config: .init( + mode: .types, + access: Config.defaultAccessModifier, + namingStrategy: Config.defaultNamingStrategy + ), diagnostics: PrintingDiagnosticCollector(), components: .init(schemas: [ "Foo": .string, "MyObj": .object, "MyObj2": .object,