From 7be826174d1837629c0ad33c7b6d4dfb3bc63a47 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kjetil=20=C3=98rbekk?= Date: Tue, 28 Feb 2012 14:17:17 +0100 Subject: Add VariableUpdaterTask. VariableUpdaterTask updates a variable countinously. --- .../com/orbekk/same/VariableUpdaterTaskTest.java | 62 ++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 same/src/test/java/com/orbekk/same/VariableUpdaterTaskTest.java (limited to 'same/src/test/java/com') diff --git a/same/src/test/java/com/orbekk/same/VariableUpdaterTaskTest.java b/same/src/test/java/com/orbekk/same/VariableUpdaterTaskTest.java new file mode 100644 index 0000000..3ecf444 --- /dev/null +++ b/same/src/test/java/com/orbekk/same/VariableUpdaterTaskTest.java @@ -0,0 +1,62 @@ +package com.orbekk.same; + +import static org.junit.Assert.*; + +import org.junit.Before; +import org.junit.Test; +import static org.mockito.Mockito.*; + +public class VariableUpdaterTaskTest { + Variable v; + VariableUpdaterTask updater; + + @Before public void setUp() { + v = mock(Variable.class); + updater = new VariableUpdaterTask(v); + } + + @Test + public void updatesValue() { + updater.set("FirstValue"); + updater.performWork(); + verify(v).set("FirstValue"); + } + + @Test + public void noUpdateIfNotSet() { + updater.set("FirstValue"); + updater.performWork(); + reset(v); + updater.performWork(); + verify(v, never()).set(anyString()); + } + + @Test + public void noUpdateIfNotReady() { + updater.set("FirstValue"); + updater.performWork(); + reset(v); + updater.set("SecondValue"); + updater.performWork(); + verify(v, never()).set(anyString()); + } + + @Test + public void updatesWhenReady() { + updater.set("Value1"); + updater.performWork(); + reset(v); + updater.valueChanged(null); + updater.set("Value2"); + updater.performWork(); + verify(v).set("Value2"); + } + + @Test + public void choosesLastUpdate() { + updater.set("FirstValue"); + updater.set("SecondValue"); + updater.performWork(); + verify(v).set("SecondValue"); + } +} -- cgit v1.2.3