diff options
author | Henning Baldersheim <balder@yahoo-inc.com> | 2017-11-24 10:58:01 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-11-24 10:58:01 +0100 |
commit | 3c72ae828ce4a8c03e1fea050784f6b30725cc5d (patch) | |
tree | 7ebc3956b7fdc164660e3cc13e940ea1d3171432 /config | |
parent | 2f5a882a19af695fcb29f04bf349e8c57aa8ba1b (diff) | |
parent | 30ca148be73f15ac05485ff6d09f8b44090959cd (diff) |
Merge pull request #4264 from vespa-engine/hmusum/test-two-config-updates-in-a-row
Test that getting two updates before checking for new config uses theā¦
Diffstat (limited to 'config')
-rw-r--r-- | config/src/test/java/com/yahoo/config/subscription/ConfigSetSubscriptionTest.java | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/config/src/test/java/com/yahoo/config/subscription/ConfigSetSubscriptionTest.java b/config/src/test/java/com/yahoo/config/subscription/ConfigSetSubscriptionTest.java index 2aa7c66ce87..8acab56d838 100644 --- a/config/src/test/java/com/yahoo/config/subscription/ConfigSetSubscriptionTest.java +++ b/config/src/test/java/com/yahoo/config/subscription/ConfigSetSubscriptionTest.java @@ -130,4 +130,32 @@ public class ConfigSetSubscriptionTest { assertEquals(hS.getConfig().stringVal(), "new StringVal"); } + @Test + public void requireThatWeGetLatestConfigWhenTwoUpdatesBeforeClientChecks() { + ConfigSet myConfigs = new ConfigSet(); + AppConfig.Builder a0builder = new AppConfig.Builder().message("A message, 1"); + myConfigs.addBuilder("app/0", a0builder); + ConfigSubscriber subscriber = new ConfigSubscriber(myConfigs); + ConfigHandle<AppConfig> hA0 = subscriber.subscribe(AppConfig.class, "app/0"); + + assertTrue(subscriber.nextConfig(0)); + assertTrue(hA0.isChanged()); + assertEquals(hA0.getConfig().message(), "A message, 1"); + + assertFalse(subscriber.nextConfig(10)); + assertFalse(hA0.isChanged()); + assertEquals(hA0.getConfig().message(), "A message, 1"); + + //Reconfigure two times in a row + a0builder.message("A new message, 2"); + subscriber.reload(1); + a0builder.message("An even newer message, 3"); + subscriber.reload(2); + + // Should pick up the last one + assertTrue(subscriber.nextConfig(0)); + assertTrue(hA0.isChanged()); + assertEquals(hA0.getConfig().message(), "An even newer message, 3"); + } + } |