1 // Copyright 2020 The Pigweed Authors
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License"); you may not
4 // use this file except in compliance with the License. You may obtain a copy of
5 // the License at
6 //
7 //     https://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11 // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12 // License for the specific language governing permissions and limitations under
13 // the License.
14 
15 #define PW_TRACE_MODULE_NAME "TST"
16 #include "gtest/gtest.h"
17 #include "pw_trace/trace.h"
18 #include "pw_trace_test/fake_backend.h"
19 
20 using namespace trace_fake_backend;
21 
22 // Used by fake backend
23 LastEvent LastEvent::instance_;
24 
25 namespace {
26 
TraceFunction()27 void TraceFunction() {
28   PW_TRACE_FUNCTION();
29   // Can't check label, since might change depending on compiler.
30   EXPECT_TRUE(LastEvent::Instance().Get().IsEqualIgnoreLabel(
31       Event(DurationStart,
32             PW_TRACE_FLAGS_DEFAULT,
33             nullptr,
34             PW_TRACE_GROUP_LABEL_DEFAULT,
35             PW_TRACE_TRACE_ID_DEFAULT)));
36 }
37 
TraceFunctionGroup()38 void TraceFunctionGroup() {
39   PW_TRACE_FUNCTION("FunctionGroup");
40   // Can't check label, since might change depending on compiler.
41   EXPECT_TRUE(LastEvent::Instance().Get().IsEqualIgnoreLabel(
42       Event(DurationGroupStart,
43             PW_TRACE_FLAGS_DEFAULT,
44             nullptr,
45             "FunctionGroup",
46             PW_TRACE_TRACE_ID_DEFAULT)));
47 }
48 
49 const char kSomeData[] = "SOME DATA";
50 
51 }  // namespace
52 
TEST(BasicTrace,Instant)53 TEST(BasicTrace, Instant) {
54   PW_TRACE_INSTANT("Test");
55   EXPECT_EQ(LastEvent::Instance().Get(),
56             Event(Instantaneous,
57                   PW_TRACE_FLAGS_DEFAULT,
58                   "Test",
59                   PW_TRACE_GROUP_LABEL_DEFAULT,
60                   PW_TRACE_TRACE_ID_DEFAULT));
61 }
62 
TEST(BasicTrace,InstantGroup)63 TEST(BasicTrace, InstantGroup) {
64   PW_TRACE_INSTANT("Test", "group");
65   EXPECT_EQ(LastEvent::Instance().Get(),
66             Event(InstantaneousGroup,
67                   PW_TRACE_FLAGS_DEFAULT,
68                   "Test",
69                   "group",
70                   PW_TRACE_TRACE_ID_DEFAULT));
71 }
72 
TEST(BasicTrace,Duration)73 TEST(BasicTrace, Duration) {
74   PW_TRACE_START("Test");
75   EXPECT_EQ(LastEvent::Instance().Get(),
76             Event(DurationStart,
77                   PW_TRACE_FLAGS_DEFAULT,
78                   "Test",
79                   PW_TRACE_GROUP_LABEL_DEFAULT,
80                   PW_TRACE_TRACE_ID_DEFAULT));
81   PW_TRACE_END("Test");
82   EXPECT_EQ(LastEvent::Instance().Get(),
83             Event(DurationEnd,
84                   PW_TRACE_FLAGS_DEFAULT,
85                   "Test",
86                   PW_TRACE_GROUP_LABEL_DEFAULT,
87                   PW_TRACE_TRACE_ID_DEFAULT));
88 }
89 
TEST(BasicTrace,DurationGroup)90 TEST(BasicTrace, DurationGroup) {
91   PW_TRACE_START("Parent", "group");
92   EXPECT_EQ(LastEvent::Instance().Get(),
93             Event(DurationGroupStart,
94                   PW_TRACE_FLAGS_DEFAULT,
95                   "Parent",
96                   "group",
97                   PW_TRACE_TRACE_ID_DEFAULT));
98   PW_TRACE_START("Child", "group");
99   EXPECT_EQ(LastEvent::Instance().Get(),
100             Event(DurationGroupStart,
101                   PW_TRACE_FLAGS_DEFAULT,
102                   "Child",
103                   "group",
104                   PW_TRACE_TRACE_ID_DEFAULT));
105   PW_TRACE_END("Child", "group");
106   EXPECT_EQ(LastEvent::Instance().Get(),
107             Event(DurationGroupEnd,
108                   PW_TRACE_FLAGS_DEFAULT,
109                   "Child",
110                   "group",
111                   PW_TRACE_TRACE_ID_DEFAULT));
112   PW_TRACE_START("Other Child", "group");
113   EXPECT_EQ(LastEvent::Instance().Get(),
114             Event(DurationGroupStart,
115                   PW_TRACE_FLAGS_DEFAULT,
116                   "Other Child",
117                   "group",
118                   PW_TRACE_TRACE_ID_DEFAULT));
119   PW_TRACE_END("Other Child", "group");
120   EXPECT_EQ(LastEvent::Instance().Get(),
121             Event(DurationGroupEnd,
122                   PW_TRACE_FLAGS_DEFAULT,
123                   "Other Child",
124                   "group",
125                   PW_TRACE_TRACE_ID_DEFAULT));
126   PW_TRACE_END("Parent", "group");
127   EXPECT_EQ(LastEvent::Instance().Get(),
128             Event(DurationGroupEnd,
129                   PW_TRACE_FLAGS_DEFAULT,
130                   "Parent",
131                   "group",
132                   PW_TRACE_TRACE_ID_DEFAULT));
133 }
134 
TEST(BasicTrace,Async)135 TEST(BasicTrace, Async) {
136   uint32_t trace_id = 1;
137   PW_TRACE_START("async", "group", trace_id);
138   EXPECT_EQ(
139       LastEvent::Instance().Get(),
140       Event(AsyncStart, PW_TRACE_FLAGS_DEFAULT, "async", "group", trace_id));
141   PW_TRACE_INSTANT("step", "group", trace_id);
142   EXPECT_EQ(
143       LastEvent::Instance().Get(),
144       Event(AsyncStep, PW_TRACE_FLAGS_DEFAULT, "step", "group", trace_id));
145   PW_TRACE_END("async", "group", trace_id);
146   EXPECT_EQ(
147       LastEvent::Instance().Get(),
148       Event(AsyncEnd, PW_TRACE_FLAGS_DEFAULT, "async", "group", trace_id));
149 }
150 
TEST(BasicTrace,Scope)151 TEST(BasicTrace, Scope) {
152   {
153     PW_TRACE_SCOPE("scoped trace");
154     EXPECT_EQ(LastEvent::Instance().Get(),
155               Event(DurationStart,
156                     PW_TRACE_FLAGS_DEFAULT,
157                     "scoped trace",
158                     PW_TRACE_GROUP_LABEL_DEFAULT,
159                     PW_TRACE_TRACE_ID_DEFAULT));
160   }
161   EXPECT_EQ(LastEvent::Instance().Get(),
162             Event(DurationEnd,
163                   PW_TRACE_FLAGS_DEFAULT,
164                   "scoped trace",
165                   PW_TRACE_GROUP_LABEL_DEFAULT,
166                   PW_TRACE_TRACE_ID_DEFAULT));
167 }
168 
TEST(BasicTrace,ScopeGroup)169 TEST(BasicTrace, ScopeGroup) {
170   {
171     PW_TRACE_SCOPE("scoped group trace", "group");
172     EXPECT_EQ(LastEvent::Instance().Get(),
173               Event(DurationGroupStart,
174                     PW_TRACE_FLAGS_DEFAULT,
175                     "scoped group trace",
176                     "group",
177                     PW_TRACE_TRACE_ID_DEFAULT));
178     {
179       PW_TRACE_SCOPE("sub scoped group trace", "group");
180       EXPECT_EQ(LastEvent::Instance().Get(),
181                 Event(DurationGroupStart,
182                       PW_TRACE_FLAGS_DEFAULT,
183                       "sub scoped group trace",
184                       "group",
185                       PW_TRACE_TRACE_ID_DEFAULT));
186     }
187     EXPECT_EQ(LastEvent::Instance().Get(),
188               Event(DurationGroupEnd,
189                     PW_TRACE_FLAGS_DEFAULT,
190                     "sub scoped group trace",
191                     "group",
192                     PW_TRACE_TRACE_ID_DEFAULT));
193   }
194   EXPECT_EQ(LastEvent::Instance().Get(),
195             Event(DurationGroupEnd,
196                   PW_TRACE_FLAGS_DEFAULT,
197                   "scoped group trace",
198                   "group",
199                   PW_TRACE_TRACE_ID_DEFAULT));
200 }
201 
TEST(BasicTrace,ScopeTraceId)202 TEST(BasicTrace, ScopeTraceId) {
203   static constexpr uint32_t kTraceId = 5;
204   {
205     PW_TRACE_SCOPE("scoped trace id", "group", kTraceId);
206     EXPECT_EQ(LastEvent::Instance().Get(),
207               Event(AsyncStart,
208                     PW_TRACE_FLAGS_DEFAULT,
209                     "scoped trace id",
210                     "group",
211                     kTraceId));
212   }
213   EXPECT_EQ(LastEvent::Instance().Get(),
214             Event(AsyncEnd,
215                   PW_TRACE_FLAGS_DEFAULT,
216                   "scoped trace id",
217                   "group",
218                   kTraceId));
219 }
220 
TEST(BasicTrace,Function)221 TEST(BasicTrace, Function) {
222   TraceFunction();
223   // Can't check label, since might change depending on compiler.
224   EXPECT_TRUE(LastEvent::Instance().Get().IsEqualIgnoreLabel(
225       Event(DurationEnd,
226             PW_TRACE_FLAGS_DEFAULT,
227             nullptr,
228             PW_TRACE_GROUP_LABEL_DEFAULT,
229             PW_TRACE_TRACE_ID_DEFAULT)));
230 }
231 
TEST(BasicTrace,FunctionGroup)232 TEST(BasicTrace, FunctionGroup) {
233   TraceFunctionGroup();
234   // Can't check label, since might change depending on compiler.
235   EXPECT_TRUE(LastEvent::Instance().Get().IsEqualIgnoreLabel(
236       Event(DurationGroupEnd,
237             PW_TRACE_FLAGS_DEFAULT,
238             nullptr,
239             "FunctionGroup",
240             PW_TRACE_TRACE_ID_DEFAULT)));
241 }
242 
TEST(BasicTrace,InstantData)243 TEST(BasicTrace, InstantData) {
244   PW_TRACE_INSTANT_DATA("Test", "s", kSomeData, sizeof(kSomeData));
245   EXPECT_EQ(LastEvent::Instance().Get(),
246             Event(Instantaneous,
247                   PW_TRACE_FLAGS_DEFAULT,
248                   "Test",
249                   PW_TRACE_GROUP_LABEL_DEFAULT,
250                   PW_TRACE_TRACE_ID_DEFAULT,
251                   "s",
252                   kSomeData,
253                   sizeof(kSomeData)));
254 }
255 
TEST(BasicTrace,InstantGroupData)256 TEST(BasicTrace, InstantGroupData) {
257   PW_TRACE_INSTANT_DATA("Test", "Group", "s", kSomeData, sizeof(kSomeData));
258   EXPECT_EQ(LastEvent::Instance().Get(),
259             Event(InstantaneousGroup,
260                   PW_TRACE_FLAGS_DEFAULT,
261                   "Test",
262                   "Group",
263                   PW_TRACE_TRACE_ID_DEFAULT,
264                   "s",
265                   kSomeData,
266                   sizeof(kSomeData)));
267 }
268 
TEST(BasicTrace,DurationData)269 TEST(BasicTrace, DurationData) {
270   PW_TRACE_START_DATA("Test", "s", kSomeData, sizeof(kSomeData));
271   EXPECT_EQ(LastEvent::Instance().Get(),
272             Event(DurationStart,
273                   PW_TRACE_FLAGS_DEFAULT,
274                   "Test",
275                   PW_TRACE_GROUP_LABEL_DEFAULT,
276                   PW_TRACE_TRACE_ID_DEFAULT,
277                   "s",
278                   kSomeData,
279                   sizeof(kSomeData)));
280   PW_TRACE_END_DATA("Test", "s", kSomeData, sizeof(kSomeData));
281   EXPECT_EQ(LastEvent::Instance().Get(),
282             Event(DurationEnd,
283                   PW_TRACE_FLAGS_DEFAULT,
284                   "Test",
285                   PW_TRACE_GROUP_LABEL_DEFAULT,
286                   PW_TRACE_TRACE_ID_DEFAULT,
287                   "s",
288                   kSomeData,
289                   sizeof(kSomeData)));
290 }
291 
TEST(BasicTrace,DurationGroupData)292 TEST(BasicTrace, DurationGroupData) {
293   PW_TRACE_START_DATA("Parent", "group", "s", kSomeData, sizeof(kSomeData));
294   EXPECT_EQ(LastEvent::Instance().Get(),
295             Event(DurationGroupStart,
296                   PW_TRACE_FLAGS_DEFAULT,
297                   "Parent",
298                   "group",
299                   PW_TRACE_TRACE_ID_DEFAULT,
300                   "s",
301                   kSomeData,
302                   sizeof(kSomeData)));
303   PW_TRACE_START_DATA("Child", "group", "s", kSomeData, sizeof(kSomeData));
304   EXPECT_EQ(LastEvent::Instance().Get(),
305             Event(DurationGroupStart,
306                   PW_TRACE_FLAGS_DEFAULT,
307                   "Child",
308                   "group",
309                   PW_TRACE_TRACE_ID_DEFAULT,
310                   "s",
311                   kSomeData,
312                   sizeof(kSomeData)));
313   PW_TRACE_END_DATA("Child", "group", "s", kSomeData, sizeof(kSomeData));
314   EXPECT_EQ(LastEvent::Instance().Get(),
315             Event(DurationGroupEnd,
316                   PW_TRACE_FLAGS_DEFAULT,
317                   "Child",
318                   "group",
319                   PW_TRACE_TRACE_ID_DEFAULT,
320                   "s",
321                   kSomeData,
322                   sizeof(kSomeData)));
323   PW_TRACE_END_DATA("Parent", "group", "s", kSomeData, sizeof(kSomeData));
324   EXPECT_EQ(LastEvent::Instance().Get(),
325             Event(DurationGroupEnd,
326                   PW_TRACE_FLAGS_DEFAULT,
327                   "Parent",
328                   "group",
329                   PW_TRACE_TRACE_ID_DEFAULT,
330                   "s",
331                   kSomeData,
332                   sizeof(kSomeData)));
333 }
334 
TEST(BasicTrace,AsyncData)335 TEST(BasicTrace, AsyncData) {
336   uint32_t trace_id = 1;
337   PW_TRACE_START_DATA(
338       "label for start", "group", trace_id, "s", kSomeData, sizeof(kSomeData));
339   EXPECT_EQ(LastEvent::Instance().Get(),
340             Event(AsyncStart,
341                   PW_TRACE_FLAGS_DEFAULT,
342                   "label for start",
343                   "group",
344                   trace_id,
345                   "s",
346                   kSomeData,
347                   sizeof(kSomeData)));
348   PW_TRACE_INSTANT_DATA(
349       "label for step", "group", trace_id, "s", kSomeData, sizeof(kSomeData));
350   EXPECT_EQ(LastEvent::Instance().Get(),
351             Event(AsyncStep,
352                   PW_TRACE_FLAGS_DEFAULT,
353                   "label for step",
354                   "group",
355                   trace_id,
356                   "s",
357                   kSomeData,
358                   sizeof(kSomeData)));
359   PW_TRACE_END_DATA(
360       "label for end", "group", trace_id, "s", kSomeData, sizeof(kSomeData));
361   EXPECT_EQ(LastEvent::Instance().Get(),
362             Event(AsyncEnd,
363                   PW_TRACE_FLAGS_DEFAULT,
364                   "label for end",
365                   "group",
366                   trace_id,
367                   "s",
368                   kSomeData,
369                   sizeof(kSomeData)));
370 }
371 
TEST(BasicTrace,ProvideFlag)372 TEST(BasicTrace, ProvideFlag) {
373   PW_TRACE_INSTANT_FLAG(5, "Test");
374   EXPECT_EQ(LastEvent::Instance().Get(),
375             Event(Instantaneous,
376                   5,
377                   "Test",
378                   PW_TRACE_GROUP_LABEL_DEFAULT,
379                   PW_TRACE_TRACE_ID_DEFAULT));
380 }
381 
TEST(BasicTrace,MacroFlag)382 TEST(BasicTrace, MacroFlag) {
383 #undef PW_TRACE_FLAGS
384 #define PW_TRACE_FLAGS 6
385   PW_TRACE_INSTANT("Test");
386   EXPECT_EQ(LastEvent::Instance().Get(),
387             Event(Instantaneous,
388                   6,
389                   "Test",
390                   PW_TRACE_GROUP_LABEL_DEFAULT,
391                   PW_TRACE_TRACE_ID_DEFAULT));
392 #undef PW_TRACE_FLAGS
393 #define PW_TRACE_FLAGS PW_TRACE_FLAGS_DEFAULT
394   PW_TRACE_INSTANT("Test");
395   EXPECT_EQ(LastEvent::Instance().Get(),
396             Event(Instantaneous,
397                   PW_TRACE_FLAGS_DEFAULT,
398                   "Test",
399                   PW_TRACE_GROUP_LABEL_DEFAULT,
400                   PW_TRACE_TRACE_ID_DEFAULT));
401 }
402