/******************************************************************************* * Copyright (c) 2012-2015 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.extension.builder.client.build; import org.eclipse.che.api.builder.dto.BuildTaskDescriptor; import org.eclipse.che.ide.extension.builder.client.BaseTest; import org.junit.Before; import org.junit.Ignore; import org.junit.Test; import org.mockito.InOrder; import java.util.ArrayList; import java.util.Collections; import java.util.List; import static org.mockito.Mockito.*; /** * Testing {@link LogMessagesHandler} functionality. * * @author Artem Zatsarynnyy */ public class LogMessagesHandlerTest extends BaseTest { private LogMessagesHandler logMessagesHandler; private List<LogMessage> orderedMessages = new ArrayList<>(100); @Before public void setUp() { super.setUp(); logMessagesHandler = new LogMessagesHandler(mock(BuildTaskDescriptor.class), builderConsolePresenter, messageBus); orderedMessages.clear(); for (int i = 0; i < 100; i++) { orderedMessages.add(new LogMessage(i + 1, "message#" + i)); } } @Test public void shouldPrintMessagesInCorrectOrder() throws Exception { List<LogMessage> shuffledMessages = new ArrayList<>(orderedMessages); Collections.shuffle(shuffledMessages); for (LogMessage logMessage : shuffledMessages) { logMessagesHandler.onMessageReceived(logMessage); } InOrder inOrder = inOrder(builderConsolePresenter); for (LogMessage logMessage : orderedMessages) { inOrder.verify(builderConsolePresenter, times(1)).print(logMessage.text); } } @Test @Ignore public void shouldSkipLostMessages() throws Exception { List<LogMessage> listWithMissedMessages = new ArrayList<>(orderedMessages); listWithMissedMessages.remove(75); listWithMissedMessages.remove(50); listWithMissedMessages.remove(25); for (LogMessage logMessage : listWithMissedMessages) { logMessagesHandler.onMessageReceived(logMessage); } for (LogMessage logMessage : orderedMessages) { final int index = orderedMessages.indexOf(logMessage); if (index == 25 || index == 50 || index == 75) { verify(builderConsolePresenter, never()).print(logMessage.text); } else { verify(builderConsolePresenter, timeout(5000).times(1)).print(logMessage.text); } } } }