tmf: Consolidate constructors in coalesced requests
[deliverable/tracecompass.git] / org.eclipse.linuxtools.tmf.core.tests / src / org / eclipse / linuxtools / tmf / core / tests / trace / TmfExperimentTest.java
CommitLineData
d18dd09b 1/*******************************************************************************
61759503 2 * Copyright (c) 2009, 2013 Ericsson
9b749023 3 *
d18dd09b
ASL
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
9b749023 8 *
d18dd09b
ASL
9 * Contributors:
10 * Francois Chouinard - Initial API and implementation
0316808c 11 * Francois Chouinard - Adjusted for new Trace Model
6e1886bc 12 * Alexandre Montplaisir - Port to JUnit4
ea271da6 13 * Patrick Tasse - Updated for rank in experiment location
d18dd09b
ASL
14 *******************************************************************************/
15
9e0640dc 16package org.eclipse.linuxtools.tmf.core.tests.trace;
d18dd09b 17
6e1886bc
AM
18import static org.junit.Assert.assertEquals;
19import static org.junit.Assert.assertFalse;
6e1886bc
AM
20import static org.junit.Assert.assertNull;
21import static org.junit.Assert.assertTrue;
22
d18dd09b
ASL
23import java.io.File;
24import java.io.IOException;
25import java.net.URISyntaxException;
26import java.net.URL;
27import java.util.Vector;
28
9e0640dc 29import org.eclipse.core.resources.IFile;
d18dd09b
ASL
30import org.eclipse.core.runtime.FileLocator;
31import org.eclipse.core.runtime.Path;
17324c9a 32import org.eclipse.linuxtools.internal.tmf.core.trace.TmfExperimentContext;
9e0640dc 33import org.eclipse.linuxtools.internal.tmf.core.trace.TmfExperimentLocation;
72f1e62a 34import org.eclipse.linuxtools.tmf.core.event.ITmfEvent;
b4f71e4a 35import org.eclipse.linuxtools.tmf.core.exceptions.TmfTraceException;
9b749023 36import org.eclipse.linuxtools.tmf.core.request.TmfDataRequest;
6c13869b 37import org.eclipse.linuxtools.tmf.core.request.TmfEventRequest;
7184fc40 38import org.eclipse.linuxtools.tmf.core.request.ITmfDataRequest.ExecutionType;
a51b2b9f
AM
39import org.eclipse.linuxtools.tmf.core.statesystem.ITmfStateSystem;
40import org.eclipse.linuxtools.tmf.core.statistics.ITmfStatistics;
6c13869b 41import org.eclipse.linuxtools.tmf.core.tests.TmfCoreTestPlugin;
3bd46eef
AM
42import org.eclipse.linuxtools.tmf.core.timestamp.TmfTimeRange;
43import org.eclipse.linuxtools.tmf.core.timestamp.TmfTimestamp;
6c13869b 44import org.eclipse.linuxtools.tmf.core.trace.ITmfContext;
0316808c 45import org.eclipse.linuxtools.tmf.core.trace.ITmfLocation;
6c13869b 46import org.eclipse.linuxtools.tmf.core.trace.ITmfTrace;
9e0640dc 47import org.eclipse.linuxtools.tmf.core.trace.TmfExperiment;
cb8c854e 48import org.eclipse.linuxtools.tmf.core.trace.TmfLongLocation;
9e0640dc 49import org.eclipse.linuxtools.tmf.tests.stubs.trace.TmfExperimentStub;
4918b8f2 50import org.eclipse.linuxtools.tmf.tests.stubs.trace.TmfTraceStub;
6e1886bc
AM
51import org.junit.Before;
52import org.junit.Test;
d18dd09b
ASL
53
54/**
0316808c 55 * Test suite for the TmfExperiment class (single trace).
d18dd09b 56 */
cad06250 57@SuppressWarnings("javadoc")
6e1886bc 58public class TmfExperimentTest {
d18dd09b 59
0316808c
FC
60 // ------------------------------------------------------------------------
61 // Attributes
62 // ------------------------------------------------------------------------
63
d18dd09b
ASL
64 private static final String DIRECTORY = "testfiles";
65 private static final String TEST_STREAM = "A-Test-10K";
66 private static final String EXPERIMENT = "MyExperiment";
67 private static int NB_EVENTS = 10000;
0316808c 68 private static int BLOCK_SIZE = 1000;
d18dd09b 69
6e1886bc
AM
70 private static final double DELTA = 1e-15;
71
6256d8ad
AM
72 private ITmfTrace[] fTestTraces;
73 private TmfExperimentStub fExperiment;
d18dd09b
ASL
74
75 private static byte SCALE = (byte) -3;
76
77 // ------------------------------------------------------------------------
78 // Housekeeping
79 // ------------------------------------------------------------------------
80
6256d8ad 81 private synchronized ITmfTrace[] setupTrace(final String path) {
9e0640dc
FC
82 if (fTestTraces == null) {
83 fTestTraces = new ITmfTrace[1];
25e48683
FC
84 try {
85 final URL location = FileLocator.find(TmfCoreTestPlugin.getDefault().getBundle(), new Path(path), null);
86 final File test = new File(FileLocator.toFileURL(location).toURI());
20658947 87 final TmfTraceStub trace = new TmfTraceStub(test.getPath(), 0, true);
9e0640dc 88 fTestTraces[0] = trace;
b4f71e4a
FC
89 } catch (final TmfTraceException e) {
90 e.printStackTrace();
25e48683
FC
91 } catch (final URISyntaxException e) {
92 e.printStackTrace();
93 } catch (final IOException e) {
94 e.printStackTrace();
95 }
96 }
9e0640dc 97 return fTestTraces;
d18dd09b
ASL
98 }
99
9e0640dc 100 private synchronized void setupExperiment() {
20658947 101 if (fExperiment == null) {
6256d8ad 102 fExperiment = new TmfExperimentStub(EXPERIMENT, fTestTraces, BLOCK_SIZE);
9e0640dc 103 fExperiment.getIndexer().buildIndex(0, TmfTimeRange.ETERNITY, true);
20658947 104 }
d18dd09b
ASL
105 }
106
6e1886bc
AM
107 @Before
108 public void setUp() {
25e48683
FC
109 setupTrace(DIRECTORY + File.separator + TEST_STREAM);
110 setupExperiment();
111 }
d18dd09b 112
d18dd09b
ASL
113 // ------------------------------------------------------------------------
114 // Constructor
115 // ------------------------------------------------------------------------
116
6e1886bc 117 @Test
9e0640dc 118 public void testSimpleTmfExperimentConstructor() {
2771b032 119 TmfExperiment experiment = new TmfExperiment(ITmfEvent.class, EXPERIMENT, fTestTraces);
9e0640dc
FC
120 assertEquals("GetId", EXPERIMENT, experiment.getName());
121 assertEquals("GetCacheSize", TmfExperiment.DEFAULT_INDEX_PAGE_SIZE, experiment.getCacheSize());
122 experiment.dispose();
123
2771b032 124 experiment = new TmfExperiment(ITmfEvent.class, EXPERIMENT, null);
9e0640dc
FC
125 experiment.dispose();
126 }
127
6e1886bc 128 @Test
9e0640dc 129 public void testNormalTmfExperimentConstructor() {
25e48683 130 assertEquals("GetId", EXPERIMENT, fExperiment.getName());
d18dd09b
ASL
131 assertEquals("GetNbEvents", NB_EVENTS, fExperiment.getNbEvents());
132
07671572
FC
133 final long nbExperimentEvents = fExperiment.getNbEvents();
134 assertEquals("GetNbEvents", NB_EVENTS, nbExperimentEvents);
135
25e48683 136 final long nbTraceEvents = fExperiment.getTraces()[0].getNbEvents();
82e04272
FC
137 assertEquals("GetNbEvents", NB_EVENTS, nbTraceEvents);
138
25e48683 139 final TmfTimeRange timeRange = fExperiment.getTimeRange();
d18dd09b
ASL
140 assertEquals("getStartTime", 1, timeRange.getStartTime().getValue());
141 assertEquals("getEndTime", NB_EVENTS, timeRange.getEndTime().getValue());
25e48683 142 }
d18dd09b 143
9e0640dc
FC
144 // ------------------------------------------------------------------------
145 // getTimestamp
146 // ------------------------------------------------------------------------
147
6e1886bc 148 @Test
54a7a54c 149 public void testGetTimestamp() {
17324c9a
FC
150 assertEquals("getTimestamp", new TmfTimestamp( 1, (byte) -3), fExperiment.getTimestamp( 0));
151 assertEquals("getTimestamp", new TmfTimestamp( 2, (byte) -3), fExperiment.getTimestamp( 1));
152 assertEquals("getTimestamp", new TmfTimestamp( 11, (byte) -3), fExperiment.getTimestamp( 10));
153 assertEquals("getTimestamp", new TmfTimestamp( 101, (byte) -3), fExperiment.getTimestamp( 100));
154 assertEquals("getTimestamp", new TmfTimestamp( 1001, (byte) -3), fExperiment.getTimestamp(1000));
155 assertEquals("getTimestamp", new TmfTimestamp( 2001, (byte) -3), fExperiment.getTimestamp(2000));
156 assertEquals("getTimestamp", new TmfTimestamp( 2501, (byte) -3), fExperiment.getTimestamp(2500));
157 assertEquals("getTimestamp", new TmfTimestamp(10000, (byte) -3), fExperiment.getTimestamp(9999));
9e0640dc
FC
158 assertNull("getTimestamp", fExperiment.getTimestamp(10000));
159 }
160
161 // ------------------------------------------------------------------------
162 // Bookmarks file handling
163 // ------------------------------------------------------------------------
164
6e1886bc 165 @Test
54a7a54c 166 public void testBookmarks() {
9e0640dc 167 assertNull("GetBookmarksFile", fExperiment.getBookmarksFile());
9e0640dc
FC
168 IFile bookmarks = (IFile) fTestTraces[0].getResource();
169 fExperiment.setBookmarksFile(bookmarks);
170 assertEquals("GetBookmarksFile", bookmarks, fExperiment.getBookmarksFile());
171 }
172
a51b2b9f
AM
173 // ------------------------------------------------------------------------
174 // State system and statistics methods
175 // ------------------------------------------------------------------------
176
6e1886bc 177 @Test
a51b2b9f
AM
178 public void testGetStatistics() {
179 /* There should not be any experiment-specific statistics */
180 ITmfStatistics stats = fExperiment.getStatistics();
181 assertNull(stats);
182 }
183
6e1886bc 184 @Test
a51b2b9f
AM
185 public void testGetStateSystem() {
186 /* There should not be any experiment-specific state system */
35c160d9 187 ITmfStateSystem ss = fExperiment.getStateSystems().get("something");
a51b2b9f
AM
188 assertNull(ss);
189 }
190
9e0640dc
FC
191 // ------------------------------------------------------------------------
192 // seekEvent by location
193 // ------------------------------------------------------------------------
194
6e1886bc 195 @Test
54a7a54c 196 public void testSeekBadLocation() {
cb8c854e 197 ITmfContext context = fExperiment.seekEvent(new TmfLongLocation(0L));
9e0640dc
FC
198 assertNull("seekEvent", context);
199 }
200
6e1886bc 201 @Test
54a7a54c 202 public void testSeekNoTrace() {
2771b032 203 TmfExperiment experiment = new TmfExperiment(ITmfEvent.class, EXPERIMENT, null);
9e0640dc
FC
204 ITmfContext context = experiment.seekEvent((TmfExperimentLocation) null);
205 assertNull("seekEvent", context);
206 experiment.dispose();
207 }
208
209 // ------------------------------------------------------------------------
210 // seekEvent on ratio
211 // ------------------------------------------------------------------------
212
6e1886bc 213 @Test
54a7a54c 214 public void testSeekEventOnRatio() {
9e0640dc
FC
215 // First event
216 ITmfContext context = fExperiment.seekEvent(0.0);
217 assertEquals("Context rank", 0, context.getRank());
218 ITmfEvent event = fExperiment.parseEvent(context);
219 assertEquals("Event timestamp", 1, event.getTimestamp().getValue());
220 assertEquals("Context rank", 0, context.getRank());
221
222 // Middle event
223 int midTrace = NB_EVENTS / 2;
224 context = fExperiment.seekEvent(0.5);
225 assertEquals("Context rank", midTrace, context.getRank());
226 event = fExperiment.parseEvent(context);
227 assertEquals("Event timestamp", midTrace + 1, event.getTimestamp().getValue());
228 assertEquals("Context rank", midTrace, context.getRank());
9b749023 229
9e0640dc
FC
230 // Last event
231 context = fExperiment.seekEvent(1.0);
232 assertEquals("Context rank", NB_EVENTS, context.getRank());
233 event = fExperiment.parseEvent(context);
234 assertNull("Event timestamp", event);
235 assertEquals("Context rank", NB_EVENTS, context.getRank());
9b749023 236
9e0640dc
FC
237 // Beyond last event
238 context = fExperiment.seekEvent(1.1);
239 assertEquals("Context rank", NB_EVENTS, context.getRank());
240 event = fExperiment.parseEvent(context);
241 assertNull("Event timestamp", event);
242 assertEquals("Context rank", NB_EVENTS, context.getRank());
9b749023 243
9e0640dc
FC
244 // Negative ratio
245 context = fExperiment.seekEvent(-0.5);
246 assertEquals("Context rank", 0, context.getRank());
247 event = fExperiment.parseEvent(context);
248 assertEquals("Event timestamp", 1, event.getTimestamp().getValue());
249 assertEquals("Context rank", 0, context.getRank());
250 }
251
6e1886bc 252 @Test
54a7a54c 253 public void testGetLocationRatio() {
9e0640dc
FC
254 // First event
255 ITmfContext context = fExperiment.seekEvent((ITmfLocation) null);
256 double ratio = fExperiment.getLocationRatio(context.getLocation());
ea271da6 257 assertEquals("getLocationRatio", 0.0, ratio, DELTA);
9e0640dc
FC
258
259 // Middle event
260 context = fExperiment.seekEvent(NB_EVENTS / 2);
261 ratio = fExperiment.getLocationRatio(context.getLocation());
ea271da6 262 assertEquals("getLocationRatio", (double) (NB_EVENTS / 2) / NB_EVENTS, ratio, DELTA);
9e0640dc
FC
263
264 // Last event
265 context = fExperiment.seekEvent(NB_EVENTS - 1);
266 ratio = fExperiment.getLocationRatio(context.getLocation());
ea271da6 267 assertEquals("getLocationRatio", (double) (NB_EVENTS - 1) / NB_EVENTS, ratio, DELTA);
9e0640dc
FC
268 }
269
17324c9a 270// @SuppressWarnings("rawtypes")
54a7a54c 271// public void testGetCurrentLocation() {
9e0640dc
FC
272// ITmfContext context = fExperiment.seekEvent((ITmfLocation) null);
273// ITmfLocation location = fExperiment.getCurrentLocation();
274// assertEquals("getCurrentLocation", location, context.getLocation());
275// }
276
d18dd09b 277 // ------------------------------------------------------------------------
0316808c 278 // seekEvent on rank
d18dd09b
ASL
279 // ------------------------------------------------------------------------
280
6e1886bc 281 @Test
54a7a54c 282 public void testSeekRankOnCacheBoundary() {
0316808c 283 long cacheSize = fExperiment.getCacheSize();
9b635e61 284
0316808c
FC
285 // On lower bound, returns the first event (TS = 1)
286 ITmfContext context = fExperiment.seekEvent(0);
287 assertEquals("Context rank", 0, context.getRank());
25e48683 288
c32744d6 289 ITmfEvent event = fExperiment.getNext(context);
d18dd09b 290 assertEquals("Event timestamp", 1, event.getTimestamp().getValue());
0316808c 291 assertEquals("Context rank", 1, context.getRank());
25e48683 292
0316808c
FC
293 // Position trace at event rank [cacheSize]
294 context = fExperiment.seekEvent(cacheSize);
295 assertEquals("Context rank", cacheSize, context.getRank());
25e48683 296
c32744d6 297 event = fExperiment.getNext(context);
0316808c
FC
298 assertEquals("Event timestamp", cacheSize + 1, event.getTimestamp().getValue());
299 assertEquals("Context rank", cacheSize + 1, context.getRank());
d18dd09b 300
0316808c
FC
301 // Position trace at event rank [4 * cacheSize]
302 context = fExperiment.seekEvent(4 * cacheSize);
303 assertEquals("Context rank", 4 * cacheSize, context.getRank());
25e48683 304
c32744d6 305 event = fExperiment.getNext(context);
0316808c
FC
306 assertEquals("Event timestamp", 4 * cacheSize + 1, event.getTimestamp().getValue());
307 assertEquals("Context rank", 4 * cacheSize + 1, context.getRank());
d18dd09b
ASL
308 }
309
6e1886bc 310 @Test
54a7a54c 311 public void testSeekRankNotOnCacheBoundary() {
0316808c 312 long cacheSize = fExperiment.getCacheSize();
25e48683 313
0316808c
FC
314 // Position trace at event rank 9
315 ITmfContext context = fExperiment.seekEvent(9);
316 assertEquals("Context rank", 9, context.getRank());
25e48683 317
c32744d6 318 ITmfEvent event = fExperiment.getNext(context);
d18dd09b 319 assertEquals("Event timestamp", 10, event.getTimestamp().getValue());
0316808c 320 assertEquals("Context rank", 10, context.getRank());
d18dd09b 321
0316808c
FC
322 // Position trace at event rank [cacheSize - 1]
323 context = fExperiment.seekEvent(cacheSize - 1);
324 assertEquals("Context rank", cacheSize - 1, context.getRank());
25e48683 325
c32744d6 326 event = fExperiment.getNext(context);
0316808c
FC
327 assertEquals("Event timestamp", cacheSize, event.getTimestamp().getValue());
328 assertEquals("Context rank", cacheSize, context.getRank());
d18dd09b 329
0316808c
FC
330 // Position trace at event rank [cacheSize + 1]
331 context = fExperiment.seekEvent(cacheSize + 1);
332 assertEquals("Context rank", cacheSize + 1, context.getRank());
25e48683 333
c32744d6 334 event = fExperiment.getNext(context);
0316808c
FC
335 assertEquals("Event timestamp", cacheSize + 2, event.getTimestamp().getValue());
336 assertEquals("Context rank", cacheSize + 2, context.getRank());
d18dd09b 337
25e48683 338 // Position trace at event rank 4500
0316808c
FC
339 context = fExperiment.seekEvent(4500);
340 assertEquals("Context rank", 4500, context.getRank());
25e48683 341
c32744d6 342 event = fExperiment.getNext(context);
d18dd09b 343 assertEquals("Event timestamp", 4501, event.getTimestamp().getValue());
0316808c 344 assertEquals("Context rank", 4501, context.getRank());
d18dd09b
ASL
345 }
346
6e1886bc 347 @Test
54a7a54c 348 public void testSeekRankOutOfScope() {
25e48683 349 // Position trace at beginning
0316808c 350 ITmfContext context = fExperiment.seekEvent(-1);
9b635e61 351 assertEquals("Event rank", 0, context.getRank());
25e48683 352
c32744d6 353 ITmfEvent event = fExperiment.getNext(context);
d18dd09b 354 assertEquals("Event timestamp", 1, event.getTimestamp().getValue());
0316808c 355 assertEquals("Context rank", 1, context.getRank());
d18dd09b 356
25e48683 357 // Position trace at event passed the end
0316808c
FC
358 context = fExperiment.seekEvent(NB_EVENTS);
359 assertEquals("Context rank", NB_EVENTS, context.getRank());
360
c32744d6 361 event = fExperiment.getNext(context);
0316808c
FC
362 assertNull("Event", event);
363 assertEquals("Context rank", NB_EVENTS, context.getRank());
d18dd09b
ASL
364 }
365
366 // ------------------------------------------------------------------------
367 // seekEvent on timestamp
368 // ------------------------------------------------------------------------
369
6e1886bc 370 @Test
54a7a54c 371 public void testSeekTimestampOnCacheBoundary() {
0316808c 372 long cacheSize = fExperiment.getCacheSize();
25e48683 373
0316808c
FC
374 // Position trace at event rank 0
375 ITmfContext context = fExperiment.seekEvent(new TmfTimestamp(1, SCALE, 0));
376 assertEquals("Context rank", 0, context.getRank());
25e48683 377
c32744d6 378 ITmfEvent event = fExperiment.getNext(context);
d18dd09b 379 assertEquals("Event timestamp", 1, event.getTimestamp().getValue());
0316808c 380 assertEquals("Context rank", 1, context.getRank());
25e48683 381
0316808c
FC
382 // Position trace at event rank [cacheSize]
383 context = fExperiment.seekEvent(new TmfTimestamp(cacheSize + 1, SCALE, 0));
384 assertEquals("Event rank", cacheSize, context.getRank());
25e48683 385
c32744d6 386 event = fExperiment.getNext(context);
0316808c
FC
387 assertEquals("Event timestamp", cacheSize + 1, event.getTimestamp().getValue());
388 assertEquals("Context rank", cacheSize + 1, context.getRank());
d18dd09b 389
0316808c
FC
390 // Position trace at event rank [4 * cacheSize]
391 context = fExperiment.seekEvent(new TmfTimestamp(4 * cacheSize + 1, SCALE, 0));
392 assertEquals("Context rank", 4 * cacheSize, context.getRank());
25e48683 393
c32744d6 394 event = fExperiment.getNext(context);
0316808c
FC
395 assertEquals("Event timestamp", 4 * cacheSize + 1, event.getTimestamp().getValue());
396 assertEquals("Context rank", 4 * cacheSize + 1, context.getRank());
d18dd09b
ASL
397 }
398
6e1886bc 399 @Test
54a7a54c 400 public void testSeekTimestampNotOnCacheBoundary() {
0316808c
FC
401 // Position trace at event rank 1 (TS = 2)
402 ITmfContext context = fExperiment.seekEvent(new TmfTimestamp(2, SCALE, 0));
403 assertEquals("Context rank", 1, context.getRank());
25e48683 404
c32744d6 405 ITmfEvent event = fExperiment.getNext(context);
d18dd09b 406 assertEquals("Event timestamp", 2, event.getTimestamp().getValue());
0316808c 407 assertEquals("Context rank", 2, context.getRank());
d18dd09b 408
0316808c 409 // Position trace at event rank 9 (TS = 10)
25e48683 410 context = fExperiment.seekEvent(new TmfTimestamp(10, SCALE, 0));
0316808c 411 assertEquals("Context rank", 9, context.getRank());
25e48683 412
c32744d6 413 event = fExperiment.getNext(context);
d18dd09b 414 assertEquals("Event timestamp", 10, event.getTimestamp().getValue());
0316808c 415 assertEquals("Context rank", 10, context.getRank());
d18dd09b 416
0316808c 417 // Position trace at event rank 999 (TS = 1000)
d18dd09b 418 context = fExperiment.seekEvent(new TmfTimestamp(1000, SCALE, 0));
0316808c 419 assertEquals("Context rank", 999, context.getRank());
25e48683 420
c32744d6 421 event = fExperiment.getNext(context);
d18dd09b 422 assertEquals("Event timestamp", 1000, event.getTimestamp().getValue());
0316808c 423 assertEquals("Context rank", 1000, context.getRank());
d18dd09b 424
0316808c 425 // Position trace at event rank 1001 (TS = 1002)
d18dd09b 426 context = fExperiment.seekEvent(new TmfTimestamp(1002, SCALE, 0));
0316808c 427 assertEquals("Context rank", 1001, context.getRank());
25e48683 428
c32744d6 429 event = fExperiment.getNext(context);
d18dd09b 430 assertEquals("Event timestamp", 1002, event.getTimestamp().getValue());
0316808c 431 assertEquals("Context rank", 1002, context.getRank());
d18dd09b 432
0316808c 433 // Position trace at event rank 4500 (TS = 4501)
d18dd09b 434 context = fExperiment.seekEvent(new TmfTimestamp(4501, SCALE, 0));
0316808c 435 assertEquals("Context rank", 4500, context.getRank());
25e48683 436
c32744d6 437 event = fExperiment.getNext(context);
d18dd09b 438 assertEquals("Event timestamp", 4501, event.getTimestamp().getValue());
0316808c 439 assertEquals("Context rank", 4501, context.getRank());
d18dd09b
ASL
440 }
441
6e1886bc 442 @Test
54a7a54c 443 public void testSeekTimestampOutOfScope() {
25e48683 444 // Position trace at beginning
0316808c 445 ITmfContext context = fExperiment.seekEvent(new TmfTimestamp(-1, SCALE, 0));
d18dd09b 446 assertEquals("Event rank", 0, context.getRank());
25e48683 447
c32744d6 448 ITmfEvent event = fExperiment.getNext(context);
d18dd09b
ASL
449 assertEquals("Event timestamp", 1, event.getTimestamp().getValue());
450 assertEquals("Event rank", 1, context.getRank());
451
25e48683 452 // Position trace at event passed the end
d18dd09b 453 context = fExperiment.seekEvent(new TmfTimestamp(NB_EVENTS + 1, SCALE, 0));
c32744d6 454 event = fExperiment.getNext(context);
0316808c 455 assertNull("Event location", event);
9b635e61 456 assertEquals("Event rank", ITmfContext.UNKNOWN_RANK, context.getRank());
d18dd09b
ASL
457 }
458
459 // ------------------------------------------------------------------------
0316808c 460 // seekEvent by location (context rank is undefined)
d18dd09b
ASL
461 // ------------------------------------------------------------------------
462
6e1886bc 463 @Test
54a7a54c 464 public void testSeekLocationOnCacheBoundary() {
0316808c 465 long cacheSize = fExperiment.getCacheSize();
d18dd09b 466
0316808c
FC
467 // Position trace at event rank 0
468 ITmfContext tmpContext = fExperiment.seekEvent(0);
469 ITmfContext context = fExperiment.seekEvent(tmpContext.getLocation());
25e48683 470
c32744d6 471 ITmfEvent event = fExperiment.getNext(context);
d18dd09b 472 assertEquals("Event timestamp", 1, event.getTimestamp().getValue());
25e48683 473
c32744d6 474 event = fExperiment.getNext(context);
0316808c 475 assertEquals("Event timestamp", 2, event.getTimestamp().getValue());
d18dd09b 476
0316808c
FC
477 // Position trace at event rank 'cacheSize'
478 tmpContext = fExperiment.seekEvent(cacheSize);
479 context = fExperiment.seekEvent(tmpContext.getLocation());
25e48683 480
c32744d6 481 event = fExperiment.getNext(context);
0316808c 482 assertEquals("Event timestamp", cacheSize + 1, event.getTimestamp().getValue());
25e48683 483
c32744d6 484 event = fExperiment.getNext(context);
0316808c 485 assertEquals("Event timestamp", cacheSize + 2, event.getTimestamp().getValue());
d18dd09b 486
0316808c
FC
487 // Position trace at event rank 4 * 'cacheSize'
488 tmpContext = fExperiment.seekEvent(4 * cacheSize);
489 context = fExperiment.seekEvent(tmpContext.getLocation());
25e48683 490
c32744d6 491 event = fExperiment.getNext(context);
0316808c 492 assertEquals("Event timestamp", 4 * cacheSize + 1, event.getTimestamp().getValue());
25e48683 493
c32744d6 494 event = fExperiment.getNext(context);
0316808c 495 assertEquals("Event timestamp", 4 * cacheSize + 2, event.getTimestamp().getValue());
d18dd09b
ASL
496 }
497
6e1886bc 498 @Test
54a7a54c 499 public void testSeekLocationNotOnCacheBoundary() {
0316808c 500 long cacheSize = fExperiment.getCacheSize();
25e48683 501
0316808c
FC
502 // Position trace at event 'cacheSize' - 1
503 ITmfContext tmpContext = fExperiment.seekEvent(cacheSize - 1);
504 ITmfContext context = fExperiment.seekEvent(tmpContext.getLocation());
d18dd09b 505
c32744d6 506 ITmfEvent event = fExperiment.getNext(context);
0316808c 507 assertEquals("Event timestamp", cacheSize, event.getTimestamp().getValue());
25e48683 508
c32744d6 509 event = fExperiment.getNext(context);
0316808c 510 assertEquals("Event timestamp", cacheSize + 1, event.getTimestamp().getValue());
d18dd09b 511
0316808c
FC
512 // Position trace at event rank 2 * 'cacheSize' - 1
513 tmpContext = fExperiment.seekEvent(2 * cacheSize - 1);
514 context = fExperiment.seekEvent(tmpContext.getLocation());
515 context = fExperiment.seekEvent(2 * cacheSize - 1);
25e48683 516
c32744d6 517 event = fExperiment.getNext(context);
0316808c 518 assertEquals("Event timestamp", 2 * cacheSize, event.getTimestamp().getValue());
25e48683 519
c32744d6 520 event = fExperiment.getNext(context);
0316808c 521 assertEquals("Event timestamp", 2 * cacheSize + 1, event.getTimestamp().getValue());
d18dd09b 522
25e48683 523 // Position trace at event rank 4500
0316808c
FC
524 tmpContext = fExperiment.seekEvent(4500);
525 context = fExperiment.seekEvent(tmpContext.getLocation());
25e48683 526
c32744d6 527 event = fExperiment.getNext(context);
d18dd09b 528 assertEquals("Event timestamp", 4501, event.getTimestamp().getValue());
25e48683 529
c32744d6 530 event = fExperiment.getNext(context);
0316808c 531 assertEquals("Event timestamp", 4502, event.getTimestamp().getValue());
d18dd09b
ASL
532 }
533
6e1886bc 534 @Test
54a7a54c 535 public void testSeekLocationOutOfScope() {
25e48683 536 // Position trace at beginning
1e1bef82 537 ITmfContext context = fExperiment.seekEvent((ITmfLocation) null);
25e48683 538
c32744d6 539 ITmfEvent event = fExperiment.getNext(context);
d18dd09b 540 assertEquals("Event timestamp", 1, event.getTimestamp().getValue());
d18dd09b 541 }
25e48683 542
9b635e61 543 // ------------------------------------------------------------------------
17324c9a 544 // getNext - updates the context
9b635e61
FC
545 // ------------------------------------------------------------------------
546
54a7a54c 547 private static void validateContextRanks(ITmfContext context) {
17324c9a
FC
548 assertTrue("Experiment context type", context instanceof TmfExperimentContext);
549 TmfExperimentContext ctx = (TmfExperimentContext) context;
9b635e61 550
17324c9a
FC
551 int nbTraces = ctx.getContexts().length;
552
553 // expRank = sum(trace ranks) - nbTraces + 1 (if lastTraceRead != NO_TRACE)
554 long expRank = -nbTraces + ((ctx.getLastTrace() != TmfExperimentContext.NO_TRACE) ? 1 : 0);
555 for (int i = 0; i < nbTraces; i++) {
556 long rank = ctx.getContexts()[i].getRank();
557 if (rank == -1) {
558 expRank = -1;
559 break;
560 }
561 expRank += rank;
562 }
563 assertEquals("Experiment context rank", expRank, ctx.getRank());
564 }
565
6e1886bc 566 @Test
54a7a54c 567 public void testGetNextAfteSeekingOnTS_1() {
9b635e61 568
17324c9a
FC
569 final long INITIAL_TS = 1;
570 final int NB_READS = 20;
571
572 // On lower bound, returns the first event (ts = 1)
573 final ITmfContext context = fExperiment.seekEvent(new TmfTimestamp(INITIAL_TS, SCALE, 0));
574
575 validateContextRanks(context);
576
577 // Read NB_EVENTS
578 ITmfEvent event;
579 for (int i = 0; i < NB_READS; i++) {
c32744d6 580 event = fExperiment.getNext(context);
17324c9a
FC
581 assertEquals("Event timestamp", INITIAL_TS + i, event.getTimestamp().getValue());
582 assertEquals("Event rank", INITIAL_TS + i, context.getRank());
9b635e61 583 }
17324c9a
FC
584
585 // Make sure we stay positioned
586 event = fExperiment.parseEvent(context);
587 assertEquals("Event timestamp", INITIAL_TS + NB_READS, event.getTimestamp().getValue());
588 assertEquals("Event rank", INITIAL_TS + NB_READS - 1, context.getRank());
589
590 validateContextRanks(context);
9b635e61
FC
591 }
592
6e1886bc 593 @Test
54a7a54c 594 public void testGetNextAfteSeekingOnTS_2() {
17324c9a
FC
595 final long INITIAL_TS = 2;
596 final int NB_READS = 20;
597
598 // On lower bound, returns the first event (ts = 2)
599 final ITmfContext context = fExperiment.seekEvent(new TmfTimestamp(INITIAL_TS, SCALE, 0));
600
601 validateContextRanks(context);
602
603 // Read NB_EVENTS
604 ITmfEvent event;
605 for (int i = 0; i < NB_READS; i++) {
606 event = fExperiment.getNext(context);
607 assertEquals("Event timestamp", INITIAL_TS + i, event.getTimestamp().getValue());
608 assertEquals("Event rank", INITIAL_TS + i, context.getRank());
609 }
610
611 // Make sure we stay positioned
612 event = fExperiment.parseEvent(context);
613 assertEquals("Event timestamp", INITIAL_TS + NB_READS, event.getTimestamp().getValue());
614 assertEquals("Event rank", INITIAL_TS + NB_READS - 1, context.getRank());
615
616 validateContextRanks(context);
617 }
618
6e1886bc 619 @Test
54a7a54c 620 public void testGetNextAfteSeekingOnTS_3() {
17324c9a
FC
621
622 final long INITIAL_TS = 500;
623 final int NB_READS = 20;
624
625 // On lower bound, returns the first event (ts = 500)
626 final ITmfContext context = fExperiment.seekEvent(new TmfTimestamp(INITIAL_TS, SCALE, 0));
627
628 validateContextRanks(context);
629
630 // Read NB_EVENTS
631 ITmfEvent event;
632 for (int i = 0; i < NB_READS; i++) {
633 event = fExperiment.getNext(context);
634 assertEquals("Event timestamp", INITIAL_TS + i, event.getTimestamp().getValue());
635 assertEquals("Event rank", INITIAL_TS + i, context.getRank());
636 }
637
638 // Make sure we stay positioned
639 event = fExperiment.parseEvent(context);
640 assertEquals("Event timestamp", INITIAL_TS + NB_READS, event.getTimestamp().getValue());
641 assertEquals("Event rank", INITIAL_TS + NB_READS - 1, context.getRank());
642
643 validateContextRanks(context);
644 }
645
6e1886bc 646 @Test
54a7a54c 647 public void testGetNextAfterSeekingOnRank_1() {
17324c9a
FC
648 final long INITIAL_RANK = 0L;
649 final int NB_READS = 20;
650
651 // On lower bound, returns the first event (rank = 0)
652 final ITmfContext context = fExperiment.seekEvent(INITIAL_RANK);
653
654 validateContextRanks(context);
655
656 // Read NB_EVENTS
657 ITmfEvent event;
658 for (int i = 0; i < NB_READS; i++) {
659 event = fExperiment.getNext(context);
660 assertEquals("Event timestamp", INITIAL_RANK + i + 1, event.getTimestamp().getValue());
661 assertEquals("Event rank", INITIAL_RANK + i + 1, context.getRank());
662 }
663
664 // Make sure we stay positioned
665 event = fExperiment.parseEvent(context);
666 assertEquals("Event timestamp", INITIAL_RANK + NB_READS + 1, event.getTimestamp().getValue());
667 assertEquals("Event rank", INITIAL_RANK + NB_READS, context.getRank());
668
669 validateContextRanks(context);
670 }
671
6e1886bc 672 @Test
54a7a54c 673 public void testGetNextAfterSeekingOnRank_2() {
17324c9a
FC
674 final long INITIAL_RANK = 1L;
675 final int NB_READS = 20;
676
677 // On lower bound, returns the first event (rank = 0)
678 final ITmfContext context = fExperiment.seekEvent(INITIAL_RANK);
679
680 validateContextRanks(context);
681
682 // Read NB_EVENTS
683 ITmfEvent event;
684 for (int i = 0; i < NB_READS; i++) {
685 event = fExperiment.getNext(context);
686 assertEquals("Event timestamp", INITIAL_RANK + i + 1, event.getTimestamp().getValue());
687 assertEquals("Event rank", INITIAL_RANK + i + 1, context.getRank());
688 }
689
690 // Make sure we stay positioned
691 event = fExperiment.parseEvent(context);
692 assertEquals("Event timestamp", INITIAL_RANK + NB_READS + 1, event.getTimestamp().getValue());
693 assertEquals("Event rank", INITIAL_RANK + NB_READS, context.getRank());
694
695 validateContextRanks(context);
696 }
697
6e1886bc 698 @Test
54a7a54c 699 public void testGetNextAfterSeekingOnRank_3() {
17324c9a
FC
700 final long INITIAL_RANK = 500L;
701 final int NB_READS = 20;
702
703 // On lower bound, returns the first event (rank = 0)
704 final ITmfContext context = fExperiment.seekEvent(INITIAL_RANK);
705
706 validateContextRanks(context);
707
708 // Read NB_EVENTS
709 ITmfEvent event;
710 for (int i = 0; i < NB_READS; i++) {
711 event = fExperiment.getNext(context);
712 assertEquals("Event timestamp", INITIAL_RANK + i + 1, event.getTimestamp().getValue());
713 assertEquals("Event rank", INITIAL_RANK + i + 1, context.getRank());
714 }
715
716 // Make sure we stay positioned
717 event = fExperiment.parseEvent(context);
718 assertEquals("Event timestamp", INITIAL_RANK + NB_READS + 1, event.getTimestamp().getValue());
719 assertEquals("Event rank", INITIAL_RANK + NB_READS, context.getRank());
720
721 validateContextRanks(context);
722 }
723
6e1886bc 724 @Test
54a7a54c 725 public void testGetNextAfterSeekingOnLocation_1() {
1e1bef82 726 final ITmfLocation INITIAL_LOC = null;
17324c9a
FC
727 final long INITIAL_TS = 1;
728 final int NB_READS = 20;
729
730 // On lower bound, returns the first event (ts = 1)
731 final ITmfContext context = fExperiment.seekEvent(INITIAL_LOC);
732
733 validateContextRanks(context);
734
735 // Read NB_EVENTS
736 ITmfEvent event;
737 for (int i = 0; i < NB_READS; i++) {
738 event = fExperiment.getNext(context);
739 assertEquals("Event timestamp", INITIAL_TS + i, event.getTimestamp().getValue());
740 assertEquals("Event rank", INITIAL_TS + i, context.getRank());
741 }
742
743 // Make sure we stay positioned
744 event = fExperiment.parseEvent(context);
745 assertEquals("Event timestamp", INITIAL_TS + NB_READS, event.getTimestamp().getValue());
746 assertEquals("Event rank", INITIAL_TS + NB_READS - 1, context.getRank());
747
748 validateContextRanks(context);
749 }
750
6e1886bc 751 @Test
54a7a54c 752 public void testGetNextAfterSeekingOnLocation_2() {
1e1bef82 753 final ITmfLocation INITIAL_LOC = fExperiment.seekEvent(1L).getLocation();
17324c9a
FC
754 final long INITIAL_TS = 2;
755 final int NB_READS = 20;
756
757 // On lower bound, returns the first event (ts = 2)
758 final ITmfContext context = fExperiment.seekEvent(INITIAL_LOC);
759
760 validateContextRanks(context);
761
762 // Read NB_EVENTS
763 ITmfEvent event;
764 for (int i = 0; i < NB_READS; i++) {
765 event = fExperiment.getNext(context);
766 assertEquals("Event timestamp", INITIAL_TS + i, event.getTimestamp().getValue());
767 }
768
769 // Make sure we stay positioned
770 event = fExperiment.parseEvent(context);
771 assertEquals("Event timestamp", INITIAL_TS + NB_READS, event.getTimestamp().getValue());
772
773 validateContextRanks(context);
774 }
775
6e1886bc 776 @Test
54a7a54c 777 public void testGetNextAfterSeekingOnLocation_3() {
1e1bef82 778 final ITmfLocation INITIAL_LOC = fExperiment.seekEvent(500L).getLocation();
17324c9a
FC
779 final long INITIAL_TS = 501;
780 final int NB_READS = 20;
781
782 // On lower bound, returns the first event (ts = 501)
783 final ITmfContext context = fExperiment.seekEvent(INITIAL_LOC);
784
785 validateContextRanks(context);
786
787 // Read NB_EVENTS
788 ITmfEvent event;
789 for (int i = 0; i < NB_READS; i++) {
790 event = fExperiment.getNext(context);
791 assertEquals("Event timestamp", INITIAL_TS + i, event.getTimestamp().getValue());
792 }
793
794 // Make sure we stay positioned
795 event = fExperiment.parseEvent(context);
796 assertEquals("Event timestamp", INITIAL_TS + NB_READS, event.getTimestamp().getValue());
797
798 validateContextRanks(context);
799 }
800
6e1886bc 801 @Test
54a7a54c 802 public void testGetNextLocation() {
17324c9a
FC
803 ITmfContext context1 = fExperiment.seekEvent(0);
804 fExperiment.getNext(context1);
d62bb185 805 ITmfLocation location = context1.getLocation();
17324c9a
FC
806 ITmfEvent event1 = fExperiment.getNext(context1);
807 ITmfContext context2 = fExperiment.seekEvent(location);
808 ITmfEvent event2 = fExperiment.getNext(context2);
809 assertEquals("Event timestamp", event1.getTimestamp().getValue(), event2.getTimestamp().getValue());
810 }
811
6e1886bc 812 @Test
54a7a54c 813 public void testGetNextEndLocation() {
17324c9a
FC
814 ITmfContext context1 = fExperiment.seekEvent(fExperiment.getNbEvents() - 1);
815 fExperiment.getNext(context1);
d62bb185 816 ITmfLocation location = context1.getLocation();
17324c9a
FC
817 ITmfContext context2 = fExperiment.seekEvent(location);
818 ITmfEvent event = fExperiment.getNext(context2);
819 assertNull("Event", event);
820 }
54a7a54c 821
d18dd09b
ASL
822 // ------------------------------------------------------------------------
823 // processRequest
824 // ------------------------------------------------------------------------
825
6e1886bc 826 @Test
54a7a54c 827 public void testProcessRequestForNbEvents() throws InterruptedException {
25e48683 828 final int blockSize = 100;
d18dd09b 829 final int nbEvents = 1000;
6256d8ad 830 final Vector<ITmfEvent> requestedEvents = new Vector<ITmfEvent>();
d18dd09b 831
25e48683 832 final TmfTimeRange range = new TmfTimeRange(TmfTimestamp.BIG_BANG, TmfTimestamp.BIG_CRUNCH);
7184fc40
AM
833 final TmfEventRequest request = new TmfEventRequest(ITmfEvent.class,
834 range, 0, nbEvents, blockSize, ExecutionType.FOREGROUND) {
d18dd09b 835 @Override
6256d8ad 836 public void handleData(final ITmfEvent event) {
25e48683 837 super.handleData(event);
f9673903 838 requestedEvents.add(event);
d18dd09b
ASL
839 }
840 };
841 fExperiment.sendRequest(request);
842 request.waitForCompletion();
843
844 assertEquals("nbEvents", nbEvents, requestedEvents.size());
845 assertTrue("isCompleted", request.isCompleted());
846 assertFalse("isCancelled", request.isCancelled());
847
848 // Ensure that we have distinct events.
25e48683 849 // Don't go overboard: we are not validating the stub!
20658947 850 for (int i = 0; i < nbEvents; i++) {
d18dd09b 851 assertEquals("Distinct events", i+1, requestedEvents.get(i).getTimestamp().getValue());
20658947 852 }
d18dd09b 853 }
25e48683 854
6e1886bc 855 @Test
54a7a54c 856 public void testProcessRequestForNbEvents2() throws InterruptedException {
25e48683 857 final int blockSize = 2 * NB_EVENTS;
d18dd09b 858 final int nbEvents = 1000;
6256d8ad 859 final Vector<ITmfEvent> requestedEvents = new Vector<ITmfEvent>();
d18dd09b 860
25e48683 861 final TmfTimeRange range = new TmfTimeRange(TmfTimestamp.BIG_BANG, TmfTimestamp.BIG_CRUNCH);
7184fc40
AM
862 final TmfEventRequest request = new TmfEventRequest(ITmfEvent.class,
863 range, 0, nbEvents, blockSize, ExecutionType.FOREGROUND) {
25e48683 864 @Override
6256d8ad 865 public void handleData(final ITmfEvent event) {
25e48683
FC
866 super.handleData(event);
867 requestedEvents.add(event);
868 }
d18dd09b
ASL
869 };
870 fExperiment.sendRequest(request);
871 request.waitForCompletion();
872
873 assertEquals("nbEvents", nbEvents, requestedEvents.size());
874 assertTrue("isCompleted", request.isCompleted());
875 assertFalse("isCancelled", request.isCancelled());
876
877 // Ensure that we have distinct events.
25e48683 878 // Don't go overboard: we are not validating the stub!
20658947 879 for (int i = 0; i < nbEvents; i++) {
d18dd09b 880 assertEquals("Distinct events", i+1, requestedEvents.get(i).getTimestamp().getValue());
20658947 881 }
d18dd09b 882 }
25e48683 883
6e1886bc 884 @Test
54a7a54c 885 public void testProcessRequestForAllEvents() throws InterruptedException {
9b749023 886 final int nbEvents = TmfDataRequest.ALL_DATA;
d18dd09b 887 final int blockSize = 1;
6256d8ad 888 final Vector<ITmfEvent> requestedEvents = new Vector<ITmfEvent>();
25e48683 889 final long nbExpectedEvents = NB_EVENTS;
d18dd09b 890
25e48683 891 final TmfTimeRange range = new TmfTimeRange(TmfTimestamp.BIG_BANG, TmfTimestamp.BIG_CRUNCH);
7184fc40
AM
892 final TmfEventRequest request = new TmfEventRequest(ITmfEvent.class,
893 range, 0, nbEvents, blockSize, ExecutionType.FOREGROUND) {
25e48683 894 @Override
6256d8ad 895 public void handleData(final ITmfEvent event) {
25e48683
FC
896 super.handleData(event);
897 requestedEvents.add(event);
898 }
d18dd09b
ASL
899 };
900 fExperiment.sendRequest(request);
901 request.waitForCompletion();
902
903 assertEquals("nbEvents", nbExpectedEvents, requestedEvents.size());
904 assertTrue("isCompleted", request.isCompleted());
905 assertFalse("isCancelled", request.isCancelled());
906
907 // Ensure that we have distinct events.
25e48683 908 // Don't go overboard: we are not validating the stub!
20658947 909 for (int i = 0; i < nbExpectedEvents; i++) {
d18dd09b 910 assertEquals("Distinct events", i+1, requestedEvents.get(i).getTimestamp().getValue());
20658947 911 }
d18dd09b 912 }
25e48683 913
d18dd09b
ASL
914 // ------------------------------------------------------------------------
915 // cancel
916 // ------------------------------------------------------------------------
917
6e1886bc 918 @Test
54a7a54c 919 public void testCancel() throws InterruptedException {
25e48683 920 final int nbEvents = NB_EVENTS;
0316808c 921 final int blockSize = BLOCK_SIZE;
6256d8ad 922 final Vector<ITmfEvent> requestedEvents = new Vector<ITmfEvent>();
d18dd09b 923
25e48683 924 final TmfTimeRange range = new TmfTimeRange(TmfTimestamp.BIG_BANG, TmfTimestamp.BIG_CRUNCH);
7184fc40
AM
925 final TmfEventRequest request = new TmfEventRequest(ITmfEvent.class,
926 range, 0, nbEvents, blockSize, ExecutionType.FOREGROUND) {
25e48683
FC
927 int nbRead = 0;
928 @Override
6256d8ad 929 public void handleData(final ITmfEvent event) {
25e48683
FC
930 super.handleData(event);
931 requestedEvents.add(event);
20658947 932 if (++nbRead == blockSize) {
25e48683 933 cancel();
20658947 934 }
25e48683 935 }
cb866e08
FC
936 @Override
937 public void handleCancel() {
20658947 938 if (requestedEvents.size() < blockSize) {
25e48683 939 System.out.println("aie");
20658947 940 }
cb866e08 941 }
d18dd09b
ASL
942 };
943 fExperiment.sendRequest(request);
944 request.waitForCompletion();
945
946 assertEquals("nbEvents", blockSize, requestedEvents.size());
947 assertTrue("isCompleted", request.isCompleted());
948 assertTrue("isCancelled", request.isCancelled());
949 }
25e48683 950
17324c9a 951}
This page took 0.341862 seconds and 5 git commands to generate.