From 8be56ef580e4fab732060d7d99f560c9917ca502 Mon Sep 17 00:00:00 2001 From: Leif Åstrand Date: Thu, 23 Apr 2015 15:54:29 +0300 Subject: Make restoreInstances clear value when previous value was gc:ed (#17603) Change-Id: I61992c04cac578dc1158efd9c76484eacc8a6b6a --- server/src/com/vaadin/util/CurrentInstance.java | 5 +-- .../src/com/vaadin/util/CurrentInstanceTest.java | 45 ++++++++++++++++++++++ 2 files changed, 47 insertions(+), 3 deletions(-) diff --git a/server/src/com/vaadin/util/CurrentInstance.java b/server/src/com/vaadin/util/CurrentInstance.java index d11fa175ac..e6b58ec65c 100644 --- a/server/src/com/vaadin/util/CurrentInstance.java +++ b/server/src/com/vaadin/util/CurrentInstance.java @@ -260,10 +260,9 @@ public class CurrentInstance implements Serializable { * unless it respects null values, will just leave the wrong UI * instance registered. */ - set(c, null, ci.inheritable); - } else { - set(c, v, ci.inheritable); + v = null; } + set(c, v, ci.inheritable); } if (removeStale) { diff --git a/server/tests/src/com/vaadin/util/CurrentInstanceTest.java b/server/tests/src/com/vaadin/util/CurrentInstanceTest.java index 5f9c9638e6..458e8a2f6c 100644 --- a/server/tests/src/com/vaadin/util/CurrentInstanceTest.java +++ b/server/tests/src/com/vaadin/util/CurrentInstanceTest.java @@ -17,6 +17,7 @@ package com.vaadin.util; import static org.junit.Assert.assertNull; +import java.lang.ref.WeakReference; import java.lang.reflect.Field; import java.util.Map; import java.util.concurrent.atomic.AtomicBoolean; @@ -200,4 +201,48 @@ public class CurrentInstanceTest { assertNull(CurrentInstance.get(VaadinSession.class)); assertNull(CurrentInstance.get(VaadinService.class)); } + + @Test + public void testRestoreWithGarbageCollectedValue() + throws InterruptedException { + VaadinSession session1 = new VaadinSession(null) { + @Override + public String toString() { + return "First session"; + } + }; + VaadinSession session2 = new VaadinSession(null) { + @Override + public String toString() { + return "Second session"; + } + }; + + VaadinSession.setCurrent(session1); + Map, CurrentInstance> previous = CurrentInstance + .setCurrent(session2); + + // Use weak ref to verify object is collected + WeakReference ref = new WeakReference( + session1); + + session1 = null; + waitUntilGarbageCollected(ref); + + CurrentInstance.restoreInstances(previous); + + Assert.assertNull(VaadinSession.getCurrent()); + } + + private static void waitUntilGarbageCollected(WeakReference ref) + throws InterruptedException { + for (int i = 0; i < 50; i++) { + System.gc(); + if (ref.get() == null) { + return; + } + Thread.sleep(100); + } + Assert.fail("Value was not garbage collected."); + } } -- cgit v1.2.3