diff options
Diffstat (limited to 'tmf/org.eclipse.tracecompass.tmf.ui.swtbot.tests/src/org/eclipse/tracecompass/tmf/ui/swtbot/tests/viewers/events/CollapseEventsInTableTest.java')
-rw-r--r-- | tmf/org.eclipse.tracecompass.tmf.ui.swtbot.tests/src/org/eclipse/tracecompass/tmf/ui/swtbot/tests/viewers/events/CollapseEventsInTableTest.java | 189 |
1 files changed, 189 insertions, 0 deletions
diff --git a/tmf/org.eclipse.tracecompass.tmf.ui.swtbot.tests/src/org/eclipse/tracecompass/tmf/ui/swtbot/tests/viewers/events/CollapseEventsInTableTest.java b/tmf/org.eclipse.tracecompass.tmf.ui.swtbot.tests/src/org/eclipse/tracecompass/tmf/ui/swtbot/tests/viewers/events/CollapseEventsInTableTest.java new file mode 100644 index 0000000000..1307de8c29 --- /dev/null +++ b/tmf/org.eclipse.tracecompass.tmf.ui.swtbot.tests/src/org/eclipse/tracecompass/tmf/ui/swtbot/tests/viewers/events/CollapseEventsInTableTest.java @@ -0,0 +1,189 @@ +/******************************************************************************* + * Copyright (c) 2013, 2015 Ericsson + * + * 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: + * Bernd Hufmann - Initial API and implementation + *******************************************************************************/ + +package org.eclipse.tracecompass.tmf.ui.swtbot.tests.viewers.events; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.fail; +import static org.junit.Assume.assumeTrue; + +import java.io.File; +import java.io.IOException; +import java.net.URI; +import java.net.URISyntaxException; +import java.net.URL; + +import org.apache.log4j.ConsoleAppender; +import org.apache.log4j.Logger; +import org.apache.log4j.SimpleLayout; +import org.eclipse.core.runtime.FileLocator; +import org.eclipse.core.runtime.Path; +import org.eclipse.core.runtime.preferences.IEclipsePreferences; +import org.eclipse.core.runtime.preferences.InstanceScope; +import org.eclipse.swtbot.eclipse.finder.SWTWorkbenchBot; +import org.eclipse.swtbot.eclipse.finder.widgets.SWTBotEditor; +import org.eclipse.swtbot.swt.finder.junit.SWTBotJunit4ClassRunner; +import org.eclipse.swtbot.swt.finder.utils.SWTBotPreferences; +import org.eclipse.swtbot.swt.finder.widgets.SWTBotMenu; +import org.eclipse.swtbot.swt.finder.widgets.SWTBotTable; +import org.eclipse.tracecompass.internal.tmf.core.Activator; +import org.eclipse.tracecompass.tmf.core.tests.TmfCoreTestPlugin; +import org.eclipse.tracecompass.tmf.core.timestamp.ITmfTimePreferencesConstants; +import org.eclipse.tracecompass.tmf.core.timestamp.TmfTimestampFormat; +import org.eclipse.tracecompass.tmf.ui.swtbot.tests.shared.ConditionHelpers; +import org.eclipse.tracecompass.tmf.ui.swtbot.tests.shared.SWTBotUtils; +import org.junit.AfterClass; +import org.junit.BeforeClass; +import org.junit.Test; +import org.junit.runner.RunWith; + +/** + * SWTBot test for testing collapsing feature. + * + * @author Bernd Hufmann + */ +@RunWith(SWTBotJunit4ClassRunner.class) +public class CollapseEventsInTableTest { + + private static final String TRACE_PROJECT_NAME = "test"; + private static final String COLLAPSE_TRACE_NAME = "syslog_collapse"; + private static final String COLLAPSE_TRACE_PATH = "testfiles/" + COLLAPSE_TRACE_NAME; + private static final String COLLAPSE_TRACE_TYPE = "org.eclipse.linuxtools.tmf.tests.stubs.trace.text.testsyslog"; + + private static File fTestFile = null; + + private static SWTWorkbenchBot fBot; + + /** The Log4j logger instance. */ + private static final Logger fLogger = Logger.getRootLogger(); + + /** + * Test Class setup + */ + @BeforeClass + public static void init() { + SWTBotUtils.failIfUIThread(); + + /* set up test trace*/ + URL location = FileLocator.find(TmfCoreTestPlugin.getDefault().getBundle(), new Path(COLLAPSE_TRACE_PATH), null); + URI uri; + try { + uri = FileLocator.toFileURL(location).toURI(); + fTestFile = new File(uri); + } catch (URISyntaxException | IOException e) { + e.printStackTrace(); + fail(); + } + + assumeTrue(fTestFile.exists()); + + IEclipsePreferences defaultPreferences = InstanceScope.INSTANCE.getNode(Activator.PLUGIN_ID); + defaultPreferences.put(ITmfTimePreferencesConstants.DATIME, "MMM d HH:mm:ss"); + defaultPreferences.put(ITmfTimePreferencesConstants.SUBSEC, ITmfTimePreferencesConstants.SUBSEC_NO_FMT); + TmfTimestampFormat.updateDefaultFormats(); + + /* Set up for swtbot */ + SWTBotPreferences.TIMEOUT = 20000; /* 20 second timeout */ + fLogger.removeAllAppenders(); + fLogger.addAppender(new ConsoleAppender(new SimpleLayout(), ConsoleAppender.SYSTEM_OUT)); + fBot = new SWTWorkbenchBot(); + + /* Close welcome view */ + SWTBotUtils.closeView("Welcome", fBot); + + /* Switch perspectives */ + SWTBotUtils.switchToTracingPerspective(); + + /* Finish waiting for eclipse to load */ + SWTBotUtils.waitForJobs(); + } + + /** + * Test class tear down method. + */ + @AfterClass + public static void tearDown() { + fLogger.removeAllAppenders(); + /* Set timestamp defaults */ + IEclipsePreferences defaultPreferences = InstanceScope.INSTANCE.getNode(Activator.PLUGIN_ID); + defaultPreferences.put(ITmfTimePreferencesConstants.DATIME, ITmfTimePreferencesConstants.TIME_HOUR_FMT); + defaultPreferences.put(ITmfTimePreferencesConstants.SUBSEC, ITmfTimePreferencesConstants.SUBSEC_NANO_FMT); + TmfTimestampFormat.updateDefaultFormats(); + } + + /** + * Main test case + */ + @Test + public void test() { + SWTBotUtils.createProject(TRACE_PROJECT_NAME); + SWTBotUtils.openTrace(TRACE_PROJECT_NAME, fTestFile.getAbsolutePath(), COLLAPSE_TRACE_TYPE); + SWTBotEditor editorBot = SWTBotUtils.activateEditor(fBot, fTestFile.getName()); + + SWTBotTable tableBot = editorBot.bot().table(); + + /* Maximize editor area */ + SWTBotUtils.maximizeTable(tableBot); + tableBot.click(1, 0); + + /* Collapse Events */ + SWTBotMenu menuBot = tableBot.contextMenu("Collapse Events"); + menuBot.click(); + fBot.waitUntil(ConditionHelpers.isTableCellFilled(tableBot, "7/22", 1, 1)); + + String cell = tableBot.cell(1, 1); + assertEquals("filterString", "7/22", cell); + + /* Verify first collapsed event */ + cell = tableBot.cell(7, 0); + assertEquals("1st repeatCount", "+14", cell); + cell = tableBot.cell(7, 1); + assertEquals("1st Timestamp", "Jan 1 06:06:06", cell); + cell = tableBot.cell(7, 2); + assertEquals("1st Host", "HostF", cell); + cell = tableBot.cell(7, 3); + assertEquals("1st Logger", "LoggerF", cell); + cell = tableBot.cell(7, 4); + assertEquals("1st File", "SourceFile", cell); + cell = tableBot.cell(7, 5); + assertEquals("1st Line", "9", cell); + cell = tableBot.cell(7, 6); + assertEquals("1st Message", "Message F", cell); + + /* Verify second collapsed event */ + cell = tableBot.cell(8, 0); + assertEquals("2nd repeatCount", "+1", cell); + cell = tableBot.cell(8, 1); + assertEquals("2nd Timestamp", "Jan 1 06:06:21", cell); + cell = tableBot.cell(8, 2); + assertEquals("2nd Host", "HostF", cell); + cell = tableBot.cell(8, 3); + assertEquals("2nd Logger", "LoggerF", cell); + cell = tableBot.cell(8, 4); + assertEquals("2nd File", "SourceFile", cell); + cell = tableBot.cell(8, 5); + assertEquals("2nd Line", "10", cell); + cell = tableBot.cell(8, 6); + assertEquals("2nd Message", "Message D", cell); + + /* Clear Filter */ + menuBot = tableBot.contextMenu("Clear Filters"); + menuBot.click(); + fBot.waitUntil(ConditionHelpers.isTableCellFilled(tableBot, "Jan 1 01:01:01", 1, 1)); + assertEquals("Timestamp", "Jan 1 01:01:01", tableBot.cell(1, 1)); + + SWTBotUtils.maximizeTable(tableBot); + + fBot.closeAllEditors(); + SWTBotUtils.deleteProject(TRACE_PROJECT_NAME, fBot); + } +} |