File: TestGeckoTraceAPI.cpp

package info (click to toggle)
firefox 143.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,617,328 kB
  • sloc: cpp: 7,478,492; javascript: 6,417,157; ansic: 3,720,058; python: 1,396,372; xml: 627,523; asm: 438,677; java: 186,156; sh: 63,477; makefile: 19,171; objc: 13,059; perl: 12,983; yacc: 4,583; cs: 3,846; pascal: 3,405; lex: 1,720; ruby: 1,003; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 53; csh: 10
file content (67 lines) | stat: -rw-r--r-- 1,866 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#include <memory>

#include "gtest/gtest.h"

#include "Common.h"
#include "mozilla/GeckoTrace.h"

namespace mozilla::gecko_trace::tests {

class GeckoTraceAPITest : public TestWithInMemorySpanExporter {};

class TestEvent : public mozilla::gecko_trace::SpanEvent {
 public:
  bool ForEachKeyValue(std::function<bool(string_view, AttributeValue)>
                           aCallback) const override {
    return true;
  }

  string_view GetEventName() const override { return "manual.test"; }

  size_t Size() const override { return 0; }
};

TEST_F(GeckoTraceAPITest, NestedSpans) {
  {
    GECKO_TRACE_SCOPE("gtests", "outer span");

    TestEvent().Emit();

    {
      auto tracer = mozilla::gecko_trace::TracerProvider::GetTracer("test");
      auto innerSpan = tracer->StartSpan("inner span non macro");

      innerSpan->AddEvent(TestEvent());
    }

    TestEvent().Emit();
  }

  auto spans = mSpanData->GetSpans();

#ifdef GECKO_TRACE_ENABLE
  EXPECT_EQ(spans.size(), 2u) << "Expected exactly 2 spans (outer and inner)";

  // Verify span hierarchy - inner span should be child of outer span
  if (spans.size() >= 2) {
    // The spans should be ordered with inner span first (due to scope ending)
    // and outer span second
    const auto& innerSpan = spans[0];
    const auto& outerSpan = spans[1];

    EXPECT_EQ(innerSpan->GetName(), "inner span non macro");
    EXPECT_EQ(innerSpan->GetEvents().size(), 1u)
        << "Expected exactly 1 event in inner span";
    EXPECT_EQ(outerSpan->GetName(), "outer span");
    EXPECT_EQ(outerSpan->GetEvents().size(), 2u)
        << "Expected exactly 2 events in outer span";

    // Verify parent-child relationship
    EXPECT_EQ(innerSpan->GetParentSpanId(), outerSpan->GetSpanId());
  }
#else
  EXPECT_EQ(spans.size(), 0u) << "Expected exactly 0 spans";
#endif
}

}  // namespace mozilla::gecko_trace::tests