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
.tracecompass
.tmf
.ui
.tests
.shared
.WaitUtils
;
59 import org
.eclipse
.ui
.IViewPart
;
60 import org
.junit
.After
;
61 import org
.junit
.Before
;
62 import org
.junit
.BeforeClass
;
63 import org
.junit
.Test
;
64 import org
.junit
.runner
.RunWith
;
65 import org
.osgi
.framework
.FrameworkUtil
;
68 * Test for the LTTng Control view in Trace Compass
70 * @author Bernd Hufmann
72 @RunWith(SWTBotJunit4ClassRunner
.class)
73 public class ControlViewTest
{
76 // ------------------------------------------------------------------------
78 // ------------------------------------------------------------------------
79 private static final String TEST_STREAM
= "CreateSessionTestLTTng2_8.cfg";
80 /** The initialize scenario name */
81 protected static final String INIT_SCENARIO_NAME
= "Initialize";
82 private static final String CREATE_SESSION_WITH_LTTNG_2_8_SCENARIO_NAME
= "CreateSession_2.8";
84 private static final String SESSION_NAME
= "mysession";
85 private static final String UST_CHANNEL_NAME
= ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
;
86 private static final String NODE_NAME
= "myNode";
87 private static final String PERSPECTIVE_ID
= "org.eclipse.tracecompass.lttng2.control.ui.swtbot.tests.perspective";
89 // ------------------------------------------------------------------------
91 // ------------------------------------------------------------------------
93 /** The Log4j logger instance. */
94 protected static final Logger fLogger
= Logger
.getRootLogger();
95 /** The workbench bot */
96 protected static SWTWorkbenchBot fBot
;
97 private IRemoteConnection fHost
= TmfRemoteConnectionFactory
.getLocalConnection();
98 /** The test remote system proxy */
99 protected @NonNull TestRemoteSystemProxy fProxy
= new TestRemoteSystemProxy(fHost
);
100 /** The trace control tree */
101 protected SWTBotTree fTree
;
102 /** The trace control root component */
103 protected ITraceControlComponent fRoot
;
104 /** The target node component */
105 protected TargetNodeComponent fNode
;
108 protected String fTestFile
;
110 // ------------------------------------------------------------------------
112 // ------------------------------------------------------------------------
118 public static void init() {
119 SWTBotUtils
.initialize();
121 Thread
.currentThread().setName("SWTBot Thread"); // for the debugger
122 /* set up for swtbot */
123 SWTBotPreferences
.TIMEOUT
= 20000; /* 20 second timeout */
124 fLogger
.addAppender(new ConsoleAppender(new SimpleLayout()));
125 fBot
= new SWTWorkbenchBot();
127 SWTBotUtils
.closeView("welcome", fBot
);
129 /* finish waiting for eclipse to load */
130 WaitUtils
.waitForJobs();
132 SWTBotUtils
.switchToPerspective(PERSPECTIVE_ID
);
136 * Open a trace in an editor
142 public void beforeTest() throws Exception
{
143 SWTBotUtils
.openView(ControlView
.ID
);
144 WaitUtils
.waitForJobs();
145 URL location
= FileLocator
.find(FrameworkUtil
.getBundle(this.getClass()), new Path("testfiles" + File
.separator
+ getTestStream()), null);
146 File testfile
= new File(FileLocator
.toFileURL(location
).toURI());
147 fTestFile
= testfile
.getAbsolutePath();
149 // Create root component
150 SWTBotView viewBot
= fBot
.viewById(ControlView
.ID
);
152 IViewPart part
= viewBot
.getViewReference().getView(true);
153 ControlView view
= (ControlView
) part
;
154 fRoot
= view
.getTraceControlRoot();
156 // Create node component
157 fNode
= new TargetNodeComponent(getNodeName(), fRoot
, fProxy
);
158 fRoot
.addChild(fNode
);
159 fTree
= viewBot
.bot().tree();
166 public void tearDown() {
167 fBot
.closeAllEditors();
169 fRoot
.removeAllChildren();
174 * Get the test stream file name to use for the test suite
176 * @return the name of the test stream file
178 protected String
getTestStream() {
183 * Get the session name
185 * @return the session name for this test
187 protected String
getSessionName() {
194 * @return the node name for the test
196 protected String
getNodeName() {
201 * Test basic trace session generation.
204 public void testTraceSessionTree() {
206 fProxy
.setTestFile(fTestFile
);
207 fProxy
.setScenario(INIT_SCENARIO_NAME
);
211 fProxy
.setScenario(CREATE_SESSION_WITH_LTTNG_2_8_SCENARIO_NAME
);
213 testEnableKernelEvent();
214 testEnableSyscalls();
215 testEnableUstChannel();
216 testEnableUstEvents();
217 testStartStopTracing(TraceSessionState
.ACTIVE
);
218 testStartStopTracing(TraceSessionState
.INACTIVE
);
219 // Import without experiment creation
220 testImport(false, true);
221 SWTBotUtils
.clearTracesFolder(fBot
, ControlViewSwtBotUtil
.DEFAULT_REMOTE_PROJECT
);
222 // Import with experiment creation (default experiment name)
223 testImport(true, true);
224 SWTBotUtils
.clearTracesFolder(fBot
, ControlViewSwtBotUtil
.DEFAULT_REMOTE_PROJECT
);
226 * Import with experiment creation, test experiment already exists and
227 * with experiment name validation
229 testImport(true, false);
230 SWTBotUtils
.clearExperimentFolder(fBot
, ControlViewSwtBotUtil
.DEFAULT_REMOTE_PROJECT
);
231 testDestroySession();
232 testDisconnectFromNode();
233 SWTBotUtils
.deleteProject(ControlViewSwtBotUtil
.DEFAULT_REMOTE_PROJECT
, fBot
);
237 * Test connect to node
239 protected void testConnectToNode() {
240 SWTBotTreeItem nodeItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
, getNodeName());
242 SWTBotMenu menuBot
= nodeItem
.contextMenu(ControlViewSwtBotUtil
.CONNECT_MENU_ITEM
);
244 WaitUtils
.waitForJobs();
246 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(ControlViewSwtBotUtil
.SESSION_GROUP_NAME
, nodeItem
));
248 // Verify that node is connected
249 fBot
.waitUntil(ControlViewSwtBotUtil
.isStateChanged(fNode
, TargetNodeState
.CONNECTED
));
250 assertEquals(TargetNodeState
.CONNECTED
, fNode
.getTargetNodeState());
254 * Test create session
256 protected void testCreateSession() {
257 SWTBotTreeItem nodeItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
, getNodeName());
259 SWTBotTreeItem sessionGroupItem
= nodeItem
.getNode(ControlViewSwtBotUtil
.SESSION_GROUP_NAME
);
261 sessionGroupItem
.select();
262 SWTBotMenu menuBot
= sessionGroupItem
.contextMenu(ControlViewSwtBotUtil
.CREATE_SESSION_MENU_ITEM
);
265 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.CREATE_SESSION_DIALOG_TITLE
).activate();
267 SWTBotText sessionText
= shell
.bot().textWithLabel(ControlViewSwtBotUtil
.SESSION_NAME_LABEL
);
268 sessionText
.setText(SESSION_NAME
);
270 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
271 WaitUtils
.waitForJobs();
273 sessionGroupItem
.expand();
275 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(getSessionName(), sessionGroupItem
));
276 assertEquals(1, sessionGroupItem
.getNodes().size());
278 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
280 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
282 assertEquals(getSessionName(), sessionItem
.getText());
286 * Test enable event (all kernel tracepoints) on session level
288 protected void testEnableKernelEvent() {
289 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
291 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
294 sessionItem
.select();
295 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.ENABLE_EVENT_DEFAULT_CHANNEL_MENU_ITEM
);
298 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.ENABLE_EVENT_DIALOG_TITLE
).activate();
300 shell
.bot().radioInGroup(ControlViewSwtBotUtil
.GROUP_SELECT_NAME
, ControlViewSwtBotUtil
.TRACEPOINTS_GROUP_NAME
).click();
302 SWTBotTree tracepointsTree
= shell
.bot().treeInGroup(ControlViewSwtBotUtil
.TRACEPOINTS_GROUP_NAME
);
303 SWTBotTreeItem allItem
= SWTBotUtils
.getTreeItem(fBot
, tracepointsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
);
305 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
306 WaitUtils
.waitForJobs();
308 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, sessionItem
));
310 SWTBotTreeItem channelItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
312 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
314 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
315 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
);
316 assertEquals(ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
, channelItem
.getText());
318 SWTBotTreeItem eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
320 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
322 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
323 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
,
324 ControlViewSwtBotUtil
.ALL_EVENTS_NAME
);
325 assertEquals(ControlViewSwtBotUtil
.ALL_EVENTS_NAME
, eventItem
.getText());
327 SWTBotTreeItem kernelDomainItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
329 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
331 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
);
332 assertEquals(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, kernelDomainItem
.getText());
336 * Test enable Event (syscall) on domain level
338 protected void testEnableSyscalls() {
339 // Case 1: Enabling all syscalls
340 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
342 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
345 sessionItem
.select();
346 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.ENABLE_EVENT_DEFAULT_CHANNEL_MENU_ITEM
);
349 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.ENABLE_EVENT_DIALOG_TITLE
).activate();
350 shell
.bot().radioInGroup(ControlViewSwtBotUtil
.GROUP_SELECT_NAME
, ControlViewSwtBotUtil
.SYSCALL_GROUP_NAME
).click();
352 SWTBotTree syscallsTree
= shell
.bot().treeInGroup(ControlViewSwtBotUtil
.SYSCALL_GROUP_NAME
);
353 SWTBotTreeItem allItem
= SWTBotUtils
.getTreeItem(fBot
, syscallsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
);
355 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
356 WaitUtils
.waitForJobs();
358 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, sessionItem
));
360 SWTBotTreeItem kernelDomainItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
362 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
364 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
);
365 assertEquals(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, kernelDomainItem
.getText());
367 SWTBotTreeItem channelItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
369 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
371 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
372 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
);
373 assertEquals(ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
, channelItem
.getText());
375 SWTBotTreeItem eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
377 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
379 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
380 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
,
381 ControlViewSwtBotUtil
.ALL_EVENTS_NAME
);
382 assertEquals(ControlViewSwtBotUtil
.ALL_EVENTS_NAME
, eventItem
.getText());
384 // Case 2: Enabling three syscalls (write, read, close) from the syscall tree
385 sessionItem
.select();
386 menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.ENABLE_EVENT_DEFAULT_CHANNEL_MENU_ITEM
);
389 shell
= fBot
.shell(ControlViewSwtBotUtil
.ENABLE_EVENT_DIALOG_TITLE
).activate();
390 shell
.bot().radioInGroup(ControlViewSwtBotUtil
.GROUP_SELECT_NAME
, ControlViewSwtBotUtil
.SYSCALL_GROUP_NAME
).click();
391 syscallsTree
= shell
.bot().treeInGroup(ControlViewSwtBotUtil
.SYSCALL_GROUP_NAME
);
392 allItem
= SWTBotUtils
.getTreeItem(fBot
, syscallsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
);
394 // Enable 'write' syscall
395 SWTBotTreeItem writeItem
= SWTBotUtils
.getTreeItem(fBot
, syscallsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
, ControlViewSwtBotUtil
.SYSCALL_WRITE_EVENT
);
397 // Enable 'read' syscall
398 SWTBotTreeItem readItem
= SWTBotUtils
.getTreeItem(fBot
, syscallsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
, ControlViewSwtBotUtil
.SYSCALL_READ_EVENT
);
400 // Enable 'close' syscall
401 SWTBotTreeItem closeItem
= SWTBotUtils
.getTreeItem(fBot
, syscallsTree
, ControlViewSwtBotUtil
.ALL_TREE_NODE
, ControlViewSwtBotUtil
.SYSCALL_CLOSE_EVENT
);
403 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
404 WaitUtils
.waitForJobs();
406 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, sessionItem
));
408 kernelDomainItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
410 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
412 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
);
413 assertEquals(ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
, kernelDomainItem
.getText());
415 channelItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
417 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
419 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
420 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
);
421 assertEquals(ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
, channelItem
.getText());
423 eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
425 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
427 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
428 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
,
429 ControlViewSwtBotUtil
.SYSCALL_WRITE_EVENT
);
430 assertEquals(ControlViewSwtBotUtil
.SYSCALL_WRITE_EVENT
, eventItem
.getText());
432 eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
434 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
436 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
437 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
,
438 ControlViewSwtBotUtil
.SYSCALL_READ_EVENT
);
439 assertEquals(ControlViewSwtBotUtil
.SYSCALL_READ_EVENT
, eventItem
.getText());
441 eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
443 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
445 ControlViewSwtBotUtil
.KERNEL_DOMAIN_NAME
,
446 ControlViewSwtBotUtil
.DEFAULT_CHANNEL_NAME
,
447 ControlViewSwtBotUtil
.SYSCALL_CLOSE_EVENT
);
448 assertEquals(ControlViewSwtBotUtil
.SYSCALL_CLOSE_EVENT
, eventItem
.getText());
452 * Test enable UST channel on session level (default values)
454 protected void testEnableUstChannel() {
455 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
457 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
459 sessionItem
.select();
460 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.ENABLE_CHANNEL_MENU_ITEM
);
463 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.ENABLE_CHANNEL_DIALOG_TITLE
).activate();
464 SWTBotText channelText
= shell
.bot().textWithLabel(ControlViewSwtBotUtil
.CHANNEL_NAME_LABEL
);
465 channelText
.setText(UST_CHANNEL_NAME
);
467 shell
.bot().radioInGroup(ControlViewSwtBotUtil
.UST_GROUP_NAME
, ControlViewSwtBotUtil
.DOMAIN_GROUP_NAME
).click();
468 shell
.bot().radioInGroup(ControlViewSwtBotUtil
.BUFFERTYPE_PER_UID
, ControlViewSwtBotUtil
.BUFFERTYPE_GROUP_NAME
).click();
469 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
470 WaitUtils
.waitForJobs();
471 fBot
.waitUntil(ConditionHelpers
.IsTreeChildNodeAvailable(ControlViewSwtBotUtil
.UST_DOMAIN_NAME
, sessionItem
));
475 * Test enable event (all tracepoints) on channel level
477 protected void testEnableUstEvents() {
478 SWTBotTreeItem channelItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
480 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
481 getSessionName(), ControlViewSwtBotUtil
.UST_DOMAIN_NAME
,
483 assertEquals(UST_CHANNEL_NAME
, channelItem
.getText());
485 channelItem
.select();
486 SWTBotMenu menuBot
= channelItem
.contextMenu(ControlViewSwtBotUtil
.ENABLE_EVENT_MENU_ITEM
);
489 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.ENABLE_EVENT_DIALOG_TITLE
).activate();
490 SWTBotTree tracepointsTree
= shell
.bot().tree();
491 tracepointsTree
.select(ControlViewSwtBotUtil
.ALL_TREE_NODE
);
492 shell
.bot().button(ControlViewSwtBotUtil
.DIALOG_OK_BUTTON
).click();
493 WaitUtils
.waitForJobs();
495 SWTBotTreeItem eventItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
497 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
499 ControlViewSwtBotUtil
.UST_DOMAIN_NAME
,
501 ControlViewSwtBotUtil
.ALL_EVENTS_NAME
);
502 assertEquals(ControlViewSwtBotUtil
.ALL_EVENTS_NAME
, eventItem
.getText());
506 * Test start or stop tracing
509 * the state to change to
511 protected void testStartStopTracing(TraceSessionState state
) {
512 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
514 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
516 sessionItem
.select();
518 if (state
== TraceSessionState
.ACTIVE
) {
519 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.START_MENU_ITEM
);
521 WaitUtils
.waitForJobs();
523 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.STOP_MENU_ITEM
);
525 WaitUtils
.waitForJobs();
527 TraceSessionComponent sessionComp
= ControlViewSwtBotUtil
.getSessionComponent(fNode
, getSessionName());
529 fBot
.waitUntil(ControlViewSwtBotUtil
.isSessionStateChanged(sessionComp
, state
));
530 assertEquals(state
, sessionComp
.getSessionState());
534 * Test destroy session
536 protected void testDestroySession() {
537 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
539 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
542 sessionItem
.select();
543 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.DESTROY_MENU_ITEM
);
546 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.DESTROY_CONFIRM_DIALOG_TITLE
).activate();
547 shell
.bot().button(ControlViewSwtBotUtil
.CONFIRM_DIALOG_OK_BUTTON
).click();
548 WaitUtils
.waitForJobs();
550 SWTBotTreeItem sessionGroupItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
551 getNodeName(), ControlViewSwtBotUtil
.SESSION_GROUP_NAME
);
553 fBot
.waitUntil(ConditionHelpers
.isTreeChildNodeRemoved(0, sessionGroupItem
));
554 assertEquals(0, sessionGroupItem
.getNodes().size());
558 * Test disconnect from node
560 protected void testDisconnectFromNode() {
561 SWTBotTreeItem nodeItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
, getNodeName());
563 SWTBotMenu menuBot
= nodeItem
.contextMenu(ControlViewSwtBotUtil
.DISCONNECT_MENU_ITEM
);
565 WaitUtils
.waitForJobs();
567 // Verify that node is connected
568 fBot
.waitUntil(ControlViewSwtBotUtil
.isStateChanged(fNode
, TargetNodeState
.DISCONNECTED
));
569 assertEquals(TargetNodeState
.DISCONNECTED
, fNode
.getTargetNodeState());
570 assertEquals(0, nodeItem
.getNodes().size());
576 * @param createExperiment
577 * flag to indicate to create an experiment or not
578 * @param defaultExperiment
579 * flag to indicate to use default experiment or not
581 protected void testImport(boolean createExperiment
, boolean defaultExperiment
) {
582 SWTBotTreeItem sessionItem
= SWTBotUtils
.getTreeItem(fBot
, fTree
,
584 ControlViewSwtBotUtil
.SESSION_GROUP_NAME
,
586 sessionItem
.select();
587 TraceSessionComponent sessionComp
= ControlViewSwtBotUtil
.getSessionComponent(fNode
, getSessionName());
589 String pathString
= sessionComp
.isSnapshotSession() ? sessionComp
.getSnapshotInfo().getSnapshotPath() : sessionComp
.getSessionPath();
590 IPath path
= new Path(pathString
);
592 IWorkspace workspace
= ResourcesPlugin
.getWorkspace();
594 //get location of workspace (java.io.File)
595 File workspaceDirectory
= workspace
.getRoot().getLocation().toFile();
596 Path workspacePath
= new Path(workspaceDirectory
.toString());
598 // Only do tests if session path is in workspace
599 if (workspacePath
.isPrefixOf(path
)) {
603 // Open import wizard
604 SWTBotMenu menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.IMPORT_MENU_ITEM
);
606 SWTBotShell shell
= fBot
.shell(ControlViewSwtBotUtil
.IMPORT_WIZARD_TITLE
).activate();
608 // This will create the Remote project if needed
609 closeImportWizard(shell
, ControlViewSwtBotUtil
.CANCEL_BUTTON
);
611 // Verify that remote project was created by import wizard
612 TmfProjectElement tmfProject
= verifyRemoteProject();
614 // Re-open import wizard
615 menuBot
= sessionItem
.contextMenu(ControlViewSwtBotUtil
.IMPORT_MENU_ITEM
);
617 shell
= fBot
.shell(ControlViewSwtBotUtil
.IMPORT_WIZARD_TITLE
).activate();
619 // Prepare and verify experiment handling
620 String experimentName
= prepareAndVerifyExperimentHandling(shell
.bot(), createExperiment
, defaultExperiment
, path
);
623 closeImportWizard(shell
, ControlViewSwtBotUtil
.FINISH_BUTTON
);
625 // Verify experiment folder
626 verifyExperimentFolder(createExperiment
, tmfProject
, experimentName
);
631 private static TmfProjectElement
verifyRemoteProject() {
632 IProject project
= ResourcesPlugin
.getWorkspace().getRoot().getProject(ControlViewSwtBotUtil
.DEFAULT_REMOTE_PROJECT
);
633 // verify that project was created
634 assertTrue(project
.exists());
635 TmfProjectElement tmfProject
= TmfProjectRegistry
.getProject(project
, true);
639 private static void verifyExperimentFolder(boolean createExperiment
, TmfProjectElement tmfProject
, String experimentName
) {
640 TmfExperimentFolder expFolder
= tmfProject
.getExperimentsFolder();
641 if (createExperiment
) {
642 if (experimentName
!= null) {
643 TmfExperimentElement expElement
= expFolder
.getExperiment(experimentName
);
644 assertNotNull(expElement
);
645 assertEquals(1, expElement
.getTraces().size());
648 assertTrue(expFolder
.getExperiments().size() == 0);
652 private static void generateTrace(IPath path
) {
653 File traceParent
= path
.toFile();
654 traceParent
.mkdirs();
655 LttngTraceGenerator
.generateLttngTrace(path
.append(ControlViewSwtBotUtil
.KERNEL_TRACE_NAME
).toFile());
658 private static void closeImportWizard(SWTBotShell shell
, String buttonName
) {
659 SWTBotButton button
= shell
.bot().button(buttonName
);
660 shell
.bot().waitUntil(Conditions
.widgetIsEnabled(button
));
662 fBot
.waitUntil(Conditions
.shellCloses(shell
));
663 WaitUtils
.waitForJobs();
666 private static String
prepareAndVerifyExperimentHandling(SWTBot bot
, boolean createExperiment
, boolean defaultExperiment
, IPath path
) {
667 String experimentName
= path
.lastSegment();
668 if (createExperiment
) {
669 SWTBotCheckBox checkBox
= bot
.checkBox();
671 if (!defaultExperiment
) {
672 experimentName
= verifyExperimentNameHandling(bot
, experimentName
);
675 return experimentName
;
678 private static @NonNull String
verifyExperimentNameHandling(SWTBot bot
, String aExperimentName
) {
679 String experimentName
= aExperimentName
;
681 // experiment already exists
682 checkFinishButton(bot
, false);
684 SWTBotText expText
= bot
.textInGroup(ControlViewSwtBotUtil
.OPTION_GROUP_NAME
);
686 // Invalid experiment name (only whitespaces)
687 expText
.setText(String
.valueOf(' '));
688 checkFinishButton(bot
, false);
690 // Invalid experiment name
691 expText
.setText(String
.valueOf('/'));
692 checkFinishButton(bot
, false);
694 // Set valid experiment name
695 experimentName
+= '_';
696 expText
.setText(experimentName
);
697 return experimentName
;
700 private static void checkFinishButton(SWTBot bot
, boolean isEnabled
) {
701 final SWTBotButton finishButton
= bot
.button(ControlViewSwtBotUtil
.FINISH_BUTTON
);
702 assertTrue(finishButton
.isEnabled() == isEnabled
);