Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Updates Dart test template to use the first enum value for string properties with enums when generating test data, instead of always using the example value. This ensures generated test data is valid for properties with restricted enum values.
What does this PR do?
This PR updates the Dart SDK test generation template (
service_test.dart.twig) to properly handle enum properties in generated test mocks. Previously, all string properties usedproperty.exampleas mock values, which could lead to invalid enum values causing "Bad state: No element" errors in model constructors likeMessage.fromMapwhen the example value didn't match any enum option.The change adds conditional logic for string properties:
property.enum[0]) as the mock valueproperty.exampleas beforeThis ensures that generated tests use valid enum values for properties with enums, preventing runtime errors during test execution.
Test Plan
regenerate sdk and run dart test
also push changes and ensure the GitHub Actions workflow for Dart SDK completes successfully with all tests passing. #1247
before:



after:
Have you read the Contributing Guidelines on issues?
Yes
Summary by CodeRabbit