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

test(core): catch type issues when configuring from external json #14101

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

Conversation

ashwinkumar6
Copy link
Member

@ashwinkumar6 ashwinkumar6 commented Dec 27, 2024

Description of changes

  • Bug fix
    • Update AmplifyOutputs authentication_flow_type type from string literal union to string
  • Test
    • Ensure amplify_outputs.json has all combinations defined, else throw type error (CI failure)
    • Ensure TS inferred shape from external json does not throw type issues with Amplify.configure (CI failure)

Description of how you validated changes

linked ^

Checklist

  • PR description included
  • yarn test passes
  • Unit Tests are changed or added
  • Relevant documentation is changed or added (and PR referenced)

Checklist for repo maintainers

  • Verify E2E tests for existing workflows are working as expected or add E2E tests for newly added workflows
  • New source file paths included in this PR have been added to CODEOWNERS, if appropriate

By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.

Comment on lines +178 to +180
// Ensures that all optional properties in mockAmplifyOutputs are defined
const _amplifyOutputs: DeepRequired<AmplifyOutputs> =
recreateObject(mockAmplifyOutputs);
Copy link
Member

Choose a reason for hiding this comment

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

Didn't quite get this - are we validating all possible fields are contained in the amplify_outputs.json file?

Copy link
Member Author

Choose a reason for hiding this comment

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

Yep exactly, when a new optional key is added in AmplifyOutputs we want to make sure the mockAmplifyOutputs used here is also updated to include this field. With this approach if amplify_outputs isn't updated this line would crib

Copy link
Member

Choose a reason for hiding this comment

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

Got it. amplify_outputs.json will be updated manually? Is there any checks too that the manual update conforms to CLI JSON schema?

Copy link
Member

Choose a reason for hiding this comment

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

+1 we need to figure out a way to make sure our outputs.json conforms to CLI schema.Might be out of scope for this PR.

"require_symbols": true,
"min_length": 6
},
"groups": [
Copy link
Member Author

@ashwinkumar6 ashwinkumar6 Dec 30, 2024

Choose a reason for hiding this comment

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

this was previously

			{
				"ADMIN": { "precedence": 0 },
				"USER": { "precedence": 1 }
			},
			{
				"USER": { "precedence": 0 }
			},
			{
				"TEST": { "precedence": 2 },
				"USER": { "precedence": 1 },
				"ADMIN": { "precedence": 0 }
			}

since backend can only generate one userGroup as one item in the array atm, updated to this format.

@ashika112
Copy link
Member

One Major comment I have for this approach is this will only catch us from missing addition of optional properties in amplify_outputs. It does not catch the core issue on if the value we provide for these properties actually causes an issue or not.

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

Successfully merging this pull request may close these issues.

4 participants