summaryrefslogtreecommitdiffstats
path: root/testing/gtest/mozilla/MozGTestBench.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'testing/gtest/mozilla/MozGTestBench.cpp')
-rw-r--r--testing/gtest/mozilla/MozGTestBench.cpp39
1 files changed, 39 insertions, 0 deletions
diff --git a/testing/gtest/mozilla/MozGTestBench.cpp b/testing/gtest/mozilla/MozGTestBench.cpp
new file mode 100644
index 000000000..15e5a7ae1
--- /dev/null
+++ b/testing/gtest/mozilla/MozGTestBench.cpp
@@ -0,0 +1,39 @@
+/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+#include "MozGTestBench.h"
+#include "mozilla/TimeStamp.h"
+#include <stdio.h>
+
+#define MOZ_GTEST_BENCH_FRAMEWORK "platform_microbench"
+
+using mozilla::TimeStamp;
+
+namespace mozilla {
+void GTestBench(const char* aSuite, const char* aName,
+ const mozilla::function<void()>& aTest)
+{
+#ifdef DEBUG
+ // Run the test to make sure that it doesn't fail but don't log
+ // any measurements since it's not an optimized build.
+ aTest();
+#else
+ mozilla::TimeStamp start = TimeStamp::Now();
+
+ aTest();
+
+ int msDuration = (TimeStamp::Now() - start).ToMicroseconds();
+
+ // Print the result for each test. Let perfherder aggregate for us
+ printf("PERFHERDER_DATA: {\"framework\": {\"name\": \"%s\"}, "
+ "\"suites\": [{\"name\": \"%s\", \"subtests\": "
+ "[{\"name\": \"%s\", \"value\": %i, \"lowerIsBetter\": true}]"
+ "}]}\n",
+ MOZ_GTEST_BENCH_FRAMEWORK, aSuite, aName, msDuration);
+#endif
+}
+
+} // mozilla
+