lttng: Port unit tests to JUnit4
[deliverable/tracecompass.git] / org.eclipse.linuxtools.lttng2.ui.tests / src / org / eclipse / linuxtools / lttng2 / ui / tests / control / model / component / TraceControlTreeModelTest.java
CommitLineData
eb1bab5b 1/**********************************************************************
2ba3d0a1 2 * Copyright (c) 2012, 2013 Ericsson
cfdb727a 3 *
eb1bab5b
BH
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
cfdb727a
AM
8 *
9 * Contributors:
eb1bab5b 10 * Bernd Hufmann - Initial API and implementation
2ba3d0a1 11 * Alexandre Montplaisir - Port to JUnit4
eb1bab5b 12 **********************************************************************/
2ba3d0a1 13
115b4a01 14package org.eclipse.linuxtools.lttng2.ui.tests.control.model.component;
eb1bab5b 15
2ba3d0a1
AM
16import static org.junit.Assert.assertEquals;
17import static org.junit.Assert.assertFalse;
18import static org.junit.Assert.assertNotNull;
19import static org.junit.Assert.assertNotSame;
20import static org.junit.Assert.assertNull;
21import static org.junit.Assert.assertTrue;
22
d132bcc7
BH
23import java.io.File;
24import java.net.URL;
25
d132bcc7
BH
26import org.eclipse.core.runtime.FileLocator;
27import org.eclipse.core.runtime.Path;
9315aeee
BH
28import org.eclipse.linuxtools.internal.lttng2.core.control.model.TargetNodeState;
29import org.eclipse.linuxtools.internal.lttng2.core.control.model.TraceEnablement;
30import org.eclipse.linuxtools.internal.lttng2.core.control.model.TraceEventType;
31import org.eclipse.linuxtools.internal.lttng2.core.control.model.TraceLogLevel;
32import org.eclipse.linuxtools.internal.lttng2.core.control.model.TraceSessionState;
115b4a01
BH
33import org.eclipse.linuxtools.internal.lttng2.stubs.service.TestRemoteSystemProxy;
34import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.ITraceControlComponent;
115b4a01
BH
35import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.BaseEventComponent;
36import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.KernelProviderComponent;
37import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.TargetNodeComponent;
38import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.TraceChannelComponent;
4ea599a5 39import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.TraceDomainComponent;
115b4a01
BH
40import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.TraceEventComponent;
41import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.TraceProbeEventComponent;
42import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.TraceProviderGroup;
43import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.TraceSessionComponent;
44import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.TraceSessionGroup;
45import org.eclipse.linuxtools.internal.lttng2.ui.views.control.model.impl.UstProviderComponent;
46import org.eclipse.linuxtools.internal.lttng2.ui.views.control.service.ILttngControlService;
47import org.eclipse.linuxtools.internal.lttng2.ui.views.control.service.LTTngControlService;
8577ed1e 48import org.eclipse.rse.core.RSECorePlugin;
eb1bab5b 49import org.eclipse.rse.core.model.IHost;
8577ed1e
BH
50import org.eclipse.rse.core.model.ISystemProfile;
51import org.eclipse.rse.core.model.ISystemRegistry;
eb1bab5b 52import org.eclipse.swt.graphics.Image;
eb1bab5b
BH
53import org.junit.After;
54import org.junit.Before;
2ba3d0a1 55import org.junit.Test;
9269df72 56import org.osgi.framework.FrameworkUtil;
eb1bab5b
BH
57
58/**
2ba3d0a1
AM
59 * The class <code>TraceControlTreeModelTest</code> contains tests for the tree
60 * component classes.
eb1bab5b
BH
61 */
62@SuppressWarnings("nls")
2ba3d0a1 63public class TraceControlTreeModelTest {
cfdb727a 64
a26d90be
BH
65 // ------------------------------------------------------------------------
66 // Constants
67 // ------------------------------------------------------------------------
68
d132bcc7
BH
69 private static final String TEST_STREAM = "ListInfoTest.cfg";
70 private static final String SCEN_LIST_INFO_TEST = "ListInfoTest";
4ea599a5 71 private static final String TARGET_NODE_NAME = "myNode";
cfdb727a 72
eb1bab5b
BH
73 // ------------------------------------------------------------------------
74 // Test data
75 // ------------------------------------------------------------------------
cfdb727a 76
d132bcc7 77 private TestRemoteSystemProxy fProxy;
cfdb727a
AM
78 private String fTestFile;
79
eb1bab5b
BH
80 // ------------------------------------------------------------------------
81 // Housekeeping
82 // ------------------------------------------------------------------------
83
84 /**
85 * Perform pre-test initialization.
86 *
87 * @throws Exception
88 * if the initialization fails for some reason
eb1bab5b 89 */
eb1bab5b
BH
90 @Before
91 public void setUp() throws Exception {
d132bcc7 92 fProxy = new TestRemoteSystemProxy();
9269df72 93 URL location = FileLocator.find(FrameworkUtil.getBundle(this.getClass()), new Path(TraceControlTestFacility.DIRECTORY + File.separator + TEST_STREAM), null);
d132bcc7
BH
94 File testfile = new File(FileLocator.toFileURL(location).toURI());
95 fTestFile = testfile.getAbsolutePath();
eb1bab5b
BH
96 }
97
98 /**
99 * Perform post-test clean-up.
eb1bab5b 100 */
eb1bab5b 101 @After
2ba3d0a1 102 public void tearDown() {
b957fb8c 103 TraceControlTestFacility.getInstance().waitForJobs();
eb1bab5b 104 }
cfdb727a 105
eb1bab5b
BH
106 /**
107 * Run the TraceControlComponent.
cfdb727a
AM
108 *
109 * @throws Exception
110 * This will fail the test
eb1bab5b 111 */
2ba3d0a1 112 @Test
cfdb727a
AM
113 public void testTraceControlComponents() throws Exception {
114
d132bcc7
BH
115 fProxy.setTestFile(fTestFile);
116 fProxy.setScenario(SCEN_LIST_INFO_TEST);
cfdb727a 117
eb1bab5b
BH
118 ITraceControlComponent root = TraceControlTestFacility.getInstance().getControlView().getTraceControlRoot();
119
8577ed1e
BH
120 ISystemRegistry registry = RSECorePlugin.getTheSystemRegistry();
121 ISystemProfile profile = registry.createSystemProfile("myProfile", true);
122 IHost host = registry.createLocalHost(profile, "myProfile", "user");
eb1bab5b 123
4ea599a5 124 TargetNodeComponent node = new TargetNodeComponent(TARGET_NODE_NAME, root, host, fProxy);
eb1bab5b
BH
125
126 root.addChild(node);
127 node.connect();
128
129 TraceControlTestFacility.getInstance().waitForJobs();
130
eb1bab5b
BH
131 // ------------------------------------------------------------------------
132 // Verify Parameters of TargetNodeComponent
133 // ------------------------------------------------------------------------
8577ed1e
BH
134 assertEquals("LOCALHOST", node.getHostName()); // assigned in createLocalHost() above
135 assertEquals("LOCALHOST", node.getToolTip()); // assigned in createLocalHost() above
eb1bab5b
BH
136 Image connectedImage = node.getImage();
137 assertNotNull(connectedImage);
138 assertEquals(TargetNodeState.CONNECTED, node.getTargetNodeState());
139 assertNotNull(node.getControlService());
140 ILttngControlService service = node.getControlService();
141 assertTrue(service instanceof LTTngControlService);
142 node.setControlService(service);
143 assertTrue(node.getControlService() instanceof LTTngControlService);
144
145 assertTrue(node.isPassiveCommunicationsListener());
146
147 // ------------------------------------------------------------------------
148 // Verify Children of TargetNodeComponent
149 // ------------------------------------------------------------------------
150 ITraceControlComponent[] groups = node.getChildren();
151 assertNotNull(groups);
152 assertEquals(2, groups.length);
cfdb727a 153
eb1bab5b
BH
154 assertTrue(groups[0] instanceof TraceProviderGroup);
155 assertTrue(groups[1] instanceof TraceSessionGroup);
cfdb727a 156
eb1bab5b
BH
157 assertEquals("Provider", groups[0].getName());
158 assertEquals("Sessions", groups[1].getName());
159
160 // ------------------------------------------------------------------------
161 // Verify TraceProviderGroup
162 // ------------------------------------------------------------------------
163 ITraceControlComponent[] providers = groups[0].getChildren();
164
165 assertNotNull(providers);
166 assertEquals(3, providers.length);
167
168 // ------------------------------------------------------------------------
a07c7629 169 // Verify KernelProviderComponent
eb1bab5b
BH
170 // ------------------------------------------------------------------------
171 KernelProviderComponent kernelProvider = (KernelProviderComponent) providers[0];
172
173 // ------------------------------------------------------------------------
174 // Verify event info (kernel provider)
175 // ------------------------------------------------------------------------
176 ITraceControlComponent[] events = kernelProvider.getChildren();
177 assertNotNull(events);
178 assertEquals(3, events.length);
179
180 BaseEventComponent baseEventInfo = (BaseEventComponent) events[0];
181 assertNotNull(baseEventInfo);
182 assertEquals("sched_kthread_stop", baseEventInfo.getName());
183 assertEquals(TraceLogLevel.TRACE_EMERG, baseEventInfo.getLogLevel());
184 assertEquals(TraceEventType.TRACEPOINT, baseEventInfo.getEventType());
185
186 baseEventInfo = (BaseEventComponent) events[1];
187 assertEquals("sched_kthread_stop_ret", baseEventInfo.getName());
188 assertEquals(TraceLogLevel.TRACE_EMERG, baseEventInfo.getLogLevel());
189 assertEquals(TraceEventType.TRACEPOINT, baseEventInfo.getEventType());
190
191 baseEventInfo = (BaseEventComponent) events[2];
192 assertEquals("sched_wakeup_new", baseEventInfo.getName());
193 assertEquals(TraceLogLevel.TRACE_EMERG, baseEventInfo.getLogLevel());
194 assertEquals(TraceEventType.TRACEPOINT, baseEventInfo.getEventType());
195
196 // ------------------------------------------------------------------------
197 // Verify UstProviderComponent
198 // ------------------------------------------------------------------------
199 UstProviderComponent ustProvider = (UstProviderComponent) providers[1];
2e74131b 200 assertEquals("/home/user/git/lttng-ust/tests/hello.cxx/.libs/lt-hello [PID=9379]", ustProvider.getName());
eb1bab5b
BH
201 assertEquals(9379, ustProvider.getPid());
202
203 // ------------------------------------------------------------------------
204 // Verify event info (UST provider)
205 // ------------------------------------------------------------------------
206 events = ustProvider.getChildren();
207 assertNotNull(events);
208 assertEquals(2, events.length);
209
210 baseEventInfo = (BaseEventComponent) events[0];
211 assertNotNull(baseEventInfo);
212 assertEquals("ust_tests_hello:tptest_sighandler", baseEventInfo.getName());
4775bcbf 213 assertEquals(TraceLogLevel.TRACE_DEBUG_MODULE, baseEventInfo.getLogLevel());
eb1bab5b
BH
214 assertEquals(TraceEventType.TRACEPOINT, baseEventInfo.getEventType());
215
216 baseEventInfo = (BaseEventComponent) events[1];
217 assertEquals("ust_tests_hello:tptest", baseEventInfo.getName());
218 assertEquals(TraceLogLevel.TRACE_INFO, baseEventInfo.getLogLevel());
219 assertEquals(TraceEventType.TRACEPOINT, baseEventInfo.getEventType());
220
221 // ------------------------------------------------------------------------
222 // Verify UstProviderComponent
223 // ------------------------------------------------------------------------
224 ustProvider = (UstProviderComponent) providers[2];
2e74131b 225 assertEquals("/home/user/git/lttng-ust/tests/hello.cxx/.libs/lt-hello [PID=4852]", ustProvider.getName());
eb1bab5b 226 assertEquals(4852, ustProvider.getPid());
cfdb727a 227
eb1bab5b
BH
228 // verify getters and setter
229 verifyUstProviderGettersSetters(ustProvider);
230
231 // ------------------------------------------------------------------------
232 // Verify event info (UST provider)
233 // ------------------------------------------------------------------------
234 events = ustProvider.getChildren();
235 assertNotNull(events);
236 assertEquals(2, events.length);
237
238 baseEventInfo = (BaseEventComponent) events[0];
239 assertNotNull(baseEventInfo);
240 assertEquals("ust_tests_hello:tptest_sighandler", baseEventInfo.getName());
241 assertEquals(TraceLogLevel.TRACE_WARNING, baseEventInfo.getLogLevel());
242 assertEquals(TraceEventType.TRACEPOINT, baseEventInfo.getEventType());
243
244 baseEventInfo = (BaseEventComponent) events[1];
245 assertEquals("ust_tests_hello:tptest", baseEventInfo.getName());
4775bcbf 246 assertEquals(TraceLogLevel.TRACE_DEBUG_FUNCTION, baseEventInfo.getLogLevel());
eb1bab5b 247 assertEquals(TraceEventType.TRACEPOINT, baseEventInfo.getEventType());
cfdb727a 248
eb1bab5b
BH
249 // verify getters and setters
250 verifyBaseEventGettersSetters(baseEventInfo);
cfdb727a 251
eb1bab5b
BH
252 // ------------------------------------------------------------------------
253 // Verify TraceSessionGroup
254 // ------------------------------------------------------------------------
255 ITraceControlComponent[] sessions = groups[1].getChildren();
256 assertNotNull(sessions);
257 assertEquals(2, sessions.length);
258 for (int i = 0; i < sessions.length; i++) {
259 assertTrue(sessions[i] instanceof TraceSessionComponent);
260 }
261 assertEquals("mysession1", sessions[0].getName());
262 assertEquals("mysession", sessions[1].getName());
263
264 // ------------------------------------------------------------------------
265 // Verify TraceSessionComponent
266 // ------------------------------------------------------------------------
267 TraceSessionComponent session = (TraceSessionComponent)sessions[1];
268 assertEquals("mysession", session.getName());
269 assertEquals("/home/user/lttng-traces/mysession-20120129-084256", session.getSessionPath());
270 assertEquals(TraceSessionState.ACTIVE, session.getSessionState());
271
272 // Verify setters and setters
273 verifySessionGetterSetters(session);
cfdb727a 274
eb1bab5b
BH
275 ITraceControlComponent[] domains = session.getChildren();
276 assertNotNull(domains);
277 assertEquals(2, domains.length);
cfdb727a 278
eb1bab5b
BH
279 // ------------------------------------------------------------------------
280 // Verify Kernel domain
281 // ------------------------------------------------------------------------
282 assertEquals("Kernel", domains[0].getName());
283 ITraceControlComponent[] channels = domains[0].getChildren();
284 assertNotNull(channels);
285 assertEquals(2, channels.length);
286
4ea599a5
BH
287 // Verify setters and setters
288 verifyDomainGettersSetters((TraceDomainComponent) domains[0]);
cfdb727a 289
eb1bab5b
BH
290 // ------------------------------------------------------------------------
291 // Verify Kernel's channel0
292 // ------------------------------------------------------------------------
293 assertTrue(channels[0] instanceof TraceChannelComponent);
cfdb727a 294 TraceChannelComponent channel = (TraceChannelComponent) channels[0];
eb1bab5b
BH
295 assertEquals("channel0", channel.getName());
296 assertEquals(4, channel.getNumberOfSubBuffers());
297 assertEquals("splice()", channel.getOutputType());
298 assertEquals(false, channel.isOverwriteMode());
299 assertEquals(200, channel.getReadTimer());
300 assertEquals(TraceEnablement.ENABLED, channel.getState());
301 assertEquals(262144, channel.getSubBufferSize());
302 assertEquals(0, channel.getSwitchTimer());
303
304 // ------------------------------------------------------------------------
305 // Verify event info (kernel, channel0)
306 // ------------------------------------------------------------------------
307 ITraceControlComponent[] channel0Events = channel.getChildren();
308 assertNotNull(channel0Events);
d132bcc7 309 assertEquals(5, channel0Events.length);
eb1bab5b
BH
310 assertTrue(channel0Events[0] instanceof TraceEventComponent);
311 assertTrue(channel0Events[1] instanceof TraceEventComponent);
d132bcc7
BH
312 assertTrue(channel0Events[2] instanceof TraceProbeEventComponent);
313 assertTrue(channel0Events[3] instanceof TraceProbeEventComponent);
314 assertTrue(channel0Events[4] instanceof TraceEventComponent);
cfdb727a 315
eb1bab5b
BH
316 TraceEventComponent event = (TraceEventComponent) channel0Events[0];
317 assertEquals("block_rq_remap", event.getName());
318 assertEquals(TraceLogLevel.TRACE_EMERG, event.getLogLevel());
319 assertEquals(TraceEventType.TRACEPOINT, event.getEventType());
320 assertEquals(TraceEnablement.ENABLED, event.getState());
cfdb727a 321
eb1bab5b
BH
322 event = (TraceEventComponent) channel0Events[1];
323 assertEquals("block_bio_remap", event.getName());
324 assertEquals(TraceLogLevel.TRACE_EMERG, event.getLogLevel());
325 assertEquals(TraceEventType.TRACEPOINT, event.getEventType());
326 assertEquals(TraceEnablement.DISABLED, event.getState());
327
d132bcc7
BH
328 TraceProbeEventComponent probeEvent = (TraceProbeEventComponent) channel0Events[2];
329 assertEquals("myevent2", probeEvent.getName());
330 assertEquals(TraceLogLevel.LEVEL_UNKNOWN, probeEvent.getLogLevel());
331 assertEquals(TraceEventType.PROBE, probeEvent.getEventType());
332 assertEquals(TraceEnablement.ENABLED, probeEvent.getState());
333 assertEquals("0xc0101340", probeEvent.getAddress());
334 assertNull(probeEvent.getOffset());
335 assertNull(probeEvent.getSymbol());
336
4ea599a5
BH
337 // verify getters and setter
338 verifyProbeEventGettersSetters(probeEvent);
339
d132bcc7
BH
340 probeEvent = (TraceProbeEventComponent) channel0Events[3];
341 assertEquals("myevent0", probeEvent.getName());
342 assertEquals(TraceLogLevel.LEVEL_UNKNOWN, probeEvent.getLogLevel());
343 assertEquals(TraceEventType.PROBE, probeEvent.getEventType());
344 assertEquals(TraceEnablement.ENABLED, probeEvent.getState());
345 assertNull(probeEvent.getAddress());
346 assertEquals("0x0", probeEvent.getOffset());
347 assertEquals("init_post", probeEvent.getSymbol());
cfdb727a 348
d132bcc7
BH
349 event = (TraceEventComponent) channel0Events[4];
350 assertEquals("syscalls", event.getName());
351 assertEquals(TraceLogLevel.LEVEL_UNKNOWN, event.getLogLevel());
352 assertEquals(TraceEventType.SYSCALL, event.getEventType());
353 assertEquals(TraceEnablement.ENABLED, event.getState());
cfdb727a 354
eb1bab5b
BH
355 // ------------------------------------------------------------------------
356 // Verify Kernel's channel1
357 // ------------------------------------------------------------------------
358 assertEquals("channel1", channels[1].getName());
cfdb727a 359 channel = (TraceChannelComponent) channels[1];
eb1bab5b
BH
360 assertEquals(4, channel.getNumberOfSubBuffers());
361 assertEquals("splice()", channel.getOutputType());
362 assertEquals(true, channel.isOverwriteMode());
363 assertEquals(400, channel.getReadTimer());
364 assertEquals(TraceEnablement.DISABLED, channel.getState());
365 assertEquals(524288, channel.getSubBufferSize());
366 assertEquals(100, channel.getSwitchTimer());
367
368 // ------------------------------------------------------------------------
369 // Verify event info (kernel, channel1)
370 // ------------------------------------------------------------------------
371 ITraceControlComponent[] channel1Events = channels[1].getChildren();
372 assertEquals(0, channel1Events.length);
373
374 // ------------------------------------------------------------------------
375 // Verify domain UST global
376 // ------------------------------------------------------------------------
377 assertEquals("UST global", domains[1].getName());
cfdb727a 378
eb1bab5b 379 ITraceControlComponent[] ustChannels = domains[1].getChildren();
cfdb727a 380
eb1bab5b
BH
381 for (int i = 0; i < ustChannels.length; i++) {
382 assertTrue(ustChannels[i] instanceof TraceChannelComponent);
383 }
384
385 // ------------------------------------------------------------------------
386 // Verify UST global's mychannel1
387 // ------------------------------------------------------------------------
cfdb727a 388 channel = (TraceChannelComponent) ustChannels[0];
eb1bab5b
BH
389 assertEquals("mychannel1", channel.getName());
390 assertEquals(8, channel.getNumberOfSubBuffers());
391 assertEquals("mmap()", channel.getOutputType());
392 assertEquals(true, channel.isOverwriteMode());
393 assertEquals(100, channel.getReadTimer());
394 assertEquals(TraceEnablement.DISABLED, channel.getState());
395 assertEquals(8192, channel.getSubBufferSize());
396 assertEquals(200, channel.getSwitchTimer());
cfdb727a
AM
397
398 // verify getters and setters
eb1bab5b
BH
399 verifyChannelGettersSetters(channel);
400
401 // ------------------------------------------------------------------------
402 // Verify event info (UST global, mychannel1)
403 // ------------------------------------------------------------------------
404 ITraceControlComponent[] ustEvents = channel.getChildren();
405 assertEquals(0, ustEvents.length);
406
407 // ------------------------------------------------------------------------
408 // Verify UST global's channel0
409 // ------------------------------------------------------------------------
410 channel = (TraceChannelComponent) ustChannels[1];
411 assertEquals("channel0", channel.getName());
412 assertEquals(4, channel.getNumberOfSubBuffers());
413 assertEquals("mmap()", channel.getOutputType());
414 assertEquals(false, channel.isOverwriteMode());
415 assertEquals(200, channel.getReadTimer());
416 assertEquals(TraceEnablement.ENABLED, channel.getState());
417 assertEquals(4096, channel.getSubBufferSize());
418 assertEquals(0, channel.getSwitchTimer());
419
420 // ------------------------------------------------------------------------
421 // Verify event info (UST global, channel0)
422 // ------------------------------------------------------------------------
423 ustEvents = channel.getChildren();
424 assertEquals(2, ustEvents.length);
cfdb727a 425
eb1bab5b
BH
426 event = (TraceEventComponent) ustEvents[0];
427 assertEquals("ust_tests_hello:tptest_sighandler", event.getName());
4775bcbf 428 assertEquals(TraceLogLevel.TRACE_DEBUG_LINE, event.getLogLevel());
eb1bab5b
BH
429 assertEquals(TraceEventType.TRACEPOINT, event.getEventType());
430 assertEquals(TraceEnablement.DISABLED, event.getState());
cfdb727a 431
eb1bab5b
BH
432 event = (TraceEventComponent) ustEvents[1];
433 assertEquals("*", ustEvents[1].getName());
4775bcbf 434 assertEquals(TraceLogLevel.LEVEL_UNKNOWN, event.getLogLevel());
eb1bab5b
BH
435 assertEquals(TraceEventType.TRACEPOINT, event.getEventType());
436 assertEquals(TraceEnablement.ENABLED, event.getState());
cfdb727a 437
eb1bab5b
BH
438 // verify getters and setters
439 verifyEventGettersSetters(event);
cfdb727a 440
eb1bab5b
BH
441 // disconnect
442 node.disconnect();
443 assertEquals(TargetNodeState.DISCONNECTED, node.getTargetNodeState());
444 assertNotNull(node.getImage());
445 assertNotSame(connectedImage, node.getImage());
cfdb727a 446
a26d90be 447 node.getParent().removeChild(node);
eb1bab5b 448 }
cfdb727a 449
0a78d11a 450 private static void verifySessionGetterSetters(TraceSessionComponent session) {
eb1bab5b
BH
451 // save original values
452 String name = session.getName();
453 String origPath = session.getSessionPath();
454 TraceSessionState origState = session.getSessionState();
455
456 // test cases
457 session.setName("newName");
458 assertEquals("newName", session.getName());
cfdb727a 459
eb1bab5b
BH
460 session.setSessionPath("/home/user/tmp");
461 assertEquals("/home/user/tmp", session.getSessionPath());
462
463 session.setSessionState(TraceSessionState.INACTIVE);
464 assertEquals(TraceSessionState.INACTIVE, session.getSessionState());
465 Image inactiveImage = session.getImage();
466 assertNotNull(inactiveImage);
cfdb727a 467
eb1bab5b
BH
468 session.setSessionState("active");
469 assertEquals(TraceSessionState.ACTIVE, session.getSessionState());
470
471 Image activeImage = session.getImage();
472 assertNotNull(activeImage);
473 assertNotSame(activeImage, inactiveImage);
474
4ea599a5
BH
475 ITraceControlComponent[] children = session.getChildren();
476 TraceDomainComponent[] domains = session.getDomains();
477
478 assertEquals(children.length, domains.length);
479
480 for (int i = 0; i < domains.length; i++) {
481 assertEquals(domains[i].getName(), children[i].getName());
482 }
cfdb727a
AM
483
484 // restore original values
eb1bab5b
BH
485 session.setName(name);
486 session.setSessionPath(origPath);
487 session.setSessionState(origState);
488 }
cfdb727a 489
0a78d11a 490 private static void verifyDomainGettersSetters(TraceDomainComponent domain) {
4ea599a5
BH
491 // save original values
492 boolean isKernel = domain.isKernel();
493
494 domain.setIsKernel(false);
495 assertFalse(domain.isKernel());
496 domain.setIsKernel(true);
497 assertTrue(domain.isKernel());
498
499 ITraceControlComponent[] children = domain.getChildren();
500 TraceChannelComponent[] channels = domain.getChannels();
501
502 assertEquals(children.length, channels.length);
503
504 for (int i = 0; i < channels.length; i++) {
505 assertEquals(channels[i].getName(), children[i].getName());
506 }
507
508 String nodeName = domain.getTargetNode().getName();
509 assertEquals(TARGET_NODE_NAME, nodeName);
510
511 // restore original values
512 domain.setIsKernel(isKernel);
513 }
eb1bab5b 514
0a78d11a 515 private static void verifyBaseEventGettersSetters(BaseEventComponent event) {
eb1bab5b
BH
516 // save original values
517 String name = event.getName();
518 TraceLogLevel level = event.getLogLevel();
519 TraceEventType type = event.getEventType();
cfdb727a 520
eb1bab5b
BH
521 // test cases
522 event.setName("newName");
523 assertEquals("newName", event.getName());
cfdb727a 524
eb1bab5b
BH
525 event.setLogLevel(TraceLogLevel.TRACE_INFO);
526 assertEquals(TraceLogLevel.TRACE_INFO, event.getLogLevel());
4775bcbf 527 event.setLogLevel("TRACE_ALERT");
eb1bab5b
BH
528 assertEquals(TraceLogLevel.TRACE_ALERT, event.getLogLevel());
529
530 event.setEventType(TraceEventType.UNKNOWN);
531 assertEquals(TraceEventType.UNKNOWN, event.getEventType());
532 event.setEventType("tracepoint");
533 assertEquals(TraceEventType.TRACEPOINT, event.getEventType());
cfdb727a 534
eb1bab5b
BH
535 // restore original values
536 event.setName(name);
537 event.setLogLevel(level);
538 event.setEventType(type);
539 }
cfdb727a 540
0a78d11a 541 private static void verifyEventGettersSetters(TraceEventComponent event) {
eb1bab5b
BH
542 // save original values
543 String name = event.getName();
544 TraceLogLevel level = event.getLogLevel();
545 TraceEventType type = event.getEventType();
546 TraceEnablement state = event.getState();
cfdb727a 547
eb1bab5b
BH
548 // test cases
549 event.setName("newName");
550 assertEquals("newName", event.getName());
cfdb727a 551
eb1bab5b
BH
552 event.setLogLevel(TraceLogLevel.TRACE_INFO);
553 assertEquals(TraceLogLevel.TRACE_INFO, event.getLogLevel());
4775bcbf 554 event.setLogLevel("TRACE_ALERT");
eb1bab5b
BH
555 assertEquals(TraceLogLevel.TRACE_ALERT, event.getLogLevel());
556
557 event.setEventType(TraceEventType.UNKNOWN);
558 assertEquals(TraceEventType.UNKNOWN, event.getEventType());
559 event.setEventType("tracepoint");
560 assertEquals(TraceEventType.TRACEPOINT, event.getEventType());
cfdb727a 561
eb1bab5b
BH
562 event.setState("disabled");
563 assertEquals(TraceEnablement.DISABLED, event.getState());
cfdb727a 564
eb1bab5b
BH
565 Image disabledImage = event.getImage();
566 assertNotNull(disabledImage);
567
568 event.setState(TraceEnablement.ENABLED);
569 assertEquals(TraceEnablement.ENABLED, event.getState());
570
571 Image enabledImage = event.getImage();
572 assertNotNull(enabledImage);
573 assertNotSame(enabledImage, disabledImage);
574
575 // restore original values
576 event.setName(name);
577 event.setLogLevel(level);
578 event.setEventType(type);
579 event.setState(state);
580 }
cfdb727a 581
0a78d11a 582 private static void verifyProbeEventGettersSetters(TraceProbeEventComponent event) {
4ea599a5
BH
583 // save original values
584 String address = event.getAddress();
585 String offset = event.getOffset();
586 String symbol = event.getSymbol();
cfdb727a 587
4ea599a5
BH
588 // test cases
589 event.setAddress("0xffff1234");
590 assertEquals("0xffff1234", event.getAddress());
cfdb727a 591
4ea599a5
BH
592 event.setOffset("0x1234");
593 assertEquals("0x1234", event.getOffset());
cfdb727a 594
4ea599a5
BH
595 event.setSymbol("init");
596 assertEquals("init", event.getSymbol());
cfdb727a 597
4ea599a5
BH
598 // restore original values
599 event.setAddress(address);
600 event.setOffset(offset);
601 event.setSymbol(symbol);
602 }
cfdb727a 603
0a78d11a 604 private static void verifyChannelGettersSetters(TraceChannelComponent channel) {
eb1bab5b
BH
605 // save original values
606 String name = channel.getName();
607 int nbSubBuffers = channel.getNumberOfSubBuffers();
608 String type = channel.getOutputType();
609 boolean mode = channel.isOverwriteMode();
610 long readTimer = channel.getReadTimer();
611 TraceEnablement state = channel.getState();
612 long subBufferSize = channel.getSubBufferSize();
613 long switchTimer = channel.getSwitchTimer();
cfdb727a 614
eb1bab5b
BH
615 // test cases
616 channel.setName("newName");
617 assertEquals("newName", channel.getName());
cfdb727a 618
eb1bab5b
BH
619 channel.setNumberOfSubBuffers(2);
620 assertEquals(2, channel.getNumberOfSubBuffers());
cfdb727a 621
eb1bab5b
BH
622 channel.setOutputType("splice()");
623 assertEquals("splice()", channel.getOutputType());
cfdb727a 624
eb1bab5b
BH
625 channel.setOverwriteMode(false);
626 assertEquals(false, channel.isOverwriteMode());
cfdb727a 627
eb1bab5b
BH
628 channel.setReadTimer(250);
629 assertEquals(250, channel.getReadTimer());
cfdb727a 630
eb1bab5b
BH
631 channel.setState("enabled");
632 assertEquals(TraceEnablement.ENABLED, channel.getState());
cfdb727a 633
eb1bab5b
BH
634 Image enabledImage = channel.getImage();
635 assertNotNull(enabledImage);
636 channel.setState(TraceEnablement.DISABLED);
637 assertEquals(TraceEnablement.DISABLED, channel.getState());
638
639 Image disabledImage = channel.getImage();
640 assertNotNull(disabledImage);
641 assertNotSame(enabledImage, disabledImage);
cfdb727a 642
eb1bab5b
BH
643 channel.setSubBufferSize(1024);
644 assertEquals(1024, channel.getSubBufferSize());
cfdb727a 645
eb1bab5b
BH
646 channel.setSwitchTimer(1000);
647 assertEquals(1000, channel.getSwitchTimer());
648
649 // restore original values
650 channel.setName(name);
651 channel.setNumberOfSubBuffers(nbSubBuffers);
652 channel.setOutputType(type);
653 channel.setOverwriteMode(mode);
654 channel.setReadTimer(readTimer);
655 channel.setState(state);
656 channel.setSubBufferSize(subBufferSize);
657 channel.setSwitchTimer(switchTimer);
658 }
cfdb727a 659
0a78d11a 660 private static void verifyUstProviderGettersSetters(UstProviderComponent ustProvider) {
eb1bab5b
BH
661 // save original values
662 String name = ustProvider.getName();
663 int pid = ustProvider.getPid();
cfdb727a 664
eb1bab5b
BH
665 // test cases
666 ustProvider.setName("newName");
667 assertEquals("newName", ustProvider.getName());
668
669 ustProvider.setPid(9876);
670 assertEquals(9876, ustProvider.getPid());
cfdb727a 671
eb1bab5b
BH
672 // restore original values
673 ustProvider.setName(name);
674 ustProvider.setPid(pid);
675 }
676
eb1bab5b 677}
This page took 0.084339 seconds and 5 git commands to generate.