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

Unified Diff: tools/unittests/ignition_perf_report_test.py

Issue 1783503002: [Interpreter] Add Ignition profile visualization tool. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@run-perf
Patch Set: Test symbol name regex w/ template instantiations. Created 4 years, 9 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
« tools/ignition_perf_report.py ('K') | « tools/ignition_perf_report.py ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/unittests/ignition_perf_report_test.py
diff --git a/tools/unittests/ignition_perf_report_test.py b/tools/unittests/ignition_perf_report_test.py
new file mode 100644
index 0000000000000000000000000000000000000000..245dadaabe0c16aa5ebf9d51b464af47a649db3e
--- /dev/null
+++ b/tools/unittests/ignition_perf_report_test.py
@@ -0,0 +1,135 @@
+# Copyright 2016 the V8 project authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+import ignition_perf_report as ipr
+import StringIO
+import unittest
+
+
+## perf script test output.
+
+PERF_SCRIPT_OUTPUT = """
+# This line is a comment
+# This should be ignored too
+#
+# cdefab01 aRandomSymbol::Name(to, be, ignored)
+
+ 00000000 firstSymbol
+ 00000123 secondSymbol
+
+ 01234567 foo
+ abcdef76 BytecodeHandler:bar
+ 76543210 baz
+
+# Indentation shouldn't matter (neither should this line)
+
+ 01234567 foo
+ abcdef76 BytecodeHandler:bar
+ 76543210 baz
+
+ 01234567 beep
+ abcdef76 BytecodeHandler:bar
+ 76543210 baz
+
+ 01234567 hello
+ abcdef76 Builtin:CompileLazy
+ 76543210 world
+ 11111111 BytecodeHandler:nope
+"""
+
+## hide_compile_time = False test data.
+
+PERF_SCRIPT_YIELDED_CALLCHAINS = [
+ ["foo", "BytecodeHandler:bar"],
+ ["foo", "BytecodeHandler:bar"],
+ ["beep", "BytecodeHandler:bar"],
+ ["hello", "Builtin:CompileLazy", "world", "BytecodeHandler:nope"],
+]
+
+
+CALLCHAINS_COUNTERS = [
+ ('BytecodeHandler:bar;foo', 2),
+ ('BytecodeHandler:bar;beep', 1),
+ ('BytecodeHandler:nope;world;Builtin:CompileLazy;hello', 1),
+]
+
+
+HANDLER_SAMPLE_COUNTERS = [
+ ("bar", 3),
+ ("nope", 1),
+]
+
+
+## hide_compile_time = True test data.
+
+PERF_SCRIPT_YIELDED_CALLCHAINS_HIDE_COMPILE = [
+ ["foo", "BytecodeHandler:bar"],
+ ["foo", "BytecodeHandler:bar"],
+ ["beep", "BytecodeHandler:bar"],
+]
+
+
+CALLCHAINS_COUNTERS_HIDE_COMPILE = [
+ ('BytecodeHandler:bar;foo', 2),
+ ('BytecodeHandler:bar;beep', 1),
+]
+
+
+HANDLER_SAMPLE_COUNTERS_HIDE_COMPILE = [
+ ("bar", 3),
+]
+
+## Regex test cases.
+
+COMPILER_SYMBOLS = [
+ "Builtin:CompileLazy",
+ "Builtin:CompileOptimizedConcurrent",
+ "LazyCompile:foo",
+ "v8::internal::Compile::foo",
+]
+
+
+SYMBOLS_AND_NAMES = [
+ ("foo::(anonymous namespace)::bar(baz)", "foo::(anonymous namespace)::bar"),
+ ("foo::bar<baz<beep>, blop>(hello, world)", "foo::bar<baz<beep>, blop>"),
+ ("hello(world)", "hello"),
+]
+
+
+class IgnitionPerfReportTest(unittest.TestCase):
rmcilroy 2016/03/11 11:26:49 Are these tests run on the bots? If not they are p
+ def testYieldCollapsedCallchains(self):
+ perf_stream = StringIO.StringIO(PERF_SCRIPT_OUTPUT)
+ callchains = list(ipr.yield_collapsed_callchains(perf_stream, False))
+ self.assertListEqual(callchains, PERF_SCRIPT_YIELDED_CALLCHAINS)
+
+ def testYieldCollapsedCallchainsHideCompile(self):
+ perf_stream = StringIO.StringIO(PERF_SCRIPT_OUTPUT)
+ callchains = list(ipr.yield_collapsed_callchains(perf_stream, True))
+ self.assertListEqual(callchains,
+ PERF_SCRIPT_YIELDED_CALLCHAINS_HIDE_COMPILE)
+
+ def testCountCallchains(self):
+ counters = ipr.count_callchains(PERF_SCRIPT_YIELDED_CALLCHAINS)
+ self.assertItemsEqual(counters, CALLCHAINS_COUNTERS)
rmcilroy 2016/03/11 11:26:49 nit - could you make CALLCHAINS_COUNTERS a constan
Stefano Sanfilippo 2016/03/11 16:33:51 I'd prefer to keep them all outside, in case we ad
rmcilroy 2016/03/14 12:26:52 I disagree - the tests should be easy to reason ab
Stefano Sanfilippo 2016/03/14 13:14:20 I see. Done.
+
+ def testCountCallchainsHideCompile(self):
+ counters = ipr.count_callchains(PERF_SCRIPT_YIELDED_CALLCHAINS_HIDE_COMPILE)
+ self.assertItemsEqual(counters, CALLCHAINS_COUNTERS_HIDE_COMPILE)
+
+ def testCountHandlerSamples(self):
+ counters = ipr.count_handler_samples(PERF_SCRIPT_YIELDED_CALLCHAINS)
+ self.assertItemsEqual(counters, HANDLER_SAMPLE_COUNTERS)
+
+ def testCountHandlerSamplesHideCompile(self):
+ counters = ipr.count_handler_samples(
+ PERF_SCRIPT_YIELDED_CALLCHAINS_HIDE_COMPILE)
+ self.assertItemsEqual(counters, HANDLER_SAMPLE_COUNTERS_HIDE_COMPILE)
+
+ def testCompilerSymbolsRegex(self):
+ for compiler_symbol in COMPILER_SYMBOLS:
+ self.assertTrue(ipr.COMPILER_SYMBOLS_RE.match(compiler_symbol))
+
+ def testSymbolNameRegex(self):
+ for symbol, name in SYMBOLS_AND_NAMES:
+ self.assertEqual(ipr.SYMBOL_NAME_RE.match(symbol).group(1), name)
« tools/ignition_perf_report.py ('K') | « tools/ignition_perf_report.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698