Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(774)

Unified Diff: runtime/vm/metrics_test.cc

Issue 464953002: Add VMMetric and some sample metrics (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: runtime/vm/metrics_test.cc
diff --git a/runtime/vm/metrics_test.cc b/runtime/vm/metrics_test.cc
new file mode 100644
index 0000000000000000000000000000000000000000..254679164e596e16ccaf5c7804558e4ab279753c
--- /dev/null
+++ b/runtime/vm/metrics_test.cc
@@ -0,0 +1,62 @@
+// 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 "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"
+
+namespace dart {
+
+UNIT_TEST_CASE(Metric_Simple) {
+ Isolate* isolate = Isolate::Init(NULL);
+ EXPECT_EQ(isolate, Isolate::Current());
+ VMMetric metric;
+
+ // Initialize metric.
+ metric.Init(Isolate::Current(), "a.b.c", "foobar", VMMetric::kCounter);
+ EXPECT_EQ(0, metric.value());
+ metric.increment();
+ EXPECT_EQ(1, metric.value());
+ metric.set_value(44);
+ EXPECT_EQ(44, metric.value());
+}
+
+class MyMetric : public VMMetric {
+ protected:
+ int64_t Value() const {
+ // 99 bytes.
koda 2014/08/13 22:43:00 It would be nicer if the unit (and also name and d
Cutch 2014/08/14 20:56:19 Yes. Although overriding is probably more verbose
+ return 99;
+ }
+
+ public:
+ // Just used for testing.
+ int64_t LeakyValue() const { return Value(); }
+};
+
+UNIT_TEST_CASE(Metric_OnDemand) {
+ Isolate* isolate = Isolate::Init(NULL);
+ EXPECT_EQ(isolate, Isolate::Current());
+ MyMetric metric;
+
+ metric.Init(Isolate::Current(), "a.b.c", "foobar", VMMetric::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\",\"id\":\"metrics\\/vm\\/a.b.c\""
+ ",\"value\":99.000000}", json);
+}
+
+} // namespace dart

Powered by Google App Engine
This is Rietveld 408576698