From dfb4a648dc0e3a7c5e04cdf32fb02d9d17b15dbe Mon Sep 17 00:00:00 2001 From: Yongkoo Kang Date: Fri, 12 Apr 2024 11:34:09 -0700 Subject: [PATCH 1/2] Update handling of nested PrefixedViewConfigs --- .../config/AbstractDependentConfig.java | 2 +- .../archaius/config/PrefixedViewConfig.java | 3 + .../archaius/config/CompositeConfigTest.java | 55 ++++++++++++++----- 3 files changed, 45 insertions(+), 15 deletions(-) diff --git a/archaius2-core/src/main/java/com/netflix/archaius/config/AbstractDependentConfig.java b/archaius2-core/src/main/java/com/netflix/archaius/config/AbstractDependentConfig.java index 4eea616e..e836bbac 100644 --- a/archaius2-core/src/main/java/com/netflix/archaius/config/AbstractDependentConfig.java +++ b/archaius2-core/src/main/java/com/netflix/archaius/config/AbstractDependentConfig.java @@ -78,7 +78,7 @@ public boolean isEmpty() { @Override public void recordUsage(PropertyDetails propertyDetails) { if (getState().getInstrumentedKeys().containsKey(propertyDetails.getKey())) { - getState().getInstrumentedKeys().get(propertyDetails.getKey()).recordUsage(propertyDetails); + getState().getInstrumentedKeys().get(propertyDetails.getKey()).recordUsage(createPropertyDetails(propertyDetails.getKey(), propertyDetails.getValue())); } } diff --git a/archaius2-core/src/main/java/com/netflix/archaius/config/PrefixedViewConfig.java b/archaius2-core/src/main/java/com/netflix/archaius/config/PrefixedViewConfig.java index 9a442540..7ab6691e 100644 --- a/archaius2-core/src/main/java/com/netflix/archaius/config/PrefixedViewConfig.java +++ b/archaius2-core/src/main/java/com/netflix/archaius/config/PrefixedViewConfig.java @@ -48,16 +48,19 @@ private PrefixedViewConfigListener(PrefixedViewConfig pvc) { @Override public void onSourceConfigAdded(PrefixedViewConfig pvc, Config config) { pvc.updateState(config); + pvc.notifyConfigAdded(pvc); } @Override public void onSourceConfigRemoved(PrefixedViewConfig pvc, Config config) { pvc.updateState(config); + pvc.notifyConfigRemoved(pvc); } @Override public void onSourceConfigUpdated(PrefixedViewConfig pvc, Config config) { pvc.updateState(config); + pvc.notifyConfigUpdated(pvc); } @Override diff --git a/archaius2-core/src/test/java/com/netflix/archaius/config/CompositeConfigTest.java b/archaius2-core/src/test/java/com/netflix/archaius/config/CompositeConfigTest.java index 7dd5a20f..d825acfd 100644 --- a/archaius2-core/src/test/java/com/netflix/archaius/config/CompositeConfigTest.java +++ b/archaius2-core/src/test/java/com/netflix/archaius/config/CompositeConfigTest.java @@ -28,6 +28,7 @@ import com.google.common.collect.Sets; import com.netflix.archaius.api.Config; import com.netflix.archaius.api.config.SettableConfig; +import com.netflix.archaius.api.config.CompositeConfig; import com.netflix.archaius.config.polling.ManualPollingStrategy; import com.netflix.archaius.config.polling.PollingResponse; import com.netflix.archaius.instrumentation.AccessMonitorUtil; @@ -56,10 +57,10 @@ public void basicTest() throws ConfigException { Properties props = new Properties(); props.setProperty("env", "prod"); - com.netflix.archaius.api.config.CompositeConfig libraries = new DefaultCompositeConfig(); - com.netflix.archaius.api.config.CompositeConfig application = new DefaultCompositeConfig(); + CompositeConfig libraries = new DefaultCompositeConfig(); + CompositeConfig application = new DefaultCompositeConfig(); - com.netflix.archaius.api.config.CompositeConfig config = DefaultCompositeConfig.builder() + CompositeConfig config = DefaultCompositeConfig.builder() .withConfig("lib", libraries) .withConfig("app", application) .withConfig("set", MapConfig.from(props)) @@ -100,10 +101,10 @@ public void basicReversedTest() throws ConfigException { Properties props = new Properties(); props.setProperty("env", "prod"); - com.netflix.archaius.api.config.CompositeConfig libraries = new DefaultCompositeConfig(true); - com.netflix.archaius.api.config.CompositeConfig application = new DefaultCompositeConfig(); + CompositeConfig libraries = new DefaultCompositeConfig(true); + CompositeConfig application = new DefaultCompositeConfig(); - com.netflix.archaius.api.config.CompositeConfig config = DefaultCompositeConfig.builder() + CompositeConfig config = DefaultCompositeConfig.builder() .withConfig("lib", libraries) .withConfig("app", application) .withConfig("set", MapConfig.from(props)) @@ -142,7 +143,7 @@ public void basicReversedTest() throws ConfigException { @SuppressWarnings("deprecation") @Test public void getKeysTest() throws ConfigException { - com.netflix.archaius.api.config.CompositeConfig composite = new DefaultCompositeConfig(); + CompositeConfig composite = new DefaultCompositeConfig(); composite.addConfig("a", EmptyConfig.INSTANCE); Iterator iter = composite.getKeys(); @@ -167,7 +168,7 @@ public void getKeysTest() throws ConfigException { @Test public void testGetKeysIteratorRemoveThrows() throws ConfigException { - com.netflix.archaius.api.config.CompositeConfig composite = new DefaultCompositeConfig(); + CompositeConfig composite = new DefaultCompositeConfig(); composite.addConfig("d", MapConfig.builder().put("d1", "A").put("d2", "B").build()); @@ -182,7 +183,7 @@ public void testGetKeysIteratorRemoveThrows() throws ConfigException { @Test public void testKeysIterable() throws ConfigException { - com.netflix.archaius.api.config.CompositeConfig composite = new DefaultCompositeConfig(); + CompositeConfig composite = new DefaultCompositeConfig(); composite.addConfig("d", MapConfig.builder().put("d1", "A").put("d2", "B").build()); composite.addConfig("e", MapConfig.builder().put("e1", "A").put("e2", "B").build()); @@ -195,7 +196,7 @@ public void testKeysIterable() throws ConfigException { @Test public void testKeysIterableModificationThrows() throws ConfigException { - com.netflix.archaius.api.config.CompositeConfig composite = new DefaultCompositeConfig(); + CompositeConfig composite = new DefaultCompositeConfig(); composite.addConfig("d", MapConfig.builder().put("d1", "A").put("d2", "B").build()); composite.addConfig("e", MapConfig.builder().put("e1", "A").put("e2", "B").build()); @@ -207,7 +208,7 @@ public void testKeysIterableModificationThrows() throws ConfigException { @Test public void unusedCompositeConfigIsGarbageCollected() throws ConfigException { SettableConfig sourceConfig = new DefaultSettableConfig(); - com.netflix.archaius.api.config.CompositeConfig config = DefaultCompositeConfig.builder() + CompositeConfig config = DefaultCompositeConfig.builder() .withConfig("settable", sourceConfig) .build(); Reference weakReference = new WeakReference<>(config); @@ -220,7 +221,7 @@ public void unusedCompositeConfigIsGarbageCollected() throws ConfigException { @Test public void instrumentationNotEnabled() throws Exception { - com.netflix.archaius.api.config.CompositeConfig composite = new DefaultCompositeConfig(); + CompositeConfig composite = new DefaultCompositeConfig(); composite.addConfig("polling", createPollingDynamicConfig("a1", "1", "b1", "2", null)); @@ -231,13 +232,13 @@ public void instrumentationNotEnabled() throws Exception { @Test public void instrumentationPropagation() throws Exception { - com.netflix.archaius.api.config.CompositeConfig composite = new DefaultCompositeConfig(); + CompositeConfig composite = new DefaultCompositeConfig(); AccessMonitorUtil accessMonitorUtil = spy(AccessMonitorUtil.builder().build()); PollingDynamicConfig outerPollingDynamicConfig = createPollingDynamicConfig("a1", "1", "b1", "2", accessMonitorUtil); composite.addConfig("outer", outerPollingDynamicConfig); - com.netflix.archaius.api.config.CompositeConfig innerComposite = new DefaultCompositeConfig(); + CompositeConfig innerComposite = new DefaultCompositeConfig(); PollingDynamicConfig nestedPollingDynamicConfig = createPollingDynamicConfig("b1", "1", "c1", "3", accessMonitorUtil); innerComposite.addConfig("polling", nestedPollingDynamicConfig); composite.addConfig("innerComposite", innerComposite); @@ -283,6 +284,32 @@ public void instrumentationPropagation() throws Exception { verify(accessMonitorUtil, times(6)).registerUsage((any())); } + @Test + public void instrumentationNestedPrefixedViewConfig() throws Exception { + /* + CompositeConfig (config) + | + PrefixedViewConfig (prefixedConfig) + | + PollingDynamicConfig (instrumentedConfig) + */ + AccessMonitorUtil accessMonitorUtil = spy(AccessMonitorUtil.builder().build()); + PollingDynamicConfig instrumentedConfig = + createPollingDynamicConfig("prefix.a1", "1", "b1", "2", accessMonitorUtil); + Config prefixedConfig = instrumentedConfig.getPrefixedView("prefix"); + CompositeConfig config = new DefaultCompositeConfig(); + config.addConfig("prefixedConfig", prefixedConfig); + + assertEquals("1", config.getRawProperty("a1")); + verify(accessMonitorUtil).registerUsage(eq(new PropertyDetails("prefix.a1", "prefix.a1", "1"))); + + assertEquals("1", config.getRawPropertyUninstrumented("a1")); + verify(accessMonitorUtil, times(1)).registerUsage(any()); + + assertNull(config.getRawProperty("b1")); + verify(accessMonitorUtil, times(1)).registerUsage(any()); + } + private PollingDynamicConfig createPollingDynamicConfig( String key1, String value1, String key2, String value2, AccessMonitorUtil accessMonitorUtil) throws Exception { ManualPollingStrategy strategy = new ManualPollingStrategy(); From a7230369820bf9977cfba8be0d4756535b4e7c53 Mon Sep 17 00:00:00 2001 From: Yongkoo Kang Date: Fri, 12 Apr 2024 12:03:27 -0700 Subject: [PATCH 2/2] Undo the extra propagation --- .../java/com/netflix/archaius/config/PrefixedViewConfig.java | 3 --- 1 file changed, 3 deletions(-) diff --git a/archaius2-core/src/main/java/com/netflix/archaius/config/PrefixedViewConfig.java b/archaius2-core/src/main/java/com/netflix/archaius/config/PrefixedViewConfig.java index 7ab6691e..9a442540 100644 --- a/archaius2-core/src/main/java/com/netflix/archaius/config/PrefixedViewConfig.java +++ b/archaius2-core/src/main/java/com/netflix/archaius/config/PrefixedViewConfig.java @@ -48,19 +48,16 @@ private PrefixedViewConfigListener(PrefixedViewConfig pvc) { @Override public void onSourceConfigAdded(PrefixedViewConfig pvc, Config config) { pvc.updateState(config); - pvc.notifyConfigAdded(pvc); } @Override public void onSourceConfigRemoved(PrefixedViewConfig pvc, Config config) { pvc.updateState(config); - pvc.notifyConfigRemoved(pvc); } @Override public void onSourceConfigUpdated(PrefixedViewConfig pvc, Config config) { pvc.updateState(config); - pvc.notifyConfigUpdated(pvc); } @Override