Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(typescript): alias imported types in (de)serialization schemas #5085

Open
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

mstade
Copy link
Contributor

@mstade mstade commented Nov 3, 2024

This fixes an issue where a type imported in a (de)serialization schema has the same name as the exported schema, causing build errors.

Without this fix, we'd have schemas generated looking like so:

/**
 * This file was auto-generated by Fern from our API Definition.
 */

import * as serializers from "../../../index";
import * as Engine from "../../../../api/index";
import * as core from "../../../../core";
import { SecurityFinding } from "../../ocsf/resources/v110/resources/securityfinding/resources/classes/types/SecurityFinding";

export const SecurityFinding: core.serialization.ObjectSchema<serializers.SecurityFinding.Raw, Engine.SecurityFinding> = SecurityFinding;

export declare namespace SecurityFinding {
    type Raw = SecurityFinding.Raw;
}

The imported SecurityFinding type shares the same name as the serialization schema, which then causes build errors that are hard and awkward to fix in post processing of the generated source code.

After this fix, the generated code looks like so:

/**
 * This file was auto-generated by Fern from our API Definition.
 */

import * as serializers from "../../../index";
import * as Engine from "../../../../api/index";
import * as core from "../../../../core";
import { SecurityFinding as SecurityFindingType } from "../../ocsf/resources/v110/resources/securityfinding/resources/classes/types/SecurityFinding";

export const SecurityFinding: core.serialization.ObjectSchema<serializers.SecurityFinding.Raw, Engine.SecurityFinding> = SecurityFindingType;

export declare namespace SecurityFinding {
    type Raw = SecurityFindingType.Raw;
}

The added Type suffix ensures the names do not conflict, solving any build issues that would otherwise arise.

@coderabbitai summary

This fixes an issue where a type imported in a (de)serialization schema has
the same name as the exported schema, causing build errors.

Without this fix, we'd have schemas generated looking like so:

```ts
/**
 * This file was auto-generated by Fern from our API Definition.
 */

import * as serializers from "../../../index";
import * as Engine from "../../../../api/index";
import * as core from "../../../../core";
import { SecurityFinding } from "../../ocsf/resources/v110/resources/securityfinding/resources/classes/types/SecurityFinding";

export const SecurityFinding: core.serialization.ObjectSchema<serializers.SecurityFinding.Raw, Engine.SecurityFinding> = SecurityFinding;

export declare namespace SecurityFinding {
    type Raw = SecurityFinding.Raw;
}
```

The imported `SecurityFinding` type shares the same name as the
serialization schema, which then causes build errors that are hard and
awkward to fix in post processing of the generated source code.

After this fix, the generated code looks like so:

```ts
/**
 * This file was auto-generated by Fern from our API Definition.
 */

import * as serializers from "../../../index";
import * as Engine from "../../../../api/index";
import * as core from "../../../../core";
import { SecurityFinding as SecurityFindingType } from "../../ocsf/resources/v110/resources/securityfinding/resources/classes/types/SecurityFinding";

export const SecurityFinding: core.serialization.ObjectSchema<serializers.SecurityFinding.Raw, Engine.SecurityFinding> = SecurityFindingType;

export declare namespace SecurityFinding {
    type Raw = SecurityFindingType.Raw;
}
```

The added `Type` suffix ensures the names do not conflict, solving any build
issues that would otherwise arise.
@mstade mstade requested a review from dsinghvi as a code owner November 3, 2024 22:27
Copy link
Contributor Author

@mstade mstade left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Author Notes

@dsinghvi we've been stuck on v 0.12.7 of the TS SDK for some time due to this issue. I believe the issue was introduced with #3206, but the changes there seem sound and does improve performance. The changes I'm proposing here does not seem to break anything else in our project, but I have to admit all the indirection in this project made it extremely hard to even pinpoint where the issue is introduced, let alone trying to fix it.

This seems like a safe change to make, but your guidance here is much appreciated.

@@ -146,7 +146,7 @@ export class TypeSchemaContextImpl implements TypeSchemaContext {
useDynamicImport: false,
namespaceImport: "serializers"
}
: { type: "direct" },
: { type: "direct", alias: `${typeName.name.originalName}Type` },
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The alias here is identical to the alias on line 178. If they aren't the same type is imported twice, with different aliases. (Or indeed, if no alias is specified with the conflicting name.)

@@ -175,7 +175,7 @@ export class TypeSchemaContextImpl implements TypeSchemaContext {
return { type: "fromRoot", useDynamicImport: false, namespaceImport: "serializers" };
} else if (isGeneratingSchema) {
// Return default import strategy or another strategy based on your logic
return { type: "direct" };
return { type: "direct", alias: `${typeName.name.originalName}Type` };
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See previous comment about line 149, and the aliases being identical. It may be meaningful to extract this into a utility function to make this less prone to breakage. On the other hand, importing the same type twice with different aliases isn't going to break anything, even if it is redundant.

@mstade
Copy link
Contributor Author

mstade commented Nov 3, 2024

The failed preview-docs / run (pull_request) check does not seem to be related to these changes, unless I'm missing something, here's the error message:

Failed to read markdown file "../snippets/peace-lily.mdx" referenced in /home/runner/work/fern/fern/fern/pages/fern-docs/content/reusable-snippets.mdx

@mstade
Copy link
Contributor Author

mstade commented Nov 3, 2024

The failed seed / typescript-sdk (pull_request) check however does seem related to these changes. Looks like the test snapshots need updating. I've tried running pnpm test:update but alas, it fails with errors like:

Missing required dependency; please install 'protoc-gen-openapi' to continue (e.g. 'brew install go && go install github…

The error message is cut, but not when trying to run tests in which case it says to run:

brew install go && go install github.com/google/gnostic/cmd/protoc-gen-openapi@latest

I did try this, but to no avail. I'm not quite sure how to update these snapshots now.

@mstade
Copy link
Contributor Author

mstade commented Nov 6, 2024

@dsinghvi I wonder if maybe you have some insights into how I may update the snapshots?

@mstade
Copy link
Contributor Author

mstade commented Nov 12, 2024

@dsinghvi do you think there's any value in this change?

It fixes a very real issue in production but of course if this is the wrong approach or a won't fix I'd be happy to receive such feedback so we can adjust accordingly.

Copy link

@mstade
Copy link
Contributor Author

mstade commented Dec 11, 2024

@dsinghvi do you think there's any value in this change?

It fixes a very real issue in production but of course if this is the wrong approach or a won't fix I'd be happy to receive such feedback so we can adjust accordingly.

@amckinney apologies if you're not the right person to ping, I just saw your comment on #3453 and figured since I've not been able to get a response from @dsinghvi maybe you could help? Is this PR worth pursuing you think, or should we resolve this issue some other way and if so would you be able to provide guidance?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

Successfully merging this pull request may close these issues.

2 participants