Coverage.misc.NoSource: Нет источника для кода: '/usr/src/server/rep-1>'
Я использую пакет coverage уже довольно давно, и он хорошо функционировал до вчерашнего дня, пока не произошел сбой на уровне генерации отчета, как я полагаю. Не было никаких изменений в функциональности, что гораздо более странно.
У меня есть следующий файл coveragerc:
[run]
source = .
branch = True
concurrency = multiprocessing
omit =
manage.py
config/asgi.py
config/wsgi.py
config/settings.py
*/migrations/*
*test*
[report]
show_missing = True
skip_covered = True
и файл Django manage.py выглядит следующим образом:
import os
import sys
COVERAGE_ACCCEPTANCE = 85
def main():
argv = sys.argv
try:
command = argv[1]
except IndexError:
command = "help"
default_settings = "config.settings"
running_tests = (command == "test")
if running_tests:
default_settings = "config.settings_test"
from coverage import Coverage
cov = Coverage()
cov.erase()
cov.start()
os.environ.setdefault("DJANGO_SETTINGS_MODULE", default_settings)
try:
from django.core.management import execute_from_command_line
except ImportError as exc:
raise ImportError(
"Couldn't import Django. Are you sure it's installed and "
"available on your PYTHONPATH environment variable? Did you "
"forget to activate a virtual environment?",
) from exc
execute_from_command_line(argv)
if running_tests:
cov.stop()
cov.save()
cov.combine()
if round(cov.report()) < COVERAGE_ACCCEPTANCE:
sys.exit(1)
cov.erase()
if __name__ == "__main__":
main()
После успешного выполнения тестов покрытие выдает следующую ошибку:
Ran 317 tests in 96.790s
OK
Destroying test database for alias 'default'...
Traceback (most recent call last):
File "./serverX/manage.py", line 44, in <module>
main()
File "./serverX/manage.py", line 38, in main
if round(cov.report()) < COVERAGE_ACCCEPTANCE:
File "/usr/local/lib/python3.8/site-packages/coverage/control.py", line 913, in report
return reporter.report(morfs, outfile=file)
File "/usr/local/lib/python3.8/site-packages/coverage/summary.py", line 45, in report
for fr, analysis in get_analysis_to_report(self.coverage, morfs):
File "/usr/local/lib/python3.8/site-packages/coverage/report.py", line 70, in get_analysis_to_report
analysis = coverage._analyze(fr)
File "/usr/local/lib/python3.8/site-packages/coverage/control.py", line 808, in _analyze
return Analysis(data, it, self._file_mapper)
File "/usr/local/lib/python3.8/site-packages/coverage/results.py", line 20, in __init__
self.statements = self.file_reporter.lines()
File "/usr/local/lib/python3.8/site-packages/coverage/python.py", line 191, in lines
return self.parser.statements
File "/usr/local/lib/python3.8/site-packages/coverage/python.py", line 182, in parser
self._parser = PythonParser(
File "/usr/local/lib/python3.8/site-packages/coverage/parser.py", line 44, in __init__
self.text = get_python_source(self.filename)
File "/usr/local/lib/python3.8/site-packages/coverage/python.py", line 61, in get_python_source
raise NoSource(exc_msg)
coverage.misc.NoSource: No source for code: '/usr/src/server/rep-1>'.
Aborting report output, consider using -i.
1
Cleaning up project directory and file based variables 00:01
ERROR: Job failed: exit code 1
Я думаю, что, возможно, файл, который, как он говорит, не найден (/usr/src/server/rep-1), является сгенерированным отчетом, поскольку у меня нет таких файлов в моем репозитории. Я буду очень признателен за любое понимание, поскольку это было немного странно, и я не смог найти ничего похожего на этот случай в документации или в проблемах пакета на GitHub/ stackoverflow.
Я работаю на Django 3.1 с покрытием 5.5 на GitLab pipelines.
Я нашел первопричину в том, что библиотека attrs==21.3.0
была опубликована сегодня. Если я использую версию 21.2.0
, то coverage report
не дает сбоя из-за отсутствующих файлов представления.
Смотрите https://github.com/pytest-dev/pytest/discussions/9459