-
Notifications
You must be signed in to change notification settings - Fork 594
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
Why is everything possibly undefined? (& other typing/doc questions) #1613
Comments
One thing I would add to this, the same is true for command inputs, random example: export interface BatchDetectDominantLanguageRequest {
/**
* <p>A list containing the text of the input documents. The list can contain a maximum of 25
* documents. Each document should contain at least 20 characters and must contain fewer than
* 5,000 bytes of UTF-8 encoded characters.</p>
*/
TextList: string[] | undefined;
} While the documentation for the API clearly marks that |
Hi @mipearson Regarding the API reference, we just published the v3 API reference here: https://docs.aws.amazon.com/AWSJavaScriptSDK/v3/latest/index.html We are still working on to polishing it, please feel free to open issues if you have any questions or feedbacks. |
Taking a closer look, and with // Note: not from the code
type CreateFunctionRequest = {
Handler?: string;
Code: FunctionCode | undefined;
}; In practice, Would it be possible to generate code that reflects it? type CreateFunctionRequest = {
Handler: string;
Code?: FunctionCode;
}; |
Which seems to come from here: https://github.com/awslabs/smithy-typescript/blob/master/smithy-typescript-codegen/src/main/java/software/amazon/smithy/typescript/codegen/StructuredMemberWriter.java#L64 String optionalSuffix = shape.isUnionShape() || !isRequiredMember(member) ? "?" : "";
String typeSuffix = isRequiredMember(member) ? " | undefined" : ""; It's really not convenient the way it works right now, e.g.: // given this (where Handler is @required and Code is optional)
type CreateFunctionRequest = {
Handler?: string;
Code: FunctionCode | undefined;
};
// you can do this:
const test: CreateFunctionRequest = {
Code: undefined
}; And even if you pass |
I've come across this issue as well while using the textract client. For example:
That object cannot logically exist without all those fields defined. If you're using typescript this causes code that is much more unnecessarily verbose, having to check all the members for undefined. |
Yeah, I end up abusing |
This is what my sources are littered with: // FIXME: https://github.com/aws/aws-sdk-js-v3/issues/1613
type BatchDetectDominantLanguageCommandInputFixed = BatchDetectDominantLanguageCommandInput & {
TextList: NonNullable<BatchDetectDominantLanguageCommandInput['TextList']>;
} (which could be turned into a |
I just wanted to mention that The Go API Reference states that that fields are required. Perhaps parsing that reference could eliminate Is there any motivation for keeping the |
This is the same issue as aws/aws-sdk-js#1553 which was not addressed in v2 JS SDK. It looks like AWS don't clearly document which fields are mandatory, particularly on output models, so the SDK just presents all fields as optional. This introduces a lot of risk of potential bugs (should we be expected to check that each field in the output model is defined?) and significantly hurts developers working in TS. To see such a major bug unresolved for almost 5 years is concerning |
I've raised this issue myself before, and was told:
|
Ridiculous! Making all output fields optional so that they can remove them in future versions without breaking the API is just wrong. If the field is important, I will need to change my code when you stop sending the field - this is a breaking change in my app. By making important output fields optional you are actually making things worse because my code will still compile when you stop populating it! I'm going to have to use a non-null assertion every time I use an AWS output field and my downstream code will just break if/when they stop sending it. I have no other choice (the only other option I have is to check whether an important field is null and it is, all I can do is throw an error). |
So, coming back to this topic, I understand there is a rationale behind the current behavior (and changing it would be a breaking change). How about having a flag that can be passed when doing a |
Hi @rraziel This @trivikr's comment explains the rationales of the |
As an extension of this, This is the whole point in using versioning in the first place. As consumers we lock to particular versions to ensure compatibility. When we upgrade we acknowledge that the code we are using may change and that our code will need to change to accomodate it. By saying "well we may change the code in the future" you may as well save yourselves the trouble and just distribute a single version of the code as theres no benefit to having versioning behind this reasoning. Your even including fields that are inherently required by the backend for it to be able to function, which doesnt make sense. My example being the ListTagsForResourceCommandInput. That function has a requirement for a resource arn parameter, even though the input parameter to be undefined. Pretty much defeats the purpose of a strongly typed language. The DescribeLogGroupsCommandOutput even returns a LogGroup array where even field is optional. The backend cant function without having an ARN, so why are we expected to validate its existense. |
Also chiming in, currently migrating to @aws-sdk/* and this is a MAJOR pain, why was this done? This almost seems like someone saw protobuff and only took the bad parts. You segmented clients into smaller packages, if the api changes make breaking changes, don't create completely arbitrary api constraints just so you can claim 'technically not a breaking change :)' later. |
I just encountered this too, using EventBridge Scheduler and trying to update an existing schedule. Also, why does e.g. the UpdateScheduleCommand page show which input fields are required, but the linked UpdateScheduleCommandInput page doesn't? |
Hi everyone on the thread. To improve the typescript experience, we added a new feature, you can now cast your client to be an UncheckedClient or AssertiveClient from Smithy-Typescript package. Just be mindful that using UncheckedClient eliminates compiler-generated nullability warnings for output fields by treating them as non-nullable. You should still perform manual type checks as necessary for your application's specific needs. further discussion on this was done here #5992 Since this should address the original concern of removing the " | undefined" I'm going to close this issue and also lock it. Thanks again for your patience and for staying active. |
I've been trying to work out how some of these things are intended to be used and having trouble.
Why are all fields possibly undefined?
eg (doc comments removed:
Is the expectation that we should be putting in guard clauses for every API response, including ones that don't return an error, for things that the APIs are expected to return?
How do we use .config.* properties?
Some code naively ported from V2:
ecs.config.region
above is typed asProvider<string> | (string & Provider<string>)
(which rightfully produces a warning with eslint about embedding it in a template string). Looking atProvider
, it looks like it's a promise wrapper. Are we supposed to check viatypeof
to see if it's a function or a string, andawait
it if it's a function?Where are the SDK docs?
I've been relying on intellisense & manually reading the type definitions, but it'd be nice if AWS hosted a typedoc of the various packages.
The text was updated successfully, but these errors were encountered: