1 /*******************************************************************************
2 * Copyright (c) 2015 Ericsson
4 * All rights reserved. This program and the accompanying materials are
5 * made available under the terms of the Eclipse Public License v1.0 which
6 * accompanies this distribution, and is available at
7 * http://www.eclipse.org/legal/epl-v10.html
8 *******************************************************************************/
10 package org
.eclipse
.tracecompass
.lttng2
.control
.ui
.swtbot
.tests
;
12 import static org
.junit
.Assert
.assertEquals
;
13 import static org
.junit
.Assert
.assertNotNull
;
14 import static org
.junit
.Assert
.assertTrue
;
19 import org
.apache
.log4j
.ConsoleAppender
;
20 import org
.apache
.log4j
.Logger
;
21 import org
.apache
.log4j
.SimpleLayout
;
22 import org
.eclipse
.core
.resources
.IProject
;
23 import org
.eclipse
.core
.resources
.IWorkspace
;
24 import org
.eclipse
.core
.resources
.ResourcesPlugin
;
25 import org
.eclipse
.core
.runtime
.FileLocator
;
26 import org
.eclipse
.core
.runtime
.IPath
;
27 import org
.eclipse
.core
.runtime
.Path
;
28 import org
.eclipse
.jdt
.annotation
.NonNull
;
29 import org
.eclipse
.remote
.core
.IRemoteConnection
;
30 import org
.eclipse
.swtbot
.eclipse
.finder
.SWTWorkbenchBot
;
31 import org
.eclipse
.swtbot
.eclipse
.finder
.widgets
.SWTBotView
;
32 import org
.eclipse
.swtbot
.swt
.finder
.SWTBot
;
33 import org
.eclipse
.swtbot
.swt
.finder
.junit
.SWTBotJunit4ClassRunner
;
34 import org
.eclipse
.swtbot
.swt
.finder
.utils
.SWTBotPreferences
;
35 import org
.eclipse
.swtbot
.swt
.finder
.waits
.Conditions
;
36 import org
.eclipse
.swtbot
.swt
.finder
.widgets
.SWTBotButton
;
37 import org
.eclipse
.swtbot
.swt
.finder
.widgets
.SWTBotCheckBox
;
38 import org
.eclipse
.swtbot
.swt
.finder
.widgets
.SWTBotMenu
;
39 import org
.eclipse
.swtbot
.swt
.finder
.widgets
.SWTBotShell
;
40 import org
.eclipse
.swtbot
.swt
.finder
.widgets
.SWTBotText
;
41 import org
.eclipse
.swtbot
.swt
.finder
.widgets
.SWTBotTree
;
42 import org
.eclipse
.swtbot
.swt
.finder
.widgets
.SWTBotTreeItem
;
43 import org
.eclipse
.tracecompass
.ctf
.core
.tests
.shared
.LttngTraceGenerator
;
44 import org
.eclipse
.tracecompass
.internal
.lttng2
.control
.core
.model
.TargetNodeState
;
45 import org
.eclipse
.tracecompass
.internal
.lttng2
.control
.core
.model
.TraceSessionState
;
46 import org
.eclipse
.tracecompass
.internal
.lttng2
.control
.stubs
.service
.TestRemoteSystemProxy
;
47 import org
.eclipse
.tracecompass
.internal
.lttng2
.control
.ui
.views
.ControlView
;
48 import org
.eclipse
.tracecompass
.internal
.lttng2
.control
.ui
.views
.model
.ITraceControlComponent
;
49 import org
.eclipse
.tracecompass
.internal
.lttng2
.control
.ui
.views
.model
.impl
.TargetNodeComponent
;
50 import org
.eclipse
.tracecompass
.internal
.lttng2
.control
.ui
.views
.model
.impl
.TraceSessionComponent
;
51 import org
.eclipse
.tracecompass
.tmf
.remote
.core
.proxy
.TmfRemoteConnectionFactory
;
52 import org
.eclipse
.tracecompass
.tmf
.ui
.project
.model
.TmfExperimentElement
;
53 import org
.eclipse
.tracecompass
.tmf
.ui
.project
.model
.TmfExperimentFolder
;
54 import org
.eclipse
.tracecompass
.tmf
.ui
.project
.model
.TmfProjectElement
;
55 import org
.eclipse
.tracecompass
.tmf
.ui
.project
.model
.TmfProjectRegistry
;
56 import org
.eclipse
.tracecompass
.tmf
.ui
.swtbot
.tests
.shared
.ConditionHelpers
;
57 import org
.eclipse
.tracecompass
.tmf
.ui
.swtbot
.tests
.shared
.SWTBotUtils
;
58 import org
.eclipse
.ui
.IViewPart
;
59 import org
.junit
.After
;
60 import org
.junit
.Before
;
61 import org
.junit
.BeforeClass
;
62 import org
.junit
.Test
;
63 import org
.junit
.runner
.RunWith
;
64 import org
.osgi
.framework
.FrameworkUtil
;
67 * Test for the LTTng Control view in Trace Compass
69 * @author Bernd Hufmann
71 @RunWith(SWTBotJunit4ClassRunner
.class)
72 public class ControlViewTest
{
75 // ------------------------------------------------------------------------
77 // ------------------------------------------------------------------------
78 private static final String TEST_STREAM
= "CreateSessionTestLTTng2_8.cfg";
79 /** The initialize scenario name */
80 protected static final String INIT_SCENARIO_NAME
= "Initialize";
81 private static final String CREATE_SESSION_WITH_LTTNG_2_8_SCENARIO_NAME
= "CreateSession_2.8";
83 private static final String SESSION_NAME
= "mysession";
84 private static final String UST_CHANNEL_NAME
= ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
;
85 private static final String NODE_NAME
= "myNode";
86 private static final String PERSPECTIVE_ID
= "org.eclipse.tracecompass.lttng2.control.ui.swtbot.tests.perspective";
88 // ------------------------------------------------------------------------
90 // ------------------------------------------------------------------------
92 /** The Log4j logger instance. */
93 protected static final Logger fLogger
= Logger
.getRootLogger();
94 /** The workbench bot */
95 protected static SWTWorkbenchBot fBot
;
96 private IRemoteConnection fHost
= TmfRemoteConnectionFactory
.getLocalConnection();
97 /** The test remote system proxy */
98 protected @NonNull TestRemoteSystemProxy fProxy
= new TestRemoteSystemProxy(fHost
);
99 /** The trace control tree */
100 protected SWTBotTree fTree
;
101 /** The trace control root component */
102 protected ITraceControlComponent fRoot
;
103 /** The target node component */
104 protected TargetNodeComponent fNode
;
107 protected String fTestFile
;
109 // ------------------------------------------------------------------------
111 // ------------------------------------------------------------------------
117 public static void init() {
118 SWTBotUtils
.initialize();
120 Thread
.currentThread().setName("SWTBot Thread"); // for the debugger
121 /* set up for swtbot */
122 SWTBotPreferences
.TIMEOUT
= 20000; /* 20 second timeout */
123 fLogger
.addAppender(new ConsoleAppender(new SimpleLayout()));
124 fBot
= new SWTWorkbenchBot();
126 SWTBotUtils
.closeView("welcome", fBot
);
128 /* finish waiting for eclipse to load */
129 SWTBotUtils
.waitForJobs();
131 SWTBotUtils
.switchToPerspective(PERSPECTIVE_ID
);
135 * Open a trace in an editor
141 public void beforeTest() throws Exception
{
142 SWTBotUtils
.openView(ControlView
.ID
);
143 SWTBotUtils
.waitForJobs();
144 URL location
= FileLocator
.find(FrameworkUtil
.getBundle(this.getClass()), new Path("testfiles" + File
.separator
+ getTestStream()), null);
145 File testfile
= new File(FileLocator
.toFileURL(location
).toURI());
146 fTestFile
= testfile
.getAbsolutePath();
148 // Create root component
149 SWTBotView viewBot
= fBot
.viewById(ControlView
.ID
);
151 IViewPart part
= viewBot
.getViewReference().getView(true);
152 ControlView view
= (ControlView
) part
;
153 fRoot
= view
.getTraceControlRoot();
155 // Create node component
156 fNode
= new TargetNodeComponent(getNodeName(), fRoot
, fProxy
);
157 fRoot
.addChild(fNode
);
158 fTree
= viewBot
.bot().tree();
165 public void tearDown() {
166 fBot
.closeAllEditors();
168 fRoot
.removeAllChildren();
173 * Get the test stream file name to use for the test suite
175 * @return the name of the test stream file
177 protected String
getTestStream() {
182 * Get the session name
184 * @return the session name for this test
186 protected String
getSessionName() {
193 * @return the node name for the test
195 protected String
getNodeName() {
200 * Test basic trace session generation.
203 public void testTraceSessionTree() {
205 fProxy
.setTestFile(fTestFile
);
206 fProxy
.setScenario(INIT_SCENARIO_NAME
);
210 fProxy
.setScenario(CREATE_SESSION_WITH_LTTNG_2_8_SCENARIO_NAME
);
212 testEnableKernelEvent();
213 testEnableSyscalls();
214 testEnableUstChannel();
215 testEnableUstEvents();
216 testStartStopTracing(TraceSessionState
.ACTIVE
);
217 testStartStopTracing(TraceSessionState
.INACTIVE
);
218 // Import without experiment creation
219 testImport(false, true);
220 SWTBotUtils
.clearTracesFolder(fBot
, ControlViewSwtBotUtil
.DEFAULT_REMOTE_PROJECT
);
221 // Import with experiment creation (default experiment name)
222 testImport(true, true);
223 SWTBotUtils
.clearTracesFolder(fBot
, ControlViewSwtBotUtil
.DEFAULT_REMOTE_PROJECT
);
225 * Import with experiment creation, test experiment already exists and
226 * with experiment name validation
228 testImport(true, false);
229 SWTBotUtils
.clearExperimentFolder(fBot
, ControlViewSwtBotUtil
.DEFAULT_REMOTE_PROJECT
);
230 testDestroySession();
231 testDisconnectFromNode();
232 SWTBotUtils
.deleteProject(ControlViewSwtBotUtil
.DEFAULT_REMOTE_PROJECT
, fBot
);
236 * Test connect to node
238 protected void testConnectToNode() {
239 SWTBotTreeItem nodeItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
, getNodeName());
241 SWTBotMenu menuBot
= nodeItem
.contextMenu(ControlViewSwtBotUtil
.CONNECT_MENU_ITEM
);
243 SWTBotUtils
.waitForJobs();
245 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(ControlViewSwtBotUtil
.SESSION_GROUP_NAME
, nodeItem
));
247 // Verify that node is connected
248 fBot
.waitUntil(ControlViewSwtBotUtil
.isStateChanged(fNode
, TargetNodeState
.CONNECTED
));
249 assertEquals(TargetNodeState
.CONNECTED
, fNode
.getTargetNodeState());
253 * Test create session
255 protected void testCreateSession() {
256 SWTBotTreeItem nodeItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
, getNodeName());
258 SWTBotTreeItem sessionGroupItem
= nodeItem
.getNode(ControlViewSwtBotUtil
.SESSION_GROUP_NAME
);
260 sessionGroupItem
.select();
261 SWTBotMenu menuBot
= sessionGroupItem
.contextMenu(ControlViewSwtBotUtil
.CREATE_SESSION_MENU_ITEM
);
264 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.CREATE_SESSION_DIALOG_TITLE
).activate();
266 SWTBotText sessionText
= shell
.bot().textWithLabel(ControlViewSwtBotUtil
.SESSION_NAME_LABEL
);
267 sessionText
.setText(SESSION_NAME
);
269 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
270 SWTBotUtils
.waitForJobs();
272 sessionGroupItem
.expand();
274 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(getSessionName(), sessionGroupItem
));
275 assertEquals(1, sessionGroupItem
.getNodes().size());
277 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
279 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
281 assertEquals(getSessionName(), sessionItem
.getText());
285 * Test enable event (all kernel tracepoints) on session level
287 protected void testEnableKernelEvent() {
288 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
290 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
293 sessionItem
.select();
294 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.ENABLE_EVENT_DEFAULT_CHANNEL_MENU_ITEM
);
297 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.ENABLE_EVENT_DIALOG_TITLE
).activate();
299 shell
.bot().radioInGroup(ControlViewSwtBotUtil
.GROUP_SELECT_NAME
, ControlViewSwtBotUtil
.TRACEPOINTS_GROUP_NAME
).click();
301 SWTBotTree tracepointsTree
= shell
.bot().treeInGroup(ControlViewSwtBotUtil
.TRACEPOINTS_GROUP_NAME
);
302 SWTBotTreeItem allItem
= SWTBotUtils
.getTreeItem(fBot
, tracepointsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
);
304 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
305 SWTBotUtils
.waitForJobs();
307 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, sessionItem
));
309 SWTBotTreeItem channelItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
311 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
313 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
314 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
);
315 assertEquals(ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
, channelItem
.getText());
317 SWTBotTreeItem eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
319 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
321 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
322 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
,
323 ControlViewSwtBotUtil
.ALL_EVENTS_NAME
);
324 assertEquals(ControlViewSwtBotUtil
.ALL_EVENTS_NAME
, eventItem
.getText());
326 SWTBotTreeItem kernelDomainItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
328 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
330 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
);
331 assertEquals(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, kernelDomainItem
.getText());
335 * Test enable Event (syscall) on domain level
337 protected void testEnableSyscalls() {
338 // Case 1: Enabling all syscalls
339 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
341 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
344 sessionItem
.select();
345 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.ENABLE_EVENT_DEFAULT_CHANNEL_MENU_ITEM
);
348 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.ENABLE_EVENT_DIALOG_TITLE
).activate();
349 shell
.bot().radioInGroup(ControlViewSwtBotUtil
.GROUP_SELECT_NAME
, ControlViewSwtBotUtil
.SYSCALL_GROUP_NAME
).click();
351 SWTBotTree syscallsTree
= shell
.bot().treeInGroup(ControlViewSwtBotUtil
.SYSCALL_GROUP_NAME
);
352 SWTBotTreeItem allItem
= SWTBotUtils
.getTreeItem(fBot
, syscallsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
);
354 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
355 SWTBotUtils
.waitForJobs();
357 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, sessionItem
));
359 SWTBotTreeItem kernelDomainItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
361 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
363 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
);
364 assertEquals(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, kernelDomainItem
.getText());
366 SWTBotTreeItem channelItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
368 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
370 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
371 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
);
372 assertEquals(ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
, channelItem
.getText());
374 SWTBotTreeItem eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
376 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
378 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
379 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
,
380 ControlViewSwtBotUtil
.ALL_EVENTS_NAME
);
381 assertEquals(ControlViewSwtBotUtil
.ALL_EVENTS_NAME
, eventItem
.getText());
383 // Case 2: Enabling three syscalls (write, read, close) from the syscall tree
384 sessionItem
.select();
385 menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.ENABLE_EVENT_DEFAULT_CHANNEL_MENU_ITEM
);
388 shell
= fBot
.shell(ControlViewSwtBotUtil
.ENABLE_EVENT_DIALOG_TITLE
).activate();
389 shell
.bot().radioInGroup(ControlViewSwtBotUtil
.GROUP_SELECT_NAME
, ControlViewSwtBotUtil
.SYSCALL_GROUP_NAME
).click();
390 syscallsTree
= shell
.bot().treeInGroup(ControlViewSwtBotUtil
.SYSCALL_GROUP_NAME
);
391 allItem
= SWTBotUtils
.getTreeItem(fBot
, syscallsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
);
393 // Enable 'write' syscall
394 SWTBotTreeItem writeItem
= SWTBotUtils
.getTreeItem(fBot
, syscallsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
, ControlViewSwtBotUtil
.SYSCALL_WRITE_EVENT
);
396 // Enable 'read' syscall
397 SWTBotTreeItem readItem
= SWTBotUtils
.getTreeItem(fBot
, syscallsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
, ControlViewSwtBotUtil
.SYSCALL_READ_EVENT
);
399 // Enable 'close' syscall
400 SWTBotTreeItem closeItem
= SWTBotUtils
.getTreeItem(fBot
, syscallsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
, ControlViewSwtBotUtil
.SYSCALL_CLOSE_EVENT
);
402 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
403 SWTBotUtils
.waitForJobs();
405 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, sessionItem
));
407 kernelDomainItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
409 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
411 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
);
412 assertEquals(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, kernelDomainItem
.getText());
414 channelItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
416 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
418 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
419 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
);
420 assertEquals(ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
, channelItem
.getText());
422 eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
424 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
426 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
427 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
,
428 ControlViewSwtBotUtil
.SYSCALL_WRITE_EVENT
);
429 assertEquals(ControlViewSwtBotUtil
.SYSCALL_WRITE_EVENT
, eventItem
.getText());
431 eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
433 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
435 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
436 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
,
437 ControlViewSwtBotUtil
.SYSCALL_READ_EVENT
);
438 assertEquals(ControlViewSwtBotUtil
.SYSCALL_READ_EVENT
, eventItem
.getText());
440 eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
442 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
444 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
445 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
,
446 ControlViewSwtBotUtil
.SYSCALL_CLOSE_EVENT
);
447 assertEquals(ControlViewSwtBotUtil
.SYSCALL_CLOSE_EVENT
, eventItem
.getText());
451 * Test enable UST channel on session level (default values)
453 protected void testEnableUstChannel() {
454 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
456 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
458 sessionItem
.select();
459 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.ENABLE_CHANNEL_MENU_ITEM
);
462 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.ENABLE_CHANNEL_DIALOG_TITLE
).activate();
463 SWTBotText channelText
= shell
.bot().textWithLabel(ControlViewSwtBotUtil
.CHANNEL_NAME_LABEL
);
464 channelText
.setText(UST_CHANNEL_NAME
);
466 shell
.bot().radioInGroup(ControlViewSwtBotUtil
.UST_GROUP_NAME
, ControlViewSwtBotUtil
.DOMAIN_GROUP_NAME
).click();
467 shell
.bot().radioInGroup(ControlViewSwtBotUtil
.BUFFERTYPE_PER_UID
, ControlViewSwtBotUtil
.BUFFERTYPE_GROUP_NAME
).click();
468 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
469 SWTBotUtils
.waitForJobs();
470 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(ControlViewSwtBotUtil
.UST_DOMAIN_NAME
, sessionItem
));
474 * Test enable event (all tracepoints) on channel level
476 protected void testEnableUstEvents() {
477 SWTBotTreeItem channelItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
479 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
480 getSessionName(), ControlViewSwtBotUtil
.UST_DOMAIN_NAME
,
482 assertEquals(UST_CHANNEL_NAME
, channelItem
.getText());
484 channelItem
.select();
485 SWTBotMenu menuBot
= channelItem
.contextMenu(ControlViewSwtBotUtil
.ENABLE_EVENT_MENU_ITEM
);
488 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.ENABLE_EVENT_DIALOG_TITLE
).activate();
489 SWTBotTree tracepointsTree
= shell
.bot().tree();
490 tracepointsTree
.select(ControlViewSwtBotUtil
.ALL_TREE_NODE
);
491 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
492 SWTBotUtils
.waitForJobs();
494 SWTBotTreeItem eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
496 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
498 ControlViewSwtBotUtil
.UST_DOMAIN_NAME
,
500 ControlViewSwtBotUtil
.ALL_EVENTS_NAME
);
501 assertEquals(ControlViewSwtBotUtil
.ALL_EVENTS_NAME
, eventItem
.getText());
505 * Test start or stop tracing
508 * the state to change to
510 protected void testStartStopTracing(TraceSessionState state
) {
511 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
513 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
515 sessionItem
.select();
517 if (state
== TraceSessionState
.ACTIVE
) {
518 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.START_MENU_ITEM
);
520 SWTBotUtils
.waitForJobs();
522 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.STOP_MENU_ITEM
);
524 SWTBotUtils
.waitForJobs();
526 TraceSessionComponent sessionComp
= ControlViewSwtBotUtil
.getSessionComponent(fNode
, getSessionName());
528 fBot
.waitUntil(ControlViewSwtBotUtil
.isSessionStateChanged(sessionComp
, state
));
529 assertEquals(state
, sessionComp
.getSessionState());
533 * Test destroy session
535 protected void testDestroySession() {
536 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
538 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
541 sessionItem
.select();
542 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.DESTROY_MENU_ITEM
);
545 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.DESTROY_CONFIRM_DIALOG_TITLE
).activate();
546 shell
.bot().button(ControlViewSwtBotUtil
.CONFIRM_DIALOG_OK_BUTTON
).click();
547 SWTBotUtils
.waitForJobs();
549 SWTBotTreeItem sessionGroupItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
550 getNodeName(), ControlViewSwtBotUtil
.SESSION_GROUP_NAME
);
552 fBot
.waitUntil(ConditionHelpers
.isTreeChildNodeRemoved(0, sessionGroupItem
));
553 assertEquals(0, sessionGroupItem
.getNodes().size());
557 * Test disconnect from node
559 protected void testDisconnectFromNode() {
560 SWTBotTreeItem nodeItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
, getNodeName());
562 SWTBotMenu menuBot
= nodeItem
.contextMenu(ControlViewSwtBotUtil
.DISCONNECT_MENU_ITEM
);
564 SWTBotUtils
.waitForJobs();
566 // Verify that node is connected
567 fBot
.waitUntil(ControlViewSwtBotUtil
.isStateChanged(fNode
, TargetNodeState
.DISCONNECTED
));
568 assertEquals(TargetNodeState
.DISCONNECTED
, fNode
.getTargetNodeState());
569 assertEquals(0, nodeItem
.getNodes().size());
575 * @param createExperiment
576 * flag to indicate to create an experiment or not
577 * @param defaultExperiment
578 * flag to indicate to use default experiment or not
580 protected void testImport(boolean createExperiment
, boolean defaultExperiment
) {
581 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
583 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
585 sessionItem
.select();
586 TraceSessionComponent sessionComp
= ControlViewSwtBotUtil
.getSessionComponent(fNode
, getSessionName());
588 String pathString
= sessionComp
.isSnapshotSession() ? sessionComp
.getSnapshotInfo().getSnapshotPath() : sessionComp
.getSessionPath();
589 IPath path
= new Path(pathString
);
591 IWorkspace workspace
= ResourcesPlugin
.getWorkspace();
593 //get location of workspace (java.io.File)
594 File workspaceDirectory
= workspace
.getRoot().getLocation().toFile();
595 Path workspacePath
= new Path(workspaceDirectory
.toString());
597 // Only do tests if session path is in workspace
598 if (workspacePath
.isPrefixOf(path
)) {
602 // Open import wizard
603 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.IMPORT_MENU_ITEM
);
605 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.IMPORT_WIZARD_TITLE
).activate();
607 // This will create the Remote project if needed
608 closeImportWizard(shell
, ControlViewSwtBotUtil
.CANCEL_BUTTON
);
610 // Verify that remote project was created by import wizard
611 TmfProjectElement tmfProject
= verifyRemoteProject();
613 // Re-open import wizard
614 menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.IMPORT_MENU_ITEM
);
616 shell
= fBot
.shell(ControlViewSwtBotUtil
.IMPORT_WIZARD_TITLE
).activate();
618 // Prepare and verify experiment handling
619 String experimentName
= prepareAndVerifyExperimentHandling(shell
.bot(), createExperiment
, defaultExperiment
, path
);
622 closeImportWizard(shell
, ControlViewSwtBotUtil
.FINISH_BUTTON
);
624 // Verify experiment folder
625 verifyExperimentFolder(createExperiment
, tmfProject
, experimentName
);
630 private static TmfProjectElement
verifyRemoteProject() {
631 IProject project
= ResourcesPlugin
.getWorkspace().getRoot().getProject(ControlViewSwtBotUtil
.DEFAULT_REMOTE_PROJECT
);
632 // verify that project was created
633 assertTrue(project
.exists());
634 TmfProjectElement tmfProject
= TmfProjectRegistry
.getProject(project
, true);
638 private static void verifyExperimentFolder(boolean createExperiment
, TmfProjectElement tmfProject
, String experimentName
) {
639 TmfExperimentFolder expFolder
= tmfProject
.getExperimentsFolder();
640 if (createExperiment
) {
641 if (experimentName
!= null) {
642 TmfExperimentElement expElement
= expFolder
.getExperiment(experimentName
);
643 assertNotNull(expElement
);
644 assertEquals(1, expElement
.getTraces().size());
647 assertTrue(expFolder
.getExperiments().size() == 0);
651 private static void generateTrace(IPath path
) {
652 File traceParent
= path
.toFile();
653 traceParent
.mkdirs();
654 LttngTraceGenerator
.generateLttngTrace(path
.append(ControlViewSwtBotUtil
.KERNEL_TRACE_NAME
).toFile());
657 private static void closeImportWizard(SWTBotShell shell
, String buttonName
) {
658 SWTBotButton button
= shell
.bot().button(buttonName
);
659 shell
.bot().waitUntil(Conditions
.widgetIsEnabled(button
));
661 fBot
.waitUntil(Conditions
.shellCloses(shell
));
662 SWTBotUtils
.waitForJobs();
665 private static String
prepareAndVerifyExperimentHandling(SWTBot bot
, boolean createExperiment
, boolean defaultExperiment
, IPath path
) {
666 String experimentName
= path
.lastSegment();
667 if (createExperiment
) {
668 SWTBotCheckBox checkBox
= bot
.checkBox();
670 if (!defaultExperiment
) {
671 experimentName
= verifyExperimentNameHandling(bot
, experimentName
);
674 return experimentName
;
677 private static @NonNull String
verifyExperimentNameHandling(SWTBot bot
, String aExperimentName
) {
678 String experimentName
= aExperimentName
;
680 // experiment already exists
681 checkFinishButton(bot
, false);
683 SWTBotText expText
= bot
.textInGroup(ControlViewSwtBotUtil
.OPTION_GROUP_NAME
);
685 // Invalid experiment name (only whitespaces)
686 expText
.setText(String
.valueOf(' '));
687 checkFinishButton(bot
, false);
689 // Invalid experiment name
690 expText
.setText(String
.valueOf('/'));
691 checkFinishButton(bot
, false);
693 // Set valid experiment name
694 experimentName
+= '_';
695 expText
.setText(experimentName
);
696 return experimentName
;
699 private static void checkFinishButton(SWTBot bot
, boolean isEnabled
) {
700 final SWTBotButton finishButton
= bot
.button(ControlViewSwtBotUtil
.FINISH_BUTTON
);
701 assertTrue(finishButton
.isEnabled() == isEnabled
);