| Index: tools/telemetry/third_party/coverage/tests/plugin2.py
|
| diff --git a/tools/telemetry/third_party/coverage/tests/plugin2.py b/tools/telemetry/third_party/coverage/tests/plugin2.py
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..3bdfbdfd37f7afb59a16f5b7a9761793dd9a5acd
|
| --- /dev/null
|
| +++ b/tools/telemetry/third_party/coverage/tests/plugin2.py
|
| @@ -0,0 +1,49 @@
|
| +# Licensed under the Apache License: http://www.apache.org/licenses/LICENSE-2.0
|
| +# For details: https://bitbucket.org/ned/coveragepy/src/default/NOTICE.txt
|
| +
|
| +"""A plugin for test_plugins.py to import."""
|
| +
|
| +import os.path
|
| +
|
| +import coverage
|
| +
|
| +
|
| +class Plugin(coverage.CoveragePlugin):
|
| + """A plugin for testing."""
|
| + def file_tracer(self, filename):
|
| + if "render.py" in filename:
|
| + return RenderFileTracer()
|
| +
|
| + def file_reporter(self, filename):
|
| + return FileReporter(filename)
|
| +
|
| +
|
| +class RenderFileTracer(coverage.FileTracer):
|
| + """A FileTracer using information from the caller."""
|
| +
|
| + def has_dynamic_source_filename(self):
|
| + return True
|
| +
|
| + def dynamic_source_filename(self, filename, frame):
|
| + if frame.f_code.co_name != "render":
|
| + return None
|
| + source_filename = os.path.abspath(frame.f_locals['filename'])
|
| + return source_filename
|
| +
|
| + def line_number_range(self, frame):
|
| + lineno = frame.f_locals['linenum']
|
| + return lineno, lineno+1
|
| +
|
| +
|
| +class FileReporter(coverage.FileReporter):
|
| + """A goofy file reporter."""
|
| + def lines(self):
|
| + # Goofy test arrangement: claim that the file has as many lines as the
|
| + # number in its name.
|
| + num = os.path.basename(self.filename).split(".")[0].split("_")[1]
|
| + return set(range(1, int(num)+1))
|
| +
|
| +
|
| +def coverage_init(reg, options): # pylint: disable=unused-argument
|
| + """Called by coverage to initialize the plugins here."""
|
| + reg.add_file_tracer(Plugin())
|
|
|