aboutsummaryrefslogtreecommitdiffhomepage
path: root/site/dev
diff options
context:
space:
mode:
authorGravatar halcanary <halcanary@google.com>2016-02-12 08:08:27 -0800
committerGravatar Commit bot <commit-bot@chromium.org>2016-02-12 08:08:27 -0800
commit6f96cf4bde38337724b492a00dd8e0857d84d5d6 (patch)
tree824b7a9263d0506e7d4ec6058218b5eb52aec194 /site/dev
parent09bf666233bdb5e4e08bbeba2030055bc3bdef5f (diff)
Documantation: nanobench
Diffstat (limited to 'site/dev')
-rw-r--r--site/dev/testing/tests.md53
1 files changed, 51 insertions, 2 deletions
diff --git a/site/dev/testing/tests.md b/site/dev/testing/tests.md
index 1b440ad7ac..3b216e88af 100644
--- a/site/dev/testing/tests.md
+++ b/site/dev/testing/tests.md
@@ -1,5 +1,11 @@
-Writing Unit and Rendering Tests
-================================
+Writing Skia Tests
+==================
+
++ [Unit Tests](#test)
++ [Rendering Tests](#gm)
++ [Benchmark Tests](#bench)
+
+<span id="test"></span>
Writing a Unit Test
-------------------
@@ -29,6 +35,8 @@ Writing a Unit Test
ninja -C out/Debug dm
out/Debug/dm --match NewUnitTest
+<span id="gm"></span>
+
Writing a Rendering Test
------------------------
@@ -65,3 +73,44 @@ Writing a Rendering Test
On MacOS, try this:
out/Debug/SampleApp.app/Contents/MacOS/SampleApp --slide GM:newgmtest
+
+<span id="bench"></span>
+
+Writing a Benchmark Test
+------------------------
+
+1. Add a file `bench/FooBench.cpp`:
+
+ <!--?prettify lang=cc?-->
+
+ /*
+ * Copyright ........
+ *
+ * Use of this source code is governed by a BSD-style license
+ * that can be found in the LICENSE file.
+ */
+ #include "Benchmark.h"
+ #include "SkCanvas.h"
+ namespace {
+ class FooBench : public Benchmark {
+ public:
+ FooBench() {}
+ virtual ~FooBench() {}
+ protected:
+ const char* onGetName() override { return "Foo"; }
+ SkIPoint onGetSize() override { return SkIPoint{100, 100}; }
+ void onDraw(int loops, SkCanvas* canvas) override {
+ while (loops-- > 0) {
+ canvas->drawLine(0.0f, 0.0f, 100.0f, 100.0f, SkPaint());
+ }
+ }
+ };
+ } // namespace
+ DEF_BENCH(return new FooBench;)
+
+
+2. Recompile and run nanobench:
+
+ python bin/sync-and-gyp
+ ninja -C out/Release nanobench
+ out/Release/nanobench --match Foo