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

feat: Update in-process resolver to support flag metadata #1102 #1122

Draft
wants to merge 14 commits into
base: main
Choose a base branch
from

Conversation

chrfwow
Copy link

@chrfwow chrfwow commented Jan 2, 2025

This PR

Adds support for flag metadata in the in-process resolver

Related Issues

Fixes #1102

return fallBackMetadata;
}

ImmutableMetadata.ImmutableMetadataBuilder metadataBuilder = ImmutableMetadata.builder();
Copy link
Author

Choose a reason for hiding this comment

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

I would prefer to have a mergeMetdata or addMetadata method in the ImmutableMetadataBuilder

@@ -79,7 +81,7 @@ public void eventHandling() throws Throwable {
final MutableStructure syncMetadata = new MutableStructure();
syncMetadata.add(key, val);

InProcessResolver inProcessResolver = getInProcessResolverWth(new MockStorage(new HashMap<>(), sender),
InProcessResolver inProcessResolver = getInProcessResolverWith(new MockStorage(new HashMap<>(), sender),
Copy link
Author

Choose a reason for hiding this comment

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

I assume this was a typo

@toddbaert toddbaert closed this Jan 6, 2025
@toddbaert toddbaert reopened this Jan 6, 2025
@toddbaert toddbaert marked this pull request as ready for review January 6, 2025 19:37
@toddbaert toddbaert requested a review from a team as a code owner January 6, 2025 19:37
@toddbaert toddbaert marked this pull request as draft January 6, 2025 19:38
@toddbaert toddbaert force-pushed the feat/Update-in-process-resolver-to-support-flag-metadata branch 3 times, most recently from 1fa47fc to 1285149 Compare January 6, 2025 20:52
@toddbaert toddbaert force-pushed the feat/Update-in-process-resolver-to-support-flag-metadata branch from 1285149 to c08e7bc Compare January 6, 2025 20:52
@toddbaert toddbaert mentioned this pull request Jan 6, 2025
@toddbaert
Copy link
Member

toddbaert commented Jan 6, 2025

@chrfwow this is definitely a step in the right direction - I think there's probably some null check missing related to the metadata causing the e2e failures: Run 1: Cannot invoke "dev.openfeature.sdk.Structure.asMap()" because "structure" is null

Working with @beeme1mr and a few others in in slack, we've decided another thing we'd want here is a very basic mechanism for reducing duplication: the ability to add metadata for the entire flag set at the "top level" which all flags inherit:

{
  "metadata": {
    "foo": "bar"
  },
  "flags": {
    "flag1": {
      // ...
      "metadata": {
        // "foo":  "bar" is automatically included, but can be overridden if defined in `flag1`
      }
    }
  }
}

The same thing is implemented here: open-feature/js-sdk-contrib#1120

See: https://github.com/open-feature/flagd-schemas/blob/37baa2cdea48a5ac614ba3e718b7d02ad4120611/json/flags.json#L53

cc @beeme1mr

…to-support-flag-metadata' into feat/Update-in-process-resolver-to-support-flag-metadata

# Conflicts:
#	providers/flagd/schemas
@JsonProperty("defaultVariant") String defaultVariant,
@JsonProperty("variants") Map<String, Object> variants,
@JsonProperty("targeting") @JsonDeserialize(using = StringSerializer.class) String targeting,
@JsonProperty("metadata") Map<String, Object> metadata
Copy link
Member

Choose a reason for hiding this comment

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

[question] Currently, we do need to provide an empty map everywhere to be backward compatible. Could we also omit this parameter and make it optional? more a question out of curiosity ;)

@chrfwow chrfwow marked this pull request as ready for review January 9, 2025 09:49
@chrfwow chrfwow requested a review from aepfli January 9, 2025 09:49
assertThrows(IllegalArgumentException.class, () -> {
FlagParser.parseString(getFlagsFromResource(INVALID_FLAG), true);
});
void validJsonConfigurationWithGlobalMetadataParsing() throws IOException {
Copy link
Member

@toddbaert toddbaert Jan 9, 2025

Choose a reason for hiding this comment

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

Tests look good, thanks; I think I see all obvious the cases tested.

@toddbaert toddbaert self-requested a review January 9, 2025 20:48
@@ -178,6 +183,7 @@ private <T> ProviderEvaluation<T> resolve(Class<T> type, String key, EvaluationC
return ProviderEvaluation.<T>builder()
.errorMessage("flag: " + key + " not found")
.errorCode(ErrorCode.FLAG_NOT_FOUND)
.flagMetadata(fallBackMetadata)
Copy link
Member

Choose a reason for hiding this comment

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

As a corollary to the inheritance of the flag set metadata, for error cases we should make a "best effort" to return whatever metadata we can - so here we should still return the flag set metadata. We've added this to the spec: https://github.com/open-feature/flagd/pull/1505/files#diff-28ba4b4041b6c39c4b9deb542276312bebdd08f45b39b29d860849d9e8b81a6eR297

The simplest way might be to store the flag set metadata on the flag store and expose it there.

This will greatly help in telemetry and debugging, since we'll have some idea of the flag set, it's version, etc in error reporting and metrics.

@toddbaert toddbaert self-requested a review January 9, 2025 20:52
Copy link
Member

@toddbaert toddbaert left a comment

Choose a reason for hiding this comment

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

I found one small issue here

@chrfwow chrfwow marked this pull request as draft January 10, 2025 07:11
…to-support-flag-metadata' into feat/Update-in-process-resolver-to-support-flag-metadata

# Conflicts:
#	providers/flagd/src/main/java/dev/openfeature/contrib/providers/flagd/resolver/process/InProcessResolver.java
@chrfwow chrfwow requested a review from toddbaert January 10, 2025 10:33
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.

[flagd] Update in-process resolver to support flag metadata
8 participants