blob: e80327c2c27c75db25b21ae925655206077d8c8b [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2004, 2009 Tasktop Technologies and others.
* 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:
* Tasktop Technologies - initial API and implementation
*******************************************************************************/
package org.eclipse.mylyn.monitor.tests;
import java.io.File;
import java.io.IOException;
import java.util.HashMap;
import java.util.List;
import junit.framework.TestCase;
import org.eclipse.core.commands.ExecutionEvent;
import org.eclipse.jface.viewers.StructuredSelection;
import org.eclipse.mylyn.internal.monitor.ui.KeybindingCommandMonitor;
import org.eclipse.mylyn.internal.monitor.ui.PerspectiveChangeMonitor;
import org.eclipse.mylyn.internal.monitor.usage.InteractionEventLogger;
import org.eclipse.mylyn.internal.monitor.usage.UiUsageMonitorPlugin;
import org.eclipse.mylyn.monitor.core.InteractionEvent;
import org.eclipse.mylyn.monitor.ui.IMonitorLifecycleListener;
import org.eclipse.ui.IPerspectiveDescriptor;
import org.eclipse.ui.IPerspectiveRegistry;
import org.eclipse.ui.PlatformUI;
/**
* @author Mik Kersten
*/
public class MonitorTest extends TestCase implements IMonitorLifecycleListener {
private final InteractionEventLogger logger = UiUsageMonitorPlugin.getDefault().getInteractionLogger();
private MockSelectionMonitor selectionMonitor;
private final KeybindingCommandMonitor commandMonitor = new KeybindingCommandMonitor();
private final PerspectiveChangeMonitor perspectiveMonitor = new PerspectiveChangeMonitor();
@Override
protected void setUp() throws Exception {
super.setUp();
selectionMonitor = new MockSelectionMonitor();
}
@Override
protected void tearDown() throws Exception {
super.tearDown();
if (selectionMonitor != null) {
selectionMonitor.dispose();
}
}
public void testEnablement() throws IOException {
File monitorFile = UiUsageMonitorPlugin.getDefault().getMonitorLogFile();
assertTrue(monitorFile.exists());
UiUsageMonitorPlugin.getDefault().stopMonitoring();
logger.clearInteractionHistory();
assertEquals(0, logger.getHistoryFromFile(monitorFile).size());
generateSelection();
assertEquals(0, logger.getHistoryFromFile(monitorFile).size());
UiUsageMonitorPlugin.getDefault().startMonitoring();
generateSelection();
assertEquals(1, logger.getHistoryFromFile(monitorFile).size());
UiUsageMonitorPlugin.getDefault().stopMonitoring();
generateSelection();
assertEquals(1, logger.getHistoryFromFile(monitorFile).size());
UiUsageMonitorPlugin.getDefault().startMonitoring();
generateSelection();
assertEquals(2, logger.getHistoryFromFile(monitorFile).size());
UiUsageMonitorPlugin.getDefault().stopMonitoring();
}
@SuppressWarnings({ "deprecation", "rawtypes" })
public void testLogging() throws InterruptedException {
UiUsageMonitorPlugin.getDefault().startMonitoring();
logger.stopMonitoring();
UiUsageMonitorPlugin.getDefault().getMonitorLogFile().delete();
logger.startMonitoring();
generateSelection();
commandMonitor.preExecute("foo.command", new ExecutionEvent(new HashMap(), "trigger", "context"));
File monitorFile = UiUsageMonitorPlugin.getDefault().getMonitorLogFile();
assertTrue(monitorFile.exists());
logger.stopMonitoring();
List<InteractionEvent> events = logger.getHistoryFromFile(monitorFile);
assertTrue("" + events.size(), events.size() >= 2);
logger.stopMonitoring();
events = logger.getHistoryFromFile(monitorFile);
assertTrue(events.size() >= 0);
UiUsageMonitorPlugin.getDefault().getMonitorLogFile().delete();
logger.startMonitoring();
generatePerspectiveSwitch();
assertTrue(monitorFile.exists());
logger.stopMonitoring();
events = logger.getHistoryFromFile(monitorFile);
assertTrue(events.size() >= 1);
}
private void generateSelection() {
selectionMonitor.selectionChanged(PlatformUI.getWorkbench()
.getActiveWorkbenchWindow()
.getActivePage()
.getActivePart(), new StructuredSelection("yo"));
}
private void generatePerspectiveSwitch() {
IPerspectiveRegistry registry = PlatformUI.getWorkbench().getPerspectiveRegistry();
IPerspectiveDescriptor perspective = registry.clonePerspective("newId", "newLabel",
registry.getPerspectives()[0]);
perspectiveMonitor.perspectiveActivated(null, perspective);
}
boolean monitorRunning = false;
public void startMonitoring() {
monitorRunning = true;
}
public void stopMonitoring() {
monitorRunning = false;
}
public void testLifecycleCallbacks() {
assertFalse(monitorRunning);
UiUsageMonitorPlugin.getDefault().stopMonitoring();
UiUsageMonitorPlugin.getDefault().addMonitoringLifecycleListener(this);
assertTrue(monitorRunning);
UiUsageMonitorPlugin.getDefault().startMonitoring();
assertTrue(monitorRunning);
UiUsageMonitorPlugin.getDefault().stopMonitoring();
assertFalse(monitorRunning);
UiUsageMonitorPlugin.getDefault().startMonitoring();
assertTrue(monitorRunning);
UiUsageMonitorPlugin.getDefault().stopMonitoring();
assertFalse(monitorRunning);
UiUsageMonitorPlugin.getDefault().removeMonitoringLifecycleListener(this);
}
}
// public void testLogFileMove() throws IOException {
// File defaultFile = MylarMonitorPlugin.getDefault().getMonitorLogFile();
// MylarMonitorPlugin.getDefault().stopMonitoring();
// assertTrue(logger.clearInteractionHistory());
//
// MylarMonitorPlugin.getDefault().startMonitoring();
// generateSelection();
// generateSelection();
// assertEquals(2, logger.getHistoryFromFile(defaultFile).size());
//
// File newFile =
// MylarMonitorPlugin.getDefault().moveMonitorLogFile(ContextCore.getMylarDataDirectory()
// + "/monitor-test-new.xml");
// assertNotNull(newFile);
// File movedFile = MylarMonitorPlugin.getDefault().getMonitorLogFile();
// assertTrue(!newFile.equals(defaultFile));
// assertEquals(newFile, movedFile);
// assertEquals(newFile, logger.getOutputFile());
// assertEquals(2, logger.getHistoryFromFile(newFile).size());
// assertEquals(0, logger.getHistoryFromFile(defaultFile).size());
//
// generateSelection();
// assertEquals(3, logger.getHistoryFromFile(newFile).size());
// File restoredFile =
// MylarMonitorPlugin.getDefault().moveMonitorLogFile(defaultFile.getAbsolutePath());
// assertNotNull(restoredFile);
// }