commit
06a8e2dc02
@ -0,0 +1,126 @@ |
|||||||
|
package org.airsonic.player.service; |
||||||
|
|
||||||
|
import org.airsonic.player.domain.*; |
||||||
|
import org.airsonic.player.service.jukebox.JavaPlayerFactory; |
||||||
|
import org.junit.Before; |
||||||
|
import org.junit.Test; |
||||||
|
import org.junit.runner.RunWith; |
||||||
|
import org.mockito.Mock; |
||||||
|
import org.mockito.runners.MockitoJUnitRunner; |
||||||
|
|
||||||
|
import static org.mockito.Mockito.*; |
||||||
|
|
||||||
|
@RunWith(MockitoJUnitRunner.class) |
||||||
|
public class JukeboxJavaServiceUnitTest { |
||||||
|
|
||||||
|
private static final String USER_NAME = "admin"; |
||||||
|
|
||||||
|
private JukeboxJavaService service; |
||||||
|
@Mock |
||||||
|
private Player airsonicPlayer; |
||||||
|
@Mock |
||||||
|
private AudioScrobblerService audioScrobblerService; |
||||||
|
@Mock |
||||||
|
private StatusService statusService; |
||||||
|
@Mock |
||||||
|
private SecurityService securityService; |
||||||
|
@Mock |
||||||
|
private MediaFileService mediaFileService; |
||||||
|
@Mock |
||||||
|
private JavaPlayerFactory javaPlayerFactory; |
||||||
|
@Mock |
||||||
|
private com.github.biconou.AudioPlayer.api.Player player; |
||||||
|
@Mock |
||||||
|
private User user; |
||||||
|
@Mock |
||||||
|
private PlayQueue playQueue; |
||||||
|
@Mock |
||||||
|
private MediaFile mediaFile; |
||||||
|
|
||||||
|
|
||||||
|
@Before |
||||||
|
public void setup() { |
||||||
|
service = new JukeboxJavaService(audioScrobblerService, statusService, securityService, mediaFileService, javaPlayerFactory); |
||||||
|
when(airsonicPlayer.getTechnology()).thenReturn(PlayerTechnology.JAVA_JUKEBOX); |
||||||
|
when(airsonicPlayer.getUsername()).thenReturn(USER_NAME); |
||||||
|
when(javaPlayerFactory.createJavaPlayer()).thenReturn(player); |
||||||
|
when(securityService.getUserByName(USER_NAME)).thenReturn(user); |
||||||
|
when(user.isJukeboxRole()).thenReturn(true); |
||||||
|
when(airsonicPlayer.getPlayQueue()).thenReturn(playQueue); |
||||||
|
when(playQueue.getCurrentFile()).thenReturn(mediaFile); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void play() { |
||||||
|
// When
|
||||||
|
service.play(airsonicPlayer); |
||||||
|
// Then
|
||||||
|
verify(javaPlayerFactory).createJavaPlayer(); |
||||||
|
verify(player).play(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void playForNonDefaultMixer() { |
||||||
|
// Given
|
||||||
|
when(airsonicPlayer.getJavaJukeboxMixer()).thenReturn("mixer"); |
||||||
|
when(javaPlayerFactory.createJavaPlayer("mixer")).thenReturn(player); |
||||||
|
// When
|
||||||
|
service.play(airsonicPlayer); |
||||||
|
// Then
|
||||||
|
verify(javaPlayerFactory).createJavaPlayer("mixer"); |
||||||
|
verify(player).play(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void playAndStop() { |
||||||
|
// When
|
||||||
|
service.play(airsonicPlayer); |
||||||
|
// Then
|
||||||
|
verify(javaPlayerFactory).createJavaPlayer(); |
||||||
|
verify(player).play(); |
||||||
|
// When
|
||||||
|
service.stop(airsonicPlayer); |
||||||
|
// Then
|
||||||
|
verifyNoMoreInteractions(javaPlayerFactory); |
||||||
|
verify(player).pause(); |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void playWithNonJukeboxUser() { |
||||||
|
// Given
|
||||||
|
when(user.isJukeboxRole()).thenReturn(false); |
||||||
|
// When
|
||||||
|
service.play(airsonicPlayer); |
||||||
|
// Then
|
||||||
|
verify(javaPlayerFactory).createJavaPlayer(); |
||||||
|
verify(player, never()).play(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test(expected = RuntimeException.class) |
||||||
|
public void playWithNonJukeboxPlayer() { |
||||||
|
// Given
|
||||||
|
when(airsonicPlayer.getTechnology()).thenReturn(PlayerTechnology.WEB); |
||||||
|
// When
|
||||||
|
service.play(airsonicPlayer); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void playWithNoPlayQueueEmpty() { |
||||||
|
// Given
|
||||||
|
when(playQueue.getCurrentFile()).thenReturn(null); |
||||||
|
// When
|
||||||
|
service.play(airsonicPlayer); |
||||||
|
// Then
|
||||||
|
verify(javaPlayerFactory).createJavaPlayer(); |
||||||
|
verify(player, never()).play(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test(expected = RuntimeException.class) |
||||||
|
public void playerInitProblem() { |
||||||
|
// Given
|
||||||
|
when(javaPlayerFactory.createJavaPlayer()).thenReturn(null); |
||||||
|
// When
|
||||||
|
service.play(airsonicPlayer); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,233 @@ |
|||||||
|
package org.airsonic.player.service; |
||||||
|
|
||||||
|
import org.airsonic.player.domain.Player; |
||||||
|
import org.airsonic.player.domain.PlayerTechnology; |
||||||
|
import org.junit.Before; |
||||||
|
import org.junit.Test; |
||||||
|
import org.junit.runner.RunWith; |
||||||
|
import org.mockito.Mock; |
||||||
|
import org.mockito.runners.MockitoJUnitRunner; |
||||||
|
|
||||||
|
import static org.mockito.Mockito.verify; |
||||||
|
import static org.assertj.core.api.Assertions.*; |
||||||
|
import static org.mockito.Mockito.when; |
||||||
|
|
||||||
|
@RunWith(value = MockitoJUnitRunner.class) |
||||||
|
public class JukeboxServiceUnitTest { |
||||||
|
|
||||||
|
private JukeboxService jukeboxService; |
||||||
|
@Mock |
||||||
|
private JukeboxLegacySubsonicService jukeboxLegacySubsonicService; |
||||||
|
@Mock |
||||||
|
private JukeboxJavaService jukeboxJavaService; |
||||||
|
private Player jukeboxPlayer; |
||||||
|
private Player legacyJukeboxPlayer; |
||||||
|
private Player nonJukeboxPlayer; |
||||||
|
|
||||||
|
@Before |
||||||
|
public void setUp() { |
||||||
|
jukeboxService = new JukeboxService(jukeboxLegacySubsonicService, jukeboxJavaService); |
||||||
|
jukeboxPlayer = generateJukeboxPlayer(); |
||||||
|
legacyJukeboxPlayer = generateLegacyJukeboxPlayer(); |
||||||
|
nonJukeboxPlayer = generateNonJukeboxPlayer(); |
||||||
|
} |
||||||
|
|
||||||
|
private Player generateNonJukeboxPlayer() { |
||||||
|
Player player = new Player(); |
||||||
|
player.setId(0); |
||||||
|
player.setTechnology(PlayerTechnology.WEB); |
||||||
|
return player; |
||||||
|
} |
||||||
|
|
||||||
|
private Player generateLegacyJukeboxPlayer() { |
||||||
|
Player player = new Player(); |
||||||
|
player.setId(1); |
||||||
|
player.setTechnology(PlayerTechnology.JUKEBOX); |
||||||
|
return player; |
||||||
|
} |
||||||
|
|
||||||
|
private Player generateJukeboxPlayer() { |
||||||
|
Player player = new Player(); |
||||||
|
player.setId(2); |
||||||
|
player.setTechnology(PlayerTechnology.JAVA_JUKEBOX); |
||||||
|
return player; |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void setPositionWithJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
jukeboxService.setPosition(jukeboxPlayer, 0); |
||||||
|
// Then
|
||||||
|
verify(jukeboxJavaService).setPosition(jukeboxPlayer, 0); |
||||||
|
} |
||||||
|
|
||||||
|
@Test(expected = UnsupportedOperationException.class) |
||||||
|
public void setPositionWithLegacyJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
jukeboxService.setPosition(legacyJukeboxPlayer, 0); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void getGainWithJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
jukeboxService.getGain(jukeboxPlayer); |
||||||
|
// Then
|
||||||
|
verify(jukeboxJavaService).getGain(jukeboxPlayer); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void getGainWithLegacyJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
jukeboxService.getGain(legacyJukeboxPlayer); |
||||||
|
// Then
|
||||||
|
verify(jukeboxLegacySubsonicService).getGain(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void getGainWithNonJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
float gain = jukeboxService.getGain(nonJukeboxPlayer); |
||||||
|
// Then
|
||||||
|
assertThat(gain).isEqualTo(0); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void updateJukebox() throws Exception { |
||||||
|
// When
|
||||||
|
jukeboxService.updateJukebox(legacyJukeboxPlayer, 0); |
||||||
|
// Then
|
||||||
|
verify(jukeboxLegacySubsonicService).updateJukebox(legacyJukeboxPlayer, 0); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void getPositionWithJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
jukeboxService.getPosition(jukeboxPlayer); |
||||||
|
// Then
|
||||||
|
verify(jukeboxJavaService).getPosition(jukeboxPlayer); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void getPositionWithLegacyJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
jukeboxService.getPosition(legacyJukeboxPlayer); |
||||||
|
// Then
|
||||||
|
verify(jukeboxLegacySubsonicService).getPosition(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void getPasitionWithNonJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
int position = jukeboxService.getPosition(nonJukeboxPlayer); |
||||||
|
// Then
|
||||||
|
assertThat(position).isEqualTo(0); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void setGainWithJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
jukeboxService.setGain(jukeboxPlayer, 0.5f); |
||||||
|
// Then
|
||||||
|
verify(jukeboxJavaService).setGain(jukeboxPlayer, 0.5f); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void setGaintWithLegacyJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
jukeboxService.setGain(legacyJukeboxPlayer, 0.5f); |
||||||
|
// Then
|
||||||
|
verify(jukeboxLegacySubsonicService).setGain(0.5f); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void startWithJukeboxPlayer() throws Exception { |
||||||
|
// When
|
||||||
|
jukeboxService.start(jukeboxPlayer); |
||||||
|
// Then
|
||||||
|
verify(jukeboxJavaService).start(jukeboxPlayer); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void startWithLegacyJukeboxPlayer() throws Exception { |
||||||
|
// When
|
||||||
|
jukeboxService.start(legacyJukeboxPlayer); |
||||||
|
|
||||||
|
// Then
|
||||||
|
verify(jukeboxLegacySubsonicService).updateJukebox(legacyJukeboxPlayer, 0); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void playWithJukeboxPlayer() throws Exception { |
||||||
|
// When
|
||||||
|
jukeboxService.play(jukeboxPlayer); |
||||||
|
// Then
|
||||||
|
verify(jukeboxJavaService).play(jukeboxPlayer); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void playWithLegacyJukeboxPlayer() throws Exception { |
||||||
|
// When
|
||||||
|
jukeboxService.play(legacyJukeboxPlayer); |
||||||
|
// Then
|
||||||
|
verify(jukeboxLegacySubsonicService).updateJukebox(legacyJukeboxPlayer, 0); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void stopWithJukeboxPlayer() throws Exception { |
||||||
|
// When
|
||||||
|
jukeboxService.stop(jukeboxPlayer); |
||||||
|
// Then
|
||||||
|
verify(jukeboxJavaService).stop(jukeboxPlayer); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void stopWithLegacyJukeboxPlayer() throws Exception { |
||||||
|
// When
|
||||||
|
jukeboxService.stop(legacyJukeboxPlayer); |
||||||
|
// Then
|
||||||
|
verify(jukeboxLegacySubsonicService).updateJukebox(legacyJukeboxPlayer, 0); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
@Test |
||||||
|
public void skipWithJukeboxPlayer() throws Exception { |
||||||
|
// When
|
||||||
|
jukeboxService.skip(jukeboxPlayer, 0, 1); |
||||||
|
// Then
|
||||||
|
verify(jukeboxJavaService).skip(jukeboxPlayer, 0, 1); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void skipWithLegacyJukeboxPlayer() throws Exception { |
||||||
|
// When
|
||||||
|
jukeboxService.skip(legacyJukeboxPlayer, 0, 1); |
||||||
|
// Then
|
||||||
|
verify(jukeboxLegacySubsonicService).updateJukebox(legacyJukeboxPlayer, 1); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void canControlWithJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
boolean canControl = jukeboxService.canControl(jukeboxPlayer); |
||||||
|
// Then
|
||||||
|
assertThat(canControl).isEqualTo(true); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void canControlWithLegacyJukeboxPlayer() { |
||||||
|
// When
|
||||||
|
when(jukeboxLegacySubsonicService.getPlayer()).thenReturn(legacyJukeboxPlayer); |
||||||
|
boolean canControl = jukeboxService.canControl(legacyJukeboxPlayer); |
||||||
|
// Then
|
||||||
|
assertThat(canControl).isEqualTo(true); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void canControlWithLegacyJukeboxPlayerWrongPlayer() { |
||||||
|
// When
|
||||||
|
when(jukeboxLegacySubsonicService.getPlayer()).thenReturn(nonJukeboxPlayer); |
||||||
|
boolean canControl = jukeboxService.canControl(legacyJukeboxPlayer); |
||||||
|
// Then
|
||||||
|
assertThat(canControl).isEqualTo(false); |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue