Покрытие кода отладочным сервером django - PullRequest
3 голосов
/ 07 августа 2011

Я использую cover.py из http://nedbatchelder.com/code/coverage/ для получения данных покрытия для моих юнит-тестов django, но я не могу понять, как я могу запустить покрытие на сервере отладки django.Я хотел бы запустить сервер django, используя:

coverage -x manage.py runserver 0.0.0.0:8080

, и при остановке этого сервера я должен получить данные покрытия, с помощью которых я могу сгенерировать отчет о покрытии.Но при выключении сервера с помощью CTRL-c я получаю предупреждение

^ CCoverage.py: данные не были собраны.

Я готов использовать любой другой инструментесли это невозможно с помощью этого сценария cover.py.

ОБНОВЛЕНИЕ:

С --noreload это работает, но я получаю следующую трассировку стека при генерации отчета о покрытии html:

traceback (most recent call last):
  File "/usr/local/bin/coverage", line 8, in <module>
    load_entry_point('coverage==3.5.1', 'console_scripts', 'coverage')()
  File "/usr/local/lib/python2.6/dist-packages/coverage/cmdline.py", line 657, in main
    status = CoverageScript().command_line(argv)
  File "/usr/local/lib/python2.6/dist-packages/coverage/cmdline.py", line 549, in command_line
    directory=options.directory, **report_args)
  File "/usr/local/lib/python2.6/dist-packages/coverage/control.py", line 599, in html_report
    reporter.report(morfs, config=self.config)
  File "/usr/local/lib/python2.6/dist-packages/coverage/html.py", line 83, in report
    self.report_files(self.html_file, morfs, config, config.html_dir)
  File "/usr/local/lib/python2.6/dist-packages/coverage/report.py", line 86, in report_files
    report_fn(cu, self.coverage._analyze(cu))
  File "/usr/local/lib/python2.6/dist-packages/coverage/html.py", line 198, in html_file
    self.write_html(html_path, html)
  File "/usr/local/lib/python2.6/dist-packages/coverage/html.py", line 103, in write_html
    write_encoded(fname, html, 'ascii', 'xmlcharrefreplace')
  File "/usr/local/lib/python2.6/dist-packages/coverage/backward.py", line 137, in write_encoded
    f.write(text.decode('utf8'))
  File "/usr/lib/python2.6/encodings/utf_8.py", line 16, in decode
    return codecs.utf_8_decode(input, errors, True)
UnicodeDecodeError: 'utf8' codec can't decode byte 0xdf in position 59130: invalid continuation byte

1 Ответ

3 голосов
/ 07 августа 2011

Хм, не уверен, что с этим делать. Когда я создаю новый проект Django, я получаю некоторую оценку покрытия:

$ django-admin.py startproject mysite
$ cd mysite
$ coverage run manage.py runserver
Validating models...

0 errors found
Django version 1.3, using settings 'mysite.settings'
Development server is running at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.
^C
$ coverage report
Name       Stmts   Miss  Cover
------------------------------
__init__       0      0   100%
manage        11      4    64%
settings      24      0   100%
------------------------------
TOTAL         35      4    89%

Какие версии ОС, Django и покрытия и т. Д.? Что-нибудь еще необычное в вашем проекте?

Измерение runserver само по себе может быть не тем, что вам нужно, вы можете только измерять код, который отслеживает изменения файлов и перезапускает сервер. Испытатель Django с поддержкой покрытия может лучше удовлетворить ваши потребности.

UPDATE:

Если параметр --noreload используется для покрытия всего вашего кода.

...