Index: test/unittests/tracing/trace-event-unittest.cc |
diff --git a/test/unittests/tracing/trace-event-unittest.cc b/test/unittests/tracing/trace-event-unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..3180a731a8b11a4d235bd7c46e589123feccf4c4 |
--- /dev/null |
+++ b/test/unittests/tracing/trace-event-unittest.cc |
@@ -0,0 +1,143 @@ |
+// Copyright 2015 the V8 project authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include <include/v8-tracing.h> |
+ |
+#include "src/list.h" |
+#include "src/list-inl.h" |
+#include "src/tracing/trace-event.h" |
+#include "testing/gtest-support.h" |
+ |
+ |
+#define GET_TRACE_OBJECTS_LIST \ |
+ mock_event_tracer->GetMockTraceObjects() |
+ |
+#define GET_TRACE_OBJECT(Index) \ |
+ GET_TRACE_OBJECTS_LIST->at(Index) |
+ |
+namespace v8 { |
+namespace tracing_internals { |
+ |
+struct MockTraceObject { |
+ char phase; |
+ const char* name; |
+ int numArgs; |
+ MockTraceObject(char phase, const char* name, int numArgs): |
+ phase(phase), name(name), numArgs(numArgs){} |
+}; |
+ |
+typedef internal::List<MockTraceObject*> MockTraceObjectList; |
+ |
+class MockEventTracer : public v8::EventTracer { |
+ virtual v8::EventTracer::Handle AddTraceEvent( |
+ char phase, const uint8_t* categoryEnabledFlag, const char* name, |
+ uint64_t id, int numArgs, const char** argNames, const uint8_t* argTypes, |
+ const uint64_t* argValues, uint8_t flags) { |
+ MockTraceObject* to = new MockTraceObject(phase, name, numArgs); |
+ trace_object_list_.Add(to); |
+ return 0; |
+ } |
+ |
+ virtual void UpdateTraceEventDuration(const uint8_t* categoryEnabledFlag, |
+ const char* name, |
+ EventTracer::Handle handle) {} |
+ |
+ virtual const uint8_t* GetCategoryGroupEnabled(const char* name) { |
+ if (strcmp(name, "v8-cat")) { |
+ static uint8_t no = 0; |
+ return &no; |
+ } else { |
+ static uint8_t yes = 0x7; |
+ return &yes; |
+ } |
+ } |
+ |
+ virtual const char* GetCategoryGroupName(const uint8_t* categoryEnabledFlag) { |
+ static const char* dummy = "dummy"; |
+ return dummy; |
+ } |
+ |
+ MockTraceObjectList trace_object_list_; |
+ |
+ public: |
+ ~MockEventTracer() { |
+ for (int i = 0; i < trace_object_list_.length(); ++i) { |
+ delete trace_object_list_[i]; |
+ } |
+ trace_object_list_.Clear(); |
+ } |
+ |
+ MockTraceObjectList* GetMockTraceObjects() { |
+ return &trace_object_list_; |
+ } |
+}; |
+ |
+ |
+TEST(TraceEvent, TraceEventDisabledCategory) { |
+ MockEventTracer* mock_event_tracer = new MockEventTracer(); |
+ v8::EventTracer::SetInstance(mock_event_tracer); |
+ |
+ // Disabled category, will not add events. |
+ TRACE_EVENT_BEGIN0("cat", "e1"); |
+ TRACE_EVENT_END0("cat", "e1"); |
+ EXPECT_EQ(0, GET_TRACE_OBJECTS_LIST->length()); |
+} |
+ |
+ |
+TEST(TraceEvent, TraceEventNoArgs) { |
+ MockEventTracer* mock_event_tracer = new MockEventTracer(); |
+ v8::EventTracer::SetInstance(mock_event_tracer); |
+ |
+ // Enabled category will add 2 events. |
+ TRACE_EVENT_BEGIN0("v8-cat", "e1"); |
+ TRACE_EVENT_END0("v8-cat", "e1"); |
+ |
+ EXPECT_EQ(2, GET_TRACE_OBJECTS_LIST->length()); |
+ EXPECT_EQ('B', GET_TRACE_OBJECT(0)->phase); |
+ EXPECT_EQ("e1", GET_TRACE_OBJECT(0)->name); |
+ EXPECT_EQ(0, GET_TRACE_OBJECT(0)->numArgs); |
+ |
+ EXPECT_EQ('E', GET_TRACE_OBJECT(1)->phase); |
+ EXPECT_EQ("e1", GET_TRACE_OBJECT(1)->name); |
+ EXPECT_EQ(0, GET_TRACE_OBJECT(1)->numArgs); |
+} |
+ |
+ |
+TEST(TraceEvent, TraceEventWithOneArg) { |
+ MockEventTracer* mock_event_tracer = new MockEventTracer(); |
+ v8::EventTracer::SetInstance(mock_event_tracer); |
+ |
+ TRACE_EVENT_BEGIN1("v8-cat", "e1", "arg1", 42); |
+ TRACE_EVENT_END1("v8-cat", "e1", "arg1", 42); |
+ TRACE_EVENT_BEGIN1("v8-cat", "e2", "arg1", "abc"); |
+ TRACE_EVENT_END1("v8-cat", "e2", "arg1", "abc"); |
+ |
+ EXPECT_EQ(4, GET_TRACE_OBJECTS_LIST->length()); |
+ |
+ EXPECT_EQ(1, GET_TRACE_OBJECT(0)->numArgs); |
+ EXPECT_EQ(1, GET_TRACE_OBJECT(1)->numArgs); |
+ EXPECT_EQ(1, GET_TRACE_OBJECT(2)->numArgs); |
+ EXPECT_EQ(1, GET_TRACE_OBJECT(3)->numArgs); |
+} |
+ |
+ |
+TEST(TraceEvent, TraceEventWithTwoArgs) { |
+ MockEventTracer* mock_event_tracer = new MockEventTracer(); |
+ v8::EventTracer::SetInstance(mock_event_tracer); |
+ |
+ TRACE_EVENT_BEGIN2("v8-cat", "e1", "arg1", 42, "arg2", "abc"); |
+ TRACE_EVENT_END2("v8-cat", "e1", "arg1", 42, "arg2", "abc"); |
+ TRACE_EVENT_BEGIN2("v8-cat", "e2", "arg1", "abc", "arg2", 43); |
+ TRACE_EVENT_END2("v8-cat", "e2", "arg1", "abc", "arg2", 43); |
+ |
+ EXPECT_EQ(4, GET_TRACE_OBJECTS_LIST->length()); |
+ |
+ EXPECT_EQ(2, GET_TRACE_OBJECT(0)->numArgs); |
+ EXPECT_EQ(2, GET_TRACE_OBJECT(1)->numArgs); |
+ EXPECT_EQ(2, GET_TRACE_OBJECT(2)->numArgs); |
+ EXPECT_EQ(2, GET_TRACE_OBJECT(3)->numArgs); |
+} |
+ |
+} // namespace tracing_internals |
+} // namespace v8 |