1 /*******************************************************************************
2 * Copyright (c) 2013, 2014 Ericsson
3 * All rights reserved. This program and the accompanying materials
4 * are made available under the terms of the Eclipse Public License v1.0
5 * which accompanies this distribution, and is available at
6 * http://www.eclipse.org/legal/epl-v10.html
9 * Matthew Khouzam - Initial API and implementation
10 *******************************************************************************/
12 package org
.eclipse
.linuxtools
.ctf
.core
.tests
.trace
;
14 import static org
.junit
.Assert
.assertEquals
;
15 import static org
.junit
.Assert
.assertNotNull
;
16 import static org
.junit
.Assert
.assertNull
;
17 import static org
.junit
.Assert
.fail
;
18 import static org
.junit
.Assume
.assumeTrue
;
20 import java
.nio
.ByteOrder
;
21 import java
.util
.UUID
;
23 import org
.eclipse
.linuxtools
.ctf
.core
.tests
.shared
.CtfTestTrace
;
24 import org
.eclipse
.linuxtools
.ctf
.core
.trace
.CTFReaderException
;
25 import org
.eclipse
.linuxtools
.ctf
.core
.trace
.CTFTrace
;
26 import org
.eclipse
.linuxtools
.ctf
.core
.trace
.Metadata
;
27 import org
.eclipse
.linuxtools
.ctf
.core
.trace
.CTFStream
;
28 import org
.junit
.Before
;
29 import org
.junit
.Test
;
32 * The class <code>MetadataTest</code> contains tests for the class
33 * <code>{@link Metadata}</code>.
36 * @version $Revision: 1.0 $
38 @SuppressWarnings("javadoc")
39 public class MetadataTest
{
41 private static final CtfTestTrace testTrace
= CtfTestTrace
.KERNEL
;
42 private static final String mdStart
= "typealias integer { size = 8; align = 8; signed = false; } := uint8_t;\n" +
43 " typealias integer { size = 16; align = 8; signed = false; } := uint16_t;\n" +
44 " typealias integer { size = 32; align = 8; signed = false; } := uint32_t;\n" +
45 " typealias integer { size = 64; align = 8; signed = false; } := uint64_t;\n" +
46 " typealias integer { size = 64; align = 8; signed = false; } := unsigned long;\n" +
47 " typealias integer { size = 5; align = 1; signed = false; } := uint5_t;\n" +
48 " typealias integer { size = 27; align = 1; signed = false; } := uint27_t;\n" +
53 " uuid = \"8b1258ba-effb-554b-b779-fbd676746000\";\n" +
54 " byte_order = le;\n" +
55 " packet.header := struct {\n" +
56 " uint32_t magic;\n" +
57 " uint8_t uuid[16];\n" +
58 " uint32_t stream_id;\n" +
63 " hostname = \"computer\";\n" +
64 " domain = \"kernel\";\n" +
65 " sysname = \"BeOS\";\n" +
66 " kernel_release = \"95\";\n" +
67 " kernel_version = \"BeWare 95\";\n" +
68 " tracer_name = \"BeOS Tracer\";\n" +
69 " tracer_major = 2;\n" +
70 " tracer_minor = 3;\n" +
71 " tracer_patchlevel = 0;\n" +
74 " name = monotonic;\n" +
75 " uuid = \"4d737a79-e3f1-4f4d-a649-42015266baf5\";\n" +
76 " description = \"Monotonic Clock\";\n" +
77 " freq = 1000000000; /* Frequency, in Hz */\n" +
78 " /* clock value offset from Epoch is: offset * (1/freq) */\n" +
79 " offset = 1383600210829415521;\n" +
82 " typealias integer {\n" +
83 "size = 27; align = 1; signed = false;\n" +
84 " map = clock.monotonic.value;\n" +
85 " } := uint27_clock_monotonic_t;\n" +
87 " typealias integer {\n" +
88 " size = 32; align = 8; signed = false;\n" +
89 " map = clock.monotonic.value;\n" +
90 " } := uint32_clock_monotonic_t;\n" +
92 " typealias integer {\n" +
93 " size = 64; align = 8; signed = false;\n" +
94 " map = clock.monotonic.value;\n" +
95 " } := uint64_clock_monotonic_t;\n" +
97 " struct packet_context {\n" +
98 " uint64_clock_monotonic_t timestamp_begin;\n" +
99 " uint64_clock_monotonic_t timestamp_end;\n" +
100 " uint64_t content_size;\n" +
101 " uint64_t packet_size;\n" +
102 " unsigned long events_discarded;\n" +
103 " uint32_t cpu_id;\n" +
106 " struct event_header_compact {\n" +
107 " enum : uint5_t { compact = 0 ... 30, extended = 31 } id;\n" +
108 " variant <id> {\n" +
110 " uint27_clock_monotonic_t timestamp;\n" +
114 " uint64_clock_monotonic_t timestamp;\n" +
119 " struct event_header_large {\n" +
120 " enum : uint16_t { compact = 0 ... 65534, extended = 65535 } id;\n" +
121 " variant <id> {\n" +
123 " uint32_clock_monotonic_t timestamp;\n" +
127 " uint64_clock_monotonic_t timestamp;\n" +
134 " event.header := struct event_header_compact;\n" +
135 " packet.context := struct packet_context;\n" +
139 " name = sched_switch;\n" +
141 " stream_id = 0;\n" +
142 " fields := struct {\n" +
143 " integer { size = 8; align = 8; signed = 1; encoding = UTF8; base = 10; } _prev_comm[16];\n" +
144 " integer { size = 32; align = 8; signed = 1; encoding = none; base = 10; } _prev_tid;\n" +
145 " integer { size = 32; align = 8; signed = 1; encoding = none; base = 10; } _prev_prio;\n" +
146 " integer { size = 64; align = 8; signed = 1; encoding = none; base = 10; } _prev_state;\n" +
147 " integer { size = 8; align = 8; signed = 1; encoding = UTF8; base = 10; } _next_comm[16];\n" +
148 " integer { size = 32; align = 8; signed = 1; encoding = none; base = 10; } _next_tid;\n" +
149 " integer { size = 32; align = 8; signed = 1; encoding = none; base = 10; } _next_prio;\n" +
153 private static final String mdSecond
= " event {\n" +
154 " name = bozo_the_clown;\n" +
156 " stream_id = 0;\n" +
157 " fields := struct {\n" +
158 " integer { size = 32; align = 8; signed = 1; encoding = none; base = 10; } clown_nose;\n" +
162 private Metadata fixture
;
165 * Perform pre-test initialization.
167 * @throws CTFReaderException
170 public void setUp() throws CTFReaderException
{
171 assumeTrue(testTrace
.exists());
172 fixture
= new Metadata(testTrace
.getTrace());
176 * Run the Metadata(CTFTrace) constructor test.
179 public void testMetadata() {
180 assertNotNull(fixture
);
184 public void testTextMD() throws CTFReaderException
{
185 testSingleFragment();
188 protected CTFTrace
testSingleFragment() throws CTFReaderException
{
189 fixture
= new Metadata();
190 CTFTrace trace
= fixture
.getTrace();
191 for (CTFStream s
: trace
.getStreams()) {
192 fail("This should be empty, has" + s
.toString());
194 fixture
.parseText(mdStart
);
196 for (CTFStream s
: trace
.getStreams()) {
200 assertEquals(1, count
);
201 assertEquals(1, trace
.getEvents(0L).size());
206 public void testStreamTextMD() throws CTFReaderException
{
207 CTFTrace trace
= testSingleFragment();
208 fixture
.parseTextFragment(mdSecond
);
209 assertEquals(2, trace
.getEvents(0L).size());
210 assertEquals("bozo_the_clown", trace
.getEvents(0L).get(1L).getName());
214 * Run the ByteOrder getDetectedByteOrder() method test.
216 * @throws CTFReaderException
219 public void testGetDetectedByteOrder() throws CTFReaderException
{
221 ByteOrder result
= fixture
.getDetectedByteOrder();
228 * @throws CTFReaderException
231 public void testToString() throws CTFReaderException
{
233 String result
= fixture
.toString();
234 assertNotNull(result
);
238 * Run the void parse() method test.
240 * @throws CTFReaderException
243 public void testParse() throws CTFReaderException
{
245 assertEquals(new UUID(0xd18e637435a1cd42L
, 0x8e70a9cffa712793L
), testTrace
.getTrace().getUUID());
246 assertEquals(1332166405241713920.0, testTrace
.getTrace().getClock().getClockOffset(), 200.0);
247 assertEquals(8, testTrace
.getTrace().getEnvironment().size());
This page took 0.035908 seconds and 5 git commands to generate.