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