Jon*_*han 5 python coverage.py flask
我正在努力让coverage.py与我的Flask应用程序一起工作.
我试图通过子进程指令进行设置:http://nedbatchelder.com/code/coverage/subprocess.html
在我的create_app()函数(这是一个应用程序工厂)中,我有以下内容:
if settings.FLASK_ENV == 'TEST':
coverage.process_startup()
Run Code Online (Sandbox Code Playgroud)
在我的测试套件中,我有以下内容:
# Need to add the 'COVERAGE_PROCESS_START' environment variable for subprocesses
if os.getenv('COVERAGE'):
test_env['COVERAGE_PROCESS_START'] = 'tests/.coveragerc'
test_env['FLASK_ENV'] = 'TEST'
test_process = subprocess.Popen(["gunicorn", "run_server:app", '--log-level=warning', '-w 1', '-b {host}:{port}'.format(host='127.0.0.1',port=port())],
env=test_env)
Run Code Online (Sandbox Code Playgroud)
在我的测试结束时,我做...
coverage.save()
coverage.combine()
percent_covered = coverage.html_report(directory='covhtml')
print "Percent Covered: {}".format(percent_covered)
coverage.stop()
Run Code Online (Sandbox Code Playgroud)
但是唉......报道报道似乎并没有结合起来
注意:在调用combine之前,如果我ls -alt在目录中看到这样的列表...
-rw-r--r-- .coverage.Jonathans-MacBook-Pro-3.local.49352.501916
-rw-r--r-- .coverage.Jonathans-MacBook-Pro-3.local.49352.931352
为了完整,我的.coveragerc简单地说:
[run]
parallel = True
会喜欢正确的方向 - 谢谢!
得到它的工作 - 感谢@NedBat 的一些指导。
问题在于,gunicorn 正在产生额外的子进程——以及那些不受监控的子进程。
为了解决这个问题,我需要利用站点模块的 sitepackage.py 功能。完全公平地记录了http://nedbatchelder.com/code/coverage/subprocess.html——但我只是做错了。
您需要创建该sitepackage.py文件并将其放入您的site-packages文件夹中。然后,在环境中运行的任何进程(或子进程)都将在启动进程之前执行该文件。
| 归档时间: |
|
| 查看次数: |
3074 次 |
| 最近记录: |