blob: 64900668bd6b59938ca9e0ad841fcf7212209194 [file] [log] [blame]
// Copyright (c) 2014, 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 "include/dart_api.h"
#include "include/dart_tools_api.h"
#include "vm/dart_api_impl.h"
#include "vm/dart_api_state.h"
#include "vm/globals.h"
#include "vm/json_stream.h"
#include "vm/metrics.h"
#include "vm/unit_test.h"
// #include "vm/heap.h"
namespace dart {
#if !defined(PRODUCT)
VM_UNIT_TEST_CASE(Metric_Simple) {
TestCase::CreateTestIsolate();
{
Metric metric;
// Initialize metric.
metric.InitInstance(Isolate::Current(), "a.b.c", "foobar",
Metric::kCounter);
EXPECT_EQ(0, metric.value());
metric.increment();
EXPECT_EQ(1, metric.value());
metric.set_value(44);
EXPECT_EQ(44, metric.value());
}
Dart_ShutdownIsolate();
}
class MyMetric : public Metric {
protected:
int64_t Value() const {
// 99 bytes.
return 99;
}
public:
// Just used for testing.
int64_t LeakyValue() const { return Value(); }
};
VM_UNIT_TEST_CASE(Metric_OnDemand) {
TestCase::CreateTestIsolate();
{
Thread* thread = Thread::Current();
TransitionNativeToVM transition(thread);
StackZone zone(thread);
MyMetric metric;
metric.InitInstance(Isolate::Current(), "a.b.c", "foobar", Metric::kByte);
// value is still the default value.
EXPECT_EQ(0, metric.value());
// Call LeakyValue to confirm that Value returns constant 99.
EXPECT_EQ(99, metric.LeakyValue());
// Serialize to JSON.
JSONStream js;
metric.PrintJSON(&js);
const char* json = js.ToCString();
EXPECT_STREQ(
"{\"type\":\"Counter\",\"name\":\"a.b.c\",\"description\":"
"\"foobar\",\"unit\":\"byte\","
"\"fixedId\":true,\"id\":\"metrics\\/native\\/a.b.c\""
",\"value\":99.0}",
json);
}
Dart_ShutdownIsolate();
}
#endif // !defined(PRODUCT)
ISOLATE_UNIT_TEST_CASE(Metric_EmbedderAPI) {
{
TransitionVMToNative transition(thread);
const char* kScript = "void main() {}";
Dart_Handle api_lib = TestCase::LoadTestScript(
kScript, /*resolver=*/nullptr, RESOLVED_USER_TEST_URI);
EXPECT_VALID(api_lib);
}
// Ensure we've done new/old GCs to ensure max metrics are initialized.
String::New("<land-in-new-space>", Heap::kNew);
thread->heap()->CollectGarbage(thread, GCType::kScavenge,
GCReason::kDebugging);
thread->heap()->CollectGarbage(thread, GCType::kMarkCompact,
GCReason::kDebugging);
// Ensure we've something live in new space.
String::New("<land-in-new-space2>", Heap::kNew);
EXPECT(thread->isolate_group()->GetHeapOldUsedMaxMetric()->Value() > 0);
EXPECT(thread->isolate_group()->GetHeapOldCapacityMaxMetric()->Value() > 0);
EXPECT(thread->isolate_group()->GetHeapNewUsedMaxMetric()->Value() > 0);
EXPECT(thread->isolate_group()->GetHeapNewCapacityMaxMetric()->Value() > 0);
EXPECT(thread->isolate_group()->GetHeapGlobalUsedMetric()->Value() > 0);
EXPECT(thread->isolate_group()->GetHeapGlobalUsedMaxMetric()->Value() > 0);
{
TransitionVMToNative transition(thread);
Dart_IsolateGroup isolate_group = Dart_CurrentIsolateGroup();
EXPECT(Dart_IsolateGroupHeapOldUsedMetric(isolate_group) > 0);
EXPECT(Dart_IsolateGroupHeapOldCapacityMetric(isolate_group) > 0);
EXPECT(Dart_IsolateGroupHeapNewUsedMetric(isolate_group) > 0);
EXPECT(Dart_IsolateGroupHeapNewCapacityMetric(isolate_group) > 0);
}
}
} // namespace dart