* chore: remove _decorate_all_methods_and_functions_with_type_checker No one understands this runtime magic anymore. * build: Bump coverage.py to latest * test: Skip github in coverage reporting * test: Print traceback from all threads when test is stuck * ci: Enable coverage in server side tests * ci: Always enable coverage It's cheap in recent python versions, our reasons for selectively disabling aren't valid anymore. * ci: Disable stderr capturing * ci: Use default buffer behaviour in unittest runner * ci(coverage): Set concurrency to multiprocessing We do use multiprocessing, perhaps the patches aren't concurrectly handled? * ci(coverage): Try parallel run * fix: Apply subprocess patch * ci: Don't start web server with coverage Causes deadlock for some reason. We don't actually report it either. * ci: only submit UI coverage if ran * test: remove aggresive stuck test checking * ci: disable UI coverage (for now)
96 lines
2 KiB
Python
96 lines
2 KiB
Python
# Copyright (c) 2021, Frappe Technologies Pvt. Ltd. and Contributors
|
|
# MIT License. See LICENSE
|
|
"""
|
|
frappe.coverage
|
|
~~~~~~~~~~~~~~~~
|
|
|
|
Coverage settings for frappe
|
|
"""
|
|
|
|
STANDARD_INCLUSIONS = ["*.py"]
|
|
|
|
STANDARD_EXCLUSIONS = [
|
|
"*.js",
|
|
"*.xml",
|
|
"*.pyc",
|
|
"*.css",
|
|
"*.less",
|
|
"*.scss",
|
|
"*.vue",
|
|
"*.html",
|
|
"*/test_*/*",
|
|
"*/node_modules/*",
|
|
"*/doctype/*/*_dashboard.py",
|
|
"*/patches/*",
|
|
"*/.github/*",
|
|
]
|
|
|
|
# tested via commands' test suite
|
|
TESTED_VIA_CLI = [
|
|
"*/frappe/installer.py",
|
|
"*/frappe/utils/install.py",
|
|
"*/frappe/utils/scheduler.py",
|
|
"*/frappe/utils/doctor.py",
|
|
"*/frappe/build.py",
|
|
"*/frappe/database/__init__.py",
|
|
"*/frappe/database/db_manager.py",
|
|
"*/frappe/database/**/setup_db.py",
|
|
]
|
|
|
|
FRAPPE_EXCLUSIONS = [
|
|
"*/tests/*",
|
|
"*/commands/*",
|
|
"*/frappe/change_log/*",
|
|
"*/frappe/exceptions*",
|
|
"*/frappe/desk/page/setup_wizard/setup_wizard.py",
|
|
"*/frappe/coverage.py",
|
|
"*frappe/setup.py",
|
|
"*/doctype/*/*_dashboard.py",
|
|
"*/patches/*",
|
|
*TESTED_VIA_CLI,
|
|
]
|
|
|
|
|
|
class CodeCoverage:
|
|
"""
|
|
Context manager for handling code coverage.
|
|
|
|
This class sets up code coverage measurement for a specific app,
|
|
applying the appropriate inclusion and exclusion patterns.
|
|
"""
|
|
|
|
def __init__(self, with_coverage, app, outfile="coverage.xml"):
|
|
self.with_coverage = with_coverage
|
|
self.app = app or "frappe"
|
|
self.outfile = outfile
|
|
|
|
def __enter__(self):
|
|
if self.with_coverage:
|
|
import os
|
|
|
|
from coverage import Coverage
|
|
|
|
from frappe.utils import get_bench_path
|
|
|
|
# Generate coverage report only for app that is being tested
|
|
source_path = os.path.join(get_bench_path(), "apps", self.app)
|
|
omit = STANDARD_EXCLUSIONS[:]
|
|
|
|
if self.app == "frappe":
|
|
omit.extend(FRAPPE_EXCLUSIONS)
|
|
|
|
self.coverage = Coverage(
|
|
source=[source_path],
|
|
omit=omit,
|
|
include=STANDARD_INCLUSIONS,
|
|
data_suffix=True,
|
|
)
|
|
self.coverage.start()
|
|
return self
|
|
|
|
def __exit__(self, exc_type, exc_value, traceback):
|
|
if self.with_coverage:
|
|
self.coverage.stop()
|
|
self.coverage.save()
|
|
self.coverage.xml_report(outfile=self.outfile)
|
|
print("Saved Coverage")
|