| Index: test/cctest/test-trace-event.cc
|
| diff --git a/test/cctest/test-trace-event.cc b/test/cctest/test-trace-event.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..a889e088f667dcdcd5907b8e2c48a5459920c920
|
| --- /dev/null
|
| +++ b/test/cctest/test-trace-event.cc
|
| @@ -0,0 +1,258 @@
|
| +// 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 <stdlib.h>
|
| +#include <string.h>
|
| +
|
| +#include "src/v8.h"
|
| +
|
| +#include "src/list.h"
|
| +#include "src/list-inl.h"
|
| +#include "test/cctest/cctest.h"
|
| +
|
| +using v8::IdleTask;
|
| +using v8::Task;
|
| +using v8::Isolate;
|
| +
|
| +#include "src/tracing/trace-event.h"
|
| +
|
| +#define GET_TRACE_OBJECTS_LIST platform.GetMockTraceObjects()
|
| +
|
| +#define GET_TRACE_OBJECT(Index) GET_TRACE_OBJECTS_LIST->at(Index)
|
| +
|
| +
|
| +struct MockTraceObject {
|
| + char phase;
|
| + std::string name;
|
| + uint64_t id;
|
| + uint64_t bind_id;
|
| + int num_args;
|
| + unsigned int flags;
|
| + MockTraceObject(char phase, std::string name, uint64_t id, uint64_t bind_id,
|
| + int num_args, int flags)
|
| + : phase(phase),
|
| + name(name),
|
| + id(id),
|
| + bind_id(bind_id),
|
| + num_args(num_args),
|
| + flags(flags) {}
|
| +};
|
| +
|
| +typedef v8::internal::List<MockTraceObject*> MockTraceObjectList;
|
| +
|
| +class MockTracingPlatform : public v8::Platform {
|
| + public:
|
| + explicit MockTracingPlatform(v8::Platform* platform) {}
|
| + virtual ~MockTracingPlatform() {
|
| + for (int i = 0; i < trace_object_list_.length(); ++i) {
|
| + delete trace_object_list_[i];
|
| + }
|
| + trace_object_list_.Clear();
|
| + }
|
| + void CallOnBackgroundThread(Task* task,
|
| + ExpectedRuntime expected_runtime) override {}
|
| +
|
| + void CallOnForegroundThread(Isolate* isolate, Task* task) override {}
|
| +
|
| + void CallDelayedOnForegroundThread(Isolate* isolate, Task* task,
|
| + double delay_in_seconds) override {}
|
| +
|
| + double MonotonicallyIncreasingTime() override { return 0.0; }
|
| +
|
| + void CallIdleOnForegroundThread(Isolate* isolate, IdleTask* task) override {}
|
| +
|
| + bool IdleTasksEnabled(Isolate* isolate) override { return false; }
|
| +
|
| + bool PendingIdleTask() { return false; }
|
| +
|
| + void PerformIdleTask(double idle_time_in_seconds) {}
|
| +
|
| + bool PendingDelayedTask() { return false; }
|
| +
|
| + void PerformDelayedTask() {}
|
| +
|
| + uint64_t AddTraceEvent(char phase, const uint8_t* category_enabled_flag,
|
| + const char* name, uint64_t id, uint64_t bind_id,
|
| + int num_args, const char** arg_names,
|
| + const uint8_t* arg_types, const uint64_t* arg_values,
|
| + unsigned int flags) override {
|
| + MockTraceObject* to = new MockTraceObject(phase, std::string(name), id,
|
| + bind_id, num_args, flags);
|
| + trace_object_list_.Add(to);
|
| + return 0;
|
| + }
|
| +
|
| + void UpdateTraceEventDuration(const uint8_t* category_enabled_flag,
|
| + const char* name, uint64_t handle) override {}
|
| +
|
| + const uint8_t* GetCategoryGroupEnabled(const char* name) override {
|
| + if (strcmp(name, "v8-cat")) {
|
| + static uint8_t no = 0;
|
| + return &no;
|
| + } else {
|
| + static uint8_t yes = 0x7;
|
| + return &yes;
|
| + }
|
| + }
|
| +
|
| + const char* GetCategoryGroupName(
|
| + const uint8_t* category_enabled_flag) override {
|
| + static const char dummy[] = "dummy";
|
| + return dummy;
|
| + }
|
| +
|
| + MockTraceObjectList* GetMockTraceObjects() { return &trace_object_list_; }
|
| +
|
| + private:
|
| + MockTraceObjectList trace_object_list_;
|
| +};
|
| +
|
| +
|
| +TEST(TraceEventDisabledCategory) {
|
| + v8::Platform* old_platform = i::V8::GetCurrentPlatform();
|
| + MockTracingPlatform platform(old_platform);
|
| + i::V8::SetPlatformForTesting(&platform);
|
| +
|
| + // Disabled category, will not add events.
|
| + TRACE_EVENT_BEGIN0("cat", "e1");
|
| + TRACE_EVENT_END0("cat", "e1");
|
| + CHECK_EQ(0, GET_TRACE_OBJECTS_LIST->length());
|
| +
|
| + i::V8::SetPlatformForTesting(old_platform);
|
| +}
|
| +
|
| +
|
| +TEST(TraceEventNoArgs) {
|
| + v8::Platform* old_platform = i::V8::GetCurrentPlatform();
|
| + MockTracingPlatform platform(old_platform);
|
| + i::V8::SetPlatformForTesting(&platform);
|
| +
|
| + // Enabled category will add 2 events.
|
| + TRACE_EVENT_BEGIN0("v8-cat", "e1");
|
| + TRACE_EVENT_END0("v8-cat", "e1");
|
| +
|
| + CHECK_EQ(2, GET_TRACE_OBJECTS_LIST->length());
|
| + CHECK_EQ('B', GET_TRACE_OBJECT(0)->phase);
|
| + CHECK_EQ("e1", GET_TRACE_OBJECT(0)->name);
|
| + CHECK_EQ(0, GET_TRACE_OBJECT(0)->num_args);
|
| +
|
| + CHECK_EQ('E', GET_TRACE_OBJECT(1)->phase);
|
| + CHECK_EQ("e1", GET_TRACE_OBJECT(1)->name);
|
| + CHECK_EQ(0, GET_TRACE_OBJECT(1)->num_args);
|
| +
|
| + i::V8::SetPlatformForTesting(old_platform);
|
| +}
|
| +
|
| +
|
| +TEST(TraceEventWithOneArg) {
|
| + v8::Platform* old_platform = i::V8::GetCurrentPlatform();
|
| + MockTracingPlatform platform(old_platform);
|
| + i::V8::SetPlatformForTesting(&platform);
|
| +
|
| + 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");
|
| +
|
| + CHECK_EQ(4, GET_TRACE_OBJECTS_LIST->length());
|
| +
|
| + CHECK_EQ(1, GET_TRACE_OBJECT(0)->num_args);
|
| + CHECK_EQ(1, GET_TRACE_OBJECT(1)->num_args);
|
| + CHECK_EQ(1, GET_TRACE_OBJECT(2)->num_args);
|
| + CHECK_EQ(1, GET_TRACE_OBJECT(3)->num_args);
|
| +
|
| + i::V8::SetPlatformForTesting(old_platform);
|
| +}
|
| +
|
| +
|
| +TEST(TraceEventWithTwoArgs) {
|
| + v8::Platform* old_platform = i::V8::GetCurrentPlatform();
|
| + MockTracingPlatform platform(old_platform);
|
| + i::V8::SetPlatformForTesting(&platform);
|
| +
|
| + 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);
|
| +
|
| + CHECK_EQ(4, GET_TRACE_OBJECTS_LIST->length());
|
| +
|
| + CHECK_EQ(2, GET_TRACE_OBJECT(0)->num_args);
|
| + CHECK_EQ(2, GET_TRACE_OBJECT(1)->num_args);
|
| + CHECK_EQ(2, GET_TRACE_OBJECT(2)->num_args);
|
| + CHECK_EQ(2, GET_TRACE_OBJECT(3)->num_args);
|
| +
|
| + i::V8::SetPlatformForTesting(old_platform);
|
| +}
|
| +
|
| +
|
| +TEST(ScopedTraceEvent) {
|
| + v8::Platform* old_platform = i::V8::GetCurrentPlatform();
|
| + MockTracingPlatform platform(old_platform);
|
| + i::V8::SetPlatformForTesting(&platform);
|
| +
|
| + { TRACE_EVENT0("v8-cat", "e"); }
|
| +
|
| + CHECK_EQ(1, GET_TRACE_OBJECTS_LIST->length());
|
| + CHECK_EQ(0, GET_TRACE_OBJECT(0)->num_args);
|
| +
|
| + { TRACE_EVENT1("v8-cat", "e1", "arg1", "abc"); }
|
| +
|
| + CHECK_EQ(2, GET_TRACE_OBJECTS_LIST->length());
|
| + CHECK_EQ(1, GET_TRACE_OBJECT(1)->num_args);
|
| +
|
| + { TRACE_EVENT2("v8-cat", "e1", "arg1", "abc", "arg2", 42); }
|
| +
|
| + CHECK_EQ(3, GET_TRACE_OBJECTS_LIST->length());
|
| + CHECK_EQ(2, GET_TRACE_OBJECT(2)->num_args);
|
| +
|
| + i::V8::SetPlatformForTesting(old_platform);
|
| +}
|
| +
|
| +
|
| +TEST(TestEventWithFlow) {
|
| + v8::Platform* old_platform = i::V8::GetCurrentPlatform();
|
| + MockTracingPlatform platform(old_platform);
|
| + i::V8::SetPlatformForTesting(&platform);
|
| +
|
| + static uint64_t bind_id = 21;
|
| + {
|
| + TRACE_EVENT_WITH_FLOW0("v8-cat", "f1", bind_id, TRACE_EVENT_FLAG_FLOW_OUT);
|
| + }
|
| + {
|
| + TRACE_EVENT_WITH_FLOW0(
|
| + "v8-cat", "f2", bind_id,
|
| + TRACE_EVENT_FLAG_FLOW_IN | TRACE_EVENT_FLAG_FLOW_OUT);
|
| + }
|
| + { TRACE_EVENT_WITH_FLOW0("v8-cat", "f3", bind_id, TRACE_EVENT_FLAG_FLOW_IN); }
|
| +
|
| + CHECK_EQ(3, GET_TRACE_OBJECTS_LIST->length());
|
| + CHECK_EQ(bind_id, GET_TRACE_OBJECT(0)->bind_id);
|
| + CHECK_EQ(TRACE_EVENT_FLAG_FLOW_OUT, GET_TRACE_OBJECT(0)->flags);
|
| + CHECK_EQ(bind_id, GET_TRACE_OBJECT(1)->bind_id);
|
| + CHECK_EQ(TRACE_EVENT_FLAG_FLOW_IN | TRACE_EVENT_FLAG_FLOW_OUT,
|
| + GET_TRACE_OBJECT(1)->flags);
|
| + CHECK_EQ(bind_id, GET_TRACE_OBJECT(2)->bind_id);
|
| + CHECK_EQ(TRACE_EVENT_FLAG_FLOW_IN, GET_TRACE_OBJECT(2)->flags);
|
| +
|
| + i::V8::SetPlatformForTesting(old_platform);
|
| +}
|
| +
|
| +
|
| +TEST(TestEventWithId) {
|
| + v8::Platform* old_platform = i::V8::GetCurrentPlatform();
|
| + MockTracingPlatform platform(old_platform);
|
| + i::V8::SetPlatformForTesting(&platform);
|
| +
|
| + static uint64_t event_id = 21;
|
| + TRACE_EVENT_ASYNC_BEGIN0("v8-cat", "a1", event_id);
|
| + TRACE_EVENT_ASYNC_END0("v8-cat", "a1", event_id);
|
| +
|
| + CHECK_EQ(2, GET_TRACE_OBJECTS_LIST->length());
|
| + CHECK_EQ(TRACE_EVENT_PHASE_ASYNC_BEGIN, GET_TRACE_OBJECT(0)->phase);
|
| + CHECK_EQ(event_id, GET_TRACE_OBJECT(0)->id);
|
| + CHECK_EQ(TRACE_EVENT_PHASE_ASYNC_END, GET_TRACE_OBJECT(1)->phase);
|
| + CHECK_EQ(event_id, GET_TRACE_OBJECT(1)->id);
|
| +
|
| + i::V8::SetPlatformForTesting(old_platform);
|
| +}
|
|
|