|
24 | 24 | import org.openapitools.codegen.CodegenModel; |
25 | 25 | import org.openapitools.codegen.CodegenProperty; |
26 | 26 | import org.openapitools.codegen.DefaultCodegen; |
| 27 | +import org.openapitools.codegen.InlineModelResolver; |
27 | 28 | import org.openapitools.codegen.TestUtils; |
28 | 29 | import org.openapitools.codegen.languages.GoClientCodegen; |
| 30 | +import org.openapitools.codegen.model.ModelMap; |
| 31 | +import org.openapitools.codegen.model.ModelsMap; |
29 | 32 | import org.testng.Assert; |
30 | 33 | import org.testng.annotations.DataProvider; |
31 | 34 | import org.testng.annotations.Test; |
32 | 35 |
|
33 | 36 | import java.io.File; |
| 37 | +import java.util.ArrayList; |
| 38 | +import java.util.Arrays; |
34 | 39 |
|
35 | 40 | @SuppressWarnings("static-method") |
36 | 41 | public class GoModelTest { |
@@ -324,4 +329,168 @@ public void modelNameMappingsTest(String name, String expectedName, String expec |
324 | 329 | Assert.assertEquals(cm.name, name); |
325 | 330 | Assert.assertEquals(cm.classname, expectedName); |
326 | 331 | } |
| 332 | + |
| 333 | + @Test(description = "test that direct $ref usage does NOT create aliases") |
| 334 | + public void directRefNoAliasTest() { |
| 335 | + final Schema phoneNumberSchema = new Schema() |
| 336 | + .type("object") |
| 337 | + .addProperty("countryCode", new StringSchema()) |
| 338 | + .addProperty("number", new StringSchema()) |
| 339 | + .addRequiredItem("number"); |
| 340 | + |
| 341 | + final Schema personSchema = new Schema() |
| 342 | + .type("object") |
| 343 | + .addProperty("name", new StringSchema()) |
| 344 | + .addProperty("mobile", new Schema().$ref("#/components/schemas/PhoneNumber")) |
| 345 | + .addProperty("home", new Schema().$ref("#/components/schemas/PhoneNumber")) |
| 346 | + .addRequiredItem("name"); |
| 347 | + |
| 348 | + final DefaultCodegen codegen = new GoClientCodegen(); |
| 349 | + OpenAPI openAPI = TestUtils.createOpenAPI(); |
| 350 | + openAPI.getComponents().addSchemas("PhoneNumber", phoneNumberSchema); |
| 351 | + openAPI.getComponents().addSchemas("Person", personSchema); |
| 352 | + codegen.setOpenAPI(openAPI); |
| 353 | + |
| 354 | + final CodegenModel personModel = codegen.fromModel("Person", personSchema); |
| 355 | + Assert.assertEquals(personModel.name, "Person"); |
| 356 | + Assert.assertEquals(personModel.vars.size(), 3); |
| 357 | + |
| 358 | + // Direct $refs should not have aliases (only deduplicated inline schemas get aliases) |
| 359 | + final CodegenProperty mobileProperty = personModel.vars.stream() |
| 360 | + .filter(v -> v.baseName.equals("mobile")) |
| 361 | + .findFirst() |
| 362 | + .orElse(null); |
| 363 | + Assert.assertNotNull(mobileProperty); |
| 364 | + Assert.assertNull(mobileProperty.dataTypeAlias); |
| 365 | + Assert.assertEquals(mobileProperty.dataType, "PhoneNumber"); |
| 366 | + |
| 367 | + final CodegenProperty homeProperty = personModel.vars.stream() |
| 368 | + .filter(v -> v.baseName.equals("home")) |
| 369 | + .findFirst() |
| 370 | + .orElse(null); |
| 371 | + Assert.assertNotNull(homeProperty); |
| 372 | + Assert.assertNull(homeProperty.dataTypeAlias); |
| 373 | + Assert.assertEquals(homeProperty.dataType, "PhoneNumber"); |
| 374 | + } |
| 375 | + |
| 376 | + @Test(description = "test type aliases for deduplicated inline schemas") |
| 377 | + public void typeAliasForDeduplicatedInlineSchemasTest() { |
| 378 | + final OpenAPI openAPI = TestUtils.parseFlattenSpec("src/test/resources/3_0/inline-deduplicated-schemas.yaml"); |
| 379 | + final GoClientCodegen codegen = new GoClientCodegen(); |
| 380 | + codegen.setOpenAPI(openAPI); |
| 381 | + |
| 382 | + Schema demoResponseSchema = openAPI.getComponents().getSchemas().get("DemoResponse"); |
| 383 | + CodegenModel demoModel = codegen.fromModel("DemoResponse", demoResponseSchema); |
| 384 | + |
| 385 | + // Call postProcessModels to trigger Go-specific dataType/dataTypeAlias swapping |
| 386 | + ModelsMap modelsMap = new ModelsMap(); |
| 387 | + ModelMap modelMap = new ModelMap(); |
| 388 | + modelMap.setModel(demoModel); |
| 389 | + modelsMap.setModels(Arrays.asList(modelMap)); |
| 390 | + modelsMap.setImports(new ArrayList<>()); |
| 391 | + modelsMap = codegen.postProcessModels(modelsMap); |
| 392 | + demoModel = modelsMap.getModels().get(0).getModel(); |
| 393 | + |
| 394 | + Assert.assertEquals(demoModel.name, "DemoResponse"); |
| 395 | + |
| 396 | + // inlinePhone1 is the original (not deduplicated) |
| 397 | + final CodegenProperty inlinePhone1 = demoModel.vars.stream() |
| 398 | + .filter(v -> v.baseName.equals("inlinePhone1")) |
| 399 | + .findFirst() |
| 400 | + .orElse(null); |
| 401 | + Assert.assertNotNull(inlinePhone1); |
| 402 | + Assert.assertNull(inlinePhone1.dataTypeAlias); |
| 403 | + Assert.assertEquals(inlinePhone1.dataType, "DemoResponseInlinePhone1"); |
| 404 | + |
| 405 | + // inlinePhone2 is deduplicated with inlinePhone1 |
| 406 | + final CodegenProperty inlinePhone2 = demoModel.vars.stream() |
| 407 | + .filter(v -> v.baseName.equals("inlinePhone2")) |
| 408 | + .findFirst() |
| 409 | + .orElse(null); |
| 410 | + Assert.assertNotNull(inlinePhone2); |
| 411 | + Assert.assertNotNull(inlinePhone2.dataTypeAlias); |
| 412 | + Assert.assertEquals(inlinePhone2.dataType, "DemoResponseInlinePhone2"); |
| 413 | + Assert.assertEquals(inlinePhone2.dataTypeAlias, "DemoResponseInlinePhone1"); |
| 414 | + |
| 415 | + // nestedPhones array items are deduplicated |
| 416 | + final CodegenProperty nestedPhones = demoModel.vars.stream() |
| 417 | + .filter(v -> v.baseName.equals("nestedPhones")) |
| 418 | + .findFirst() |
| 419 | + .orElse(null); |
| 420 | + Assert.assertNotNull(nestedPhones); |
| 421 | + Assert.assertTrue(nestedPhones.isContainer); |
| 422 | + Assert.assertNotNull(nestedPhones.items); |
| 423 | + Assert.assertNotNull(nestedPhones.items.dataTypeAlias); |
| 424 | + Assert.assertEquals(nestedPhones.items.dataType, "DemoResponseNestedPhonesInner"); |
| 425 | + Assert.assertEquals(nestedPhones.items.dataTypeAlias, "DemoResponseInlinePhone1"); |
| 426 | + Assert.assertEquals(nestedPhones.dataType, "[]DemoResponseNestedPhonesInner"); |
| 427 | + |
| 428 | + // phoneHistory array items are deduplicated |
| 429 | + final CodegenProperty phoneHistory = demoModel.vars.stream() |
| 430 | + .filter(v -> v.baseName.equals("phoneHistory")) |
| 431 | + .findFirst() |
| 432 | + .orElse(null); |
| 433 | + Assert.assertNotNull(phoneHistory); |
| 434 | + Assert.assertTrue(phoneHistory.isContainer); |
| 435 | + Assert.assertNotNull(phoneHistory.items); |
| 436 | + Assert.assertNotNull(phoneHistory.items.dataTypeAlias); |
| 437 | + Assert.assertEquals(phoneHistory.items.dataType, "DemoResponsePhoneHistoryInner"); |
| 438 | + Assert.assertEquals(phoneHistory.items.dataTypeAlias, "DemoResponseInlinePhone1"); |
| 439 | + Assert.assertEquals(phoneHistory.dataType, "[]DemoResponsePhoneHistoryInner"); |
| 440 | + |
| 441 | + // optionalNumber has different structure (no required fields) |
| 442 | + final CodegenProperty optionalNumber = demoModel.vars.stream() |
| 443 | + .filter(v -> v.baseName.equals("optionalNumber")) |
| 444 | + .findFirst() |
| 445 | + .orElse(null); |
| 446 | + Assert.assertNotNull(optionalNumber); |
| 447 | + Assert.assertNull(optionalNumber.dataTypeAlias); |
| 448 | + Assert.assertEquals(optionalNumber.dataType, "DemoResponseOptionalNumber"); |
| 449 | + |
| 450 | + // requiredNumber is deduplicated with inlinePhone1 |
| 451 | + final CodegenProperty requiredNumber = demoModel.vars.stream() |
| 452 | + .filter(v -> v.baseName.equals("requiredNumber")) |
| 453 | + .findFirst() |
| 454 | + .orElse(null); |
| 455 | + Assert.assertNotNull(requiredNumber); |
| 456 | + Assert.assertNotNull(requiredNumber.dataTypeAlias); |
| 457 | + Assert.assertEquals(requiredNumber.dataType, "DemoResponseRequiredNumber"); |
| 458 | + Assert.assertEquals(requiredNumber.dataTypeAlias, "DemoResponseInlinePhone1"); |
| 459 | + |
| 460 | + // transactOptions array items are deduplicated (MapSchema with additionalProperties: true) |
| 461 | + final CodegenProperty transactOptions = demoModel.vars.stream() |
| 462 | + .filter(v -> v.baseName.equals("transactOptions")) |
| 463 | + .findFirst() |
| 464 | + .orElse(null); |
| 465 | + Assert.assertNotNull(transactOptions); |
| 466 | + Assert.assertTrue(transactOptions.isContainer); |
| 467 | + Assert.assertNotNull(transactOptions.items); |
| 468 | + // transactOptions is the ORIGINAL, so items should NOT have dataTypeAlias |
| 469 | + Assert.assertNull(transactOptions.items.dataTypeAlias); |
| 470 | + Assert.assertEquals(transactOptions.items.dataType, "DemoResponseTransactOptionsInner"); |
| 471 | + Assert.assertEquals(transactOptions.dataType, "[]DemoResponseTransactOptionsInner"); |
| 472 | + |
| 473 | + // otherOptions array items are DEDUPLICATED with transactOptions (MapSchema with additionalProperties: true) |
| 474 | + final CodegenProperty otherOptions = demoModel.vars.stream() |
| 475 | + .filter(v -> v.baseName.equals("otherOptions")) |
| 476 | + .findFirst() |
| 477 | + .orElse(null); |
| 478 | + Assert.assertNotNull(otherOptions); |
| 479 | + Assert.assertTrue(otherOptions.isContainer); |
| 480 | + Assert.assertNotNull(otherOptions.items); |
| 481 | + Assert.assertNotNull(otherOptions.items.dataTypeAlias); |
| 482 | + Assert.assertEquals(otherOptions.items.dataType, "DemoResponseOtherOptionsInner"); |
| 483 | + Assert.assertEquals(otherOptions.items.dataTypeAlias, "DemoResponseTransactOptionsInner"); |
| 484 | + Assert.assertEquals(otherOptions.dataType, "[]DemoResponseOtherOptionsInner"); |
| 485 | + |
| 486 | + // directMapObject is DEDUPLICATED with transactOptions items (MapSchema with additionalProperties: true) |
| 487 | + final CodegenProperty directMapObject = demoModel.vars.stream() |
| 488 | + .filter(v -> v.baseName.equals("directMapObject")) |
| 489 | + .findFirst() |
| 490 | + .orElse(null); |
| 491 | + Assert.assertNotNull(directMapObject); |
| 492 | + Assert.assertNotNull(directMapObject.dataTypeAlias); |
| 493 | + Assert.assertEquals(directMapObject.dataType, "DemoResponseDirectMapObject"); |
| 494 | + Assert.assertEquals(directMapObject.dataTypeAlias, "DemoResponseTransactOptionsInner"); |
| 495 | + } |
327 | 496 | } |
0 commit comments