blob: 7a71c89c3b7e241dd93b0a8ba7a5fc12a36bd8d8 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2009 Tasktop Technologies and others.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* https://www.eclipse.org/legal/epl-2.0
*
* SPDX-License-Identifier: EPL-2.0
*
* Tasktop Technologies - initial API and implementation
*******************************************************************************/
package org.eclipse.mylyn.monitor.tests;
import java.util.Arrays;
import junit.framework.TestCase;
import org.eclipse.mylyn.internal.monitor.ui.ActivityContextManager;
import org.eclipse.mylyn.monitor.ui.AbstractUserActivityMonitor;
/**
* @author Steffen Pingel
*/
public class ActivityContextManagerTest extends TestCase {
private class StubMonitor extends AbstractUserActivityMonitor {
private boolean started;
private boolean fail;
private boolean enabled = true;
@Override
public boolean isEnabled() {
return enabled;
}
@Override
public void start() {
started = true;
}
@Override
public void stop() {
started = false;
}
@Override
public long getLastInteractionTime() {
if (fail) {
throw new LinkageError();
}
return super.getLastInteractionTime();
}
}
private StubMonitor monitor1;
private StubMonitor monitor2;
private ActivityContextManager manager;
@Override
protected void setUp() throws Exception {
monitor1 = new StubMonitor();
monitor2 = new StubMonitor();
manager = new ActivityContextManager(Arrays.asList(new AbstractUserActivityMonitor[] { monitor1, monitor2 }));
}
@Override
protected void tearDown() throws Exception {
if (manager != null) {
manager.stop();
}
};
public void testStartStop() {
manager.start();
assertTrue(monitor1.started);
assertTrue(monitor2.started);
manager.stop();
assertFalse(monitor1.started);
assertFalse(monitor2.started);
}
public void testGetInactivityTimeout() {
monitor1.setLastEventTime(1);
monitor2.setLastEventTime(2);
assertEquals(1, manager.getLastInteractionTime());
assertEquals(1, manager.getLastInteractionTime());
}
public void testGetInactivityTimeoutFailure() {
monitor1.setLastEventTime(1);
monitor2.setLastEventTime(2);
manager.start();
assertEquals(1, manager.getLastInteractionTime());
monitor1.fail = true;
assertEquals(2, manager.getLastInteractionTime());
manager.stop();
// the first monitor should have been disabled
assertTrue(monitor1.started);
assertFalse(monitor2.started);
}
public void testEnabled() {
monitor1.enabled = false;
monitor1.setLastEventTime(1);
monitor2.setLastEventTime(2);
assertEquals(2, manager.getLastInteractionTime());
monitor2.enabled = false;
assertEquals(-1, manager.getLastInteractionTime());
}
}