X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Ftest%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fcore%2FPreferencesTest.java;h=65d59e7651b53e9ecaae7830190042b9f1e7be3e;hp=cd9130deea4a0199fd4a15564d148b5ede20986c;hb=fdbdc26c744865a7200017cb117943d48df498ad;hpb=3bd3f8f4ce30c73c8a15817673cec22f36a5f9da diff --git a/src/test/java/net/pterodactylus/sone/core/PreferencesTest.java b/src/test/java/net/pterodactylus/sone/core/PreferencesTest.java index cd9130d..65d59e7 100644 --- a/src/test/java/net/pterodactylus/sone/core/PreferencesTest.java +++ b/src/test/java/net/pterodactylus/sone/core/PreferencesTest.java @@ -4,15 +4,24 @@ import static net.pterodactylus.sone.fcp.FcpInterface.FullAccessRequired.ALWAYS; import static org.hamcrest.MatcherAssert.assertThat; import static org.hamcrest.Matchers.instanceOf; import static org.hamcrest.Matchers.is; +import static org.mockito.ArgumentCaptor.forClass; +import static org.mockito.Matchers.any; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.verify; +import static org.mockito.Mockito.verifyNoMoreInteractions; import static org.mockito.Mockito.when; import net.pterodactylus.sone.core.Options.Option; +import net.pterodactylus.sone.core.event.InsertionDelayChangedEvent; import net.pterodactylus.sone.fcp.FcpInterface.FullAccessRequired; +import net.pterodactylus.sone.fcp.event.FcpInterfaceActivatedEvent; +import net.pterodactylus.sone.fcp.event.FcpInterfaceDeactivatedEvent; +import net.pterodactylus.sone.fcp.event.FullAccessRequiredChanged; +import com.google.common.eventbus.EventBus; import org.junit.Before; import org.junit.Test; +import org.mockito.ArgumentCaptor; /** * Unit test for {@link Preferences}. @@ -24,7 +33,8 @@ public class PreferencesTest { private static final int INTEGER_VALUE = 1; private static final String STRING_VALUE = "string-value"; private final Options options = mock(Options.class); - private final Preferences preferences = new Preferences(options); + private final EventBus eventBus = mock(EventBus.class); + private final Preferences preferences = new Preferences(eventBus, options); private final Option integerOption = when(mock(Option.class).get()).thenReturn(INTEGER_VALUE).getMock(); private final Option booleanOption = when(mock(Option.class).get()).thenReturn(true).getMock(); private final Option stringOption = when(mock(Option.class).get()).thenReturn(STRING_VALUE).getMock(); @@ -64,6 +74,12 @@ public class PreferencesTest { } @Test + public void settingInsertionDelayIsForwardedToEventBus() { + assertThat(preferences.setInsertionDelay(INTEGER_VALUE), instanceOf(Preferences.class)); + verify(eventBus).post(any(InsertionDelayChangedEvent.class)); + } + + @Test public void testGettingPostsPerPage() { assertThat(preferences.getPostsPerPage(), is(INTEGER_VALUE)); verify(integerOption).get(); @@ -202,6 +218,20 @@ public class PreferencesTest { } @Test + public void settingFcpInterfaceActiveIsForwardedToEventBus() { + preferences.setFcpInterfaceActive(true); + verify(eventBus).post(any(FcpInterfaceActivatedEvent.class)); + verifyNoMoreInteractions(eventBus); + } + + @Test + public void settingFcpInterfaceInactiveIsForwardedToEventBus() { + preferences.setFcpInterfaceActive(false); + verify(eventBus).post(any(FcpInterfaceDeactivatedEvent.class)); + verifyNoMoreInteractions(eventBus); + } + + @Test public void settingFcpInterfaceActiveIsForwardedToOption() { preferences.setFcpInterfaceActive(true); verify(booleanOption).set(true); @@ -225,4 +255,13 @@ public class PreferencesTest { verify(integerOption).set(null); } + @Test + public void settingFcpFullAccessRequiredIsForwardedToEventBus() { + preferences.setFcpFullAccessRequired(ALWAYS); + verify(integerOption).set(2); + ArgumentCaptor fullAccessRequiredChangedCaptor = forClass(FullAccessRequiredChanged.class); + verify(eventBus).post(fullAccessRequiredChangedCaptor.capture()); + assertThat(fullAccessRequiredChangedCaptor.getValue().getFullAccessRequired(), is(ALWAYS)); + } + }