From 93499975d0b9ae30aa34db999d8aa3d7c955da70 Mon Sep 17 00:00:00 2001 From: Kavindu Dodanduwa Date: Fri, 3 Feb 2023 08:36:51 -0800 Subject: [PATCH] fix: improve error logs for evaluation failure (#276) improve error logs for evaluation failure Signed-off-by: Kavindu Dodanduwa --- .../java/dev/openfeature/sdk/OpenFeatureClient.java | 2 +- .../dev/openfeature/sdk/FlagEvaluationSpecTest.java | 12 +++++++++++- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/src/main/java/dev/openfeature/sdk/OpenFeatureClient.java b/src/main/java/dev/openfeature/sdk/OpenFeatureClient.java index 0095abce1..a13eb942a 100644 --- a/src/main/java/dev/openfeature/sdk/OpenFeatureClient.java +++ b/src/main/java/dev/openfeature/sdk/OpenFeatureClient.java @@ -137,7 +137,7 @@ private FlagEvaluationDetails evaluateFlag(FlagValueType type, String key details = FlagEvaluationDetails.from(providerEval, key); hookSupport.afterHooks(type, hookCtx, details, mergedHooks, hints); } catch (Exception e) { - log.error("Unable to correctly evaluate flag with key {} due to exception {}", key, e.getMessage()); + log.error("Unable to correctly evaluate flag with key '{}'", key, e); if (details == null) { details = FlagEvaluationDetails.builder().build(); } diff --git a/src/test/java/dev/openfeature/sdk/FlagEvaluationSpecTest.java b/src/test/java/dev/openfeature/sdk/FlagEvaluationSpecTest.java index 35f83fddb..24bb8d346 100644 --- a/src/test/java/dev/openfeature/sdk/FlagEvaluationSpecTest.java +++ b/src/test/java/dev/openfeature/sdk/FlagEvaluationSpecTest.java @@ -1,6 +1,7 @@ package dev.openfeature.sdk; import static org.assertj.core.api.Assertions.assertThat; +import static org.assertj.core.api.InstanceOfAssertFactories.optional; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertFalse; import static org.junit.jupiter.api.Assertions.assertNull; @@ -15,6 +16,8 @@ import java.util.List; import java.util.Map; +import com.google.common.collect.ImmutableList; +import dev.openfeature.sdk.exceptions.FlagNotFoundError; import io.cucumber.java.hu.Ha; import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.Test; @@ -206,7 +209,14 @@ private Client _client() { Client c = api.getClient(); FlagEvaluationDetails result = c.getBooleanDetails("test", false); assertEquals(Reason.ERROR.toString(), result.getReason()); - assertThat(TEST_LOGGER.getLoggingEvents()).contains(LoggingEvent.error("Unable to correctly evaluate flag with key {} due to exception {}", "test", TestConstants.BROKEN_MESSAGE)); + + ImmutableList loggingEvents = TEST_LOGGER.getLoggingEvents(); + assertThat(loggingEvents.size()).isGreaterThan(0); + + LoggingEvent event = loggingEvents.get(0); + assertThat(event.getMessage()).isEqualTo("Unable to correctly evaluate flag with key '{}'"); + assertThat(event.getThrowable().isPresent()).isTrue(); + assertThat(event.getThrowable().get()).isInstanceOf(FlagNotFoundError.class); } @Specification(number="1.2.2", text="The client interface MUST define a metadata member or accessor, containing an immutable name field or accessor of type string, which corresponds to the name value supplied during client creation.")