mirror of
https://github.com/dart-lang/sdk
synced 2024-09-22 05:31:22 +00:00
1186078de6
R=johnmccutchan@google.com Review URL: https://codereview.chromium.org//328663008 git-svn-id: https://dart.googlecode.com/svn/branches/bleeding_edge/dart@37298 260f80e4-7a28-3924-810f-c04153c831b5
107 lines
3.5 KiB
C++
107 lines
3.5 KiB
C++
// Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
|
|
// for details. All rights reserved. Use of this source code is governed by a
|
|
// BSD-style license that can be found in the LICENSE file.
|
|
|
|
#include "platform/assert.h"
|
|
#include "vm/globals.h"
|
|
#include "vm/json_stream.h"
|
|
#include "vm/trace_buffer.h"
|
|
#include "vm/unit_test.h"
|
|
|
|
namespace dart {
|
|
|
|
TEST_CASE(TraceBufferEmpty) {
|
|
Isolate* isolate = Isolate::Current();
|
|
TraceBuffer::Init(isolate, 3);
|
|
TraceBuffer* trace_buffer = isolate->trace_buffer();
|
|
{
|
|
JSONStream js;
|
|
trace_buffer->PrintToJSONStream(&js);
|
|
EXPECT_STREQ("{\"type\":\"TraceBuffer\",\"members\":[]}", js.ToCString());
|
|
}
|
|
delete trace_buffer;
|
|
}
|
|
|
|
|
|
TEST_CASE(TraceBufferClear) {
|
|
Isolate* isolate = Isolate::Current();
|
|
TraceBuffer::Init(isolate, 3);
|
|
TraceBuffer* trace_buffer = isolate->trace_buffer();
|
|
trace_buffer->Trace(kMicrosecondsPerSecond * 1, "abc");
|
|
trace_buffer->Clear();
|
|
{
|
|
JSONStream js;
|
|
trace_buffer->PrintToJSONStream(&js);
|
|
EXPECT_STREQ("{\"type\":\"TraceBuffer\",\"members\":[]}", js.ToCString());
|
|
}
|
|
delete trace_buffer;
|
|
}
|
|
|
|
|
|
TEST_CASE(TraceBufferTrace) {
|
|
Isolate* isolate = Isolate::Current();
|
|
TraceBuffer::Init(isolate, 3);
|
|
TraceBuffer* trace_buffer = isolate->trace_buffer();
|
|
|
|
trace_buffer->Trace(kMicrosecondsPerSecond * 1, "abc");
|
|
{
|
|
JSONStream js;
|
|
trace_buffer->PrintToJSONStream(&js);
|
|
EXPECT_STREQ("{\"type\":\"TraceBuffer\",\"members\":["
|
|
"{\"type\":\"TraceBufferEntry\",\"time\":1.000000,"
|
|
"\"message\":\"abc\"}]}", js.ToCString());
|
|
}
|
|
trace_buffer->Trace(kMicrosecondsPerSecond * 2, "def");
|
|
{
|
|
JSONStream js;
|
|
trace_buffer->PrintToJSONStream(&js);
|
|
EXPECT_STREQ("{\"type\":\"TraceBuffer\",\"members\":["
|
|
"{\"type\":\"TraceBufferEntry\",\"time\":1.000000,"
|
|
"\"message\":\"abc\"},"
|
|
"{\"type\":\"TraceBufferEntry\",\"time\":2.000000,"
|
|
"\"message\":\"def\"}]}", js.ToCString());
|
|
}
|
|
trace_buffer->Trace(kMicrosecondsPerSecond * 3, "ghi");
|
|
{
|
|
JSONStream js;
|
|
trace_buffer->PrintToJSONStream(&js);
|
|
EXPECT_STREQ("{\"type\":\"TraceBuffer\",\"members\":["
|
|
"{\"type\":\"TraceBufferEntry\",\"time\":1.000000,"
|
|
"\"message\":\"abc\"},"
|
|
"{\"type\":\"TraceBufferEntry\",\"time\":2.000000,"
|
|
"\"message\":\"def\"},"
|
|
"{\"type\":\"TraceBufferEntry\",\"time\":3.000000,"
|
|
"\"message\":\"ghi\"}]}", js.ToCString());
|
|
}
|
|
// This will overwrite the first Trace.
|
|
trace_buffer->Trace(kMicrosecondsPerSecond * 4, "jkl");
|
|
{
|
|
JSONStream js;
|
|
trace_buffer->PrintToJSONStream(&js);
|
|
EXPECT_STREQ("{\"type\":\"TraceBuffer\",\"members\":["
|
|
"{\"type\":\"TraceBufferEntry\",\"time\":2.000000,"
|
|
"\"message\":\"def\"},"
|
|
"{\"type\":\"TraceBufferEntry\",\"time\":3.000000,"
|
|
"\"message\":\"ghi\"},"
|
|
"{\"type\":\"TraceBufferEntry\",\"time\":4.000000,"
|
|
"\"message\":\"jkl\"}]}", js.ToCString());
|
|
}
|
|
delete trace_buffer;
|
|
}
|
|
|
|
|
|
TEST_CASE(TraceBufferTraceF) {
|
|
Isolate* isolate = Isolate::Current();
|
|
TraceBuffer::Init(isolate, 3);
|
|
TraceBuffer* trace_buffer = isolate->trace_buffer();
|
|
trace_buffer->TraceF("foo %d %s", 99, "bar");
|
|
{
|
|
JSONStream js;
|
|
trace_buffer->PrintToJSONStream(&js);
|
|
EXPECT_SUBSTRING("foo 99 bar", js.ToCString());
|
|
}
|
|
delete trace_buffer;
|
|
}
|
|
|
|
} // namespace dart
|