/*******************************************************************************
* Copyright (c) 2012-2016 Codenvy, S.A.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Codenvy, S.A. - initial API and implementation
*******************************************************************************/
package org.eclipse.che.ide.ext.java.client.dependenciesupdater;
import com.google.web.bindery.event.shared.EventBus;
import org.eclipse.che.ide.ext.java.client.event.DependencyUpdatedEvent;
import org.eclipse.che.ide.extension.machine.client.outputspanel.OutputsContainerPresenter;
import org.eclipse.che.ide.extension.machine.client.outputspanel.console.CommandConsoleFactory;
import org.eclipse.che.ide.extension.machine.client.outputspanel.console.DefaultOutputConsole;
import org.eclipse.che.ide.websocket.MessageBus;
import org.eclipse.che.ide.websocket.MessageBusProvider;
import org.eclipse.che.ide.websocket.events.MessageHandler;
import org.eclipse.che.ide.websocket.rest.SubscriptionHandler;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Matchers;
import org.mockito.Mock;
import org.mockito.runners.MockitoJUnitRunner;
import static org.mockito.Matchers.eq;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
/**
* @author Dmitry Shnurenko
*/
@RunWith(MockitoJUnitRunner.class)
public class LogsOutputHandlerTest {
private static final String CHANNEL = "Channel";
private static final String TAB_NAME = "tab_name";
//constructor mocks
@Mock
private CommandConsoleFactory consoleFactory;
@Mock
private OutputsContainerPresenter outputsContainerPresenter;
@Mock
private MessageBusProvider messageBusProvider;
@Mock
private EventBus eventBus;
//additional mocks
@Mock
private MessageBus messageBus;
@Mock
private DefaultOutputConsole console;
@Mock
private DependencyUpdatedEvent event;
private LogsOutputHandler logsOutputHandler;
@Before
public void setUp() {
when(messageBusProvider.getMachineMessageBus()).thenReturn(messageBus);
when(consoleFactory.create(TAB_NAME)).thenReturn(console);
when(event.getChannel()).thenReturn(CHANNEL);
logsOutputHandler = new LogsOutputHandler(consoleFactory, outputsContainerPresenter, eventBus, messageBusProvider);
}
@Test
public void dependencyUpdatedEventShouldBeAdded() {
verify(eventBus).addHandler(DependencyUpdatedEvent.TYPE, logsOutputHandler);
}
@Test
public void dependencyUpdatedEventShouldBeCaughtAndMessageBusShouldBeUnsubscribed() throws Exception {
logsOutputHandler.subscribeToOutput(CHANNEL, TAB_NAME);
logsOutputHandler.onDependencyUpdated(event);
verify(event).getChannel();
verify(messageBus).unsubscribe(eq(CHANNEL), Matchers.<MessageHandler>anyObject());
}
@Test
public void handlerShouldBeSubscribedToOutput() throws Exception {
logsOutputHandler.subscribeToOutput(CHANNEL, TAB_NAME);
verify(consoleFactory).create(TAB_NAME);
verify(outputsContainerPresenter).addConsole(console);
verify(messageBus).subscribe(eq(CHANNEL), Matchers.<SubscriptionHandler<String>>anyObject());
}
}