web-dev-qa-db-ja.com

pythonカバレッジが仮想環境サイトパッケージを含めることを防ぐ

私は取材に不慣れで、奇妙な問題に遭遇しました。私のカバレッジは、私の仮想環境サイトパッケージを考慮に入れています。これは、カバレッジ実行の出力です。

coverage run test.py
....................
----------------------------------------------------------------------
Ran 20 tests in 0.060s

OK
(atcatalog)- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -jmfrank63@fullstack-audio-text-catalog:~/workspace (git master)       [19:58:45]
$ coverage report
Name                                                                              Stmts   Miss  Cover
-----------------------------------------------------------------------------------------------------
/home/ubuntu/Envs/atcatalog/lib/python2.7/site-packages/flask/__init__               18      0   100%
/home/ubuntu/Envs/atcatalog/lib/python2.7/site-packages/flask/_compat                38     20    47%
/home/ubuntu/Envs/atcatalog/lib/python2.7/site-packages/flask/app                   528    255    52%
/home/ubuntu/Envs/atcatalog/lib/python2.7/site-packages/flask/blueprints            156    118    24%
                             .
                             .
                             .
/home/ubuntu/Envs/atcatalog/lib/python2.7/site-packages/werkzeug/urls               412    215    48%
/home/ubuntu/Envs/atcatalog/lib/python2.7/site-packages/werkzeug/utils              242    175    28%
/home/ubuntu/Envs/atcatalog/lib/python2.7/site-packages/werkzeug/wrappers           568    298    48%
/home/ubuntu/Envs/atcatalog/lib/python2.7/site-packages/werkzeug/wsgi               448    352    21%
atcatalog/__init__                                                                    7      0   100%
atcatalog/views/__init__                                                              0      0   100%
atcatalog/views/publang                                                               7      0   100%
atcatalog/views/pubtext                                                               1      0   100%
atcatalog/views/userlang                                                             13      0   100%
atcatalog/views/users                                                                 5      0   100%
atcatalog/views/usertext                                                             14      0   100%
test                                                                                120      0   100%
-----------------------------------------------------------------------------------------------------
TOTAL                                                                             12530   8044    36%
(atcatalog)- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -jmfrank63@fullstack-audio-text-catalog:~/workspace (git master)       [19:58:55]

ホームの下にある私のプロジェクトディレクトリの構造は次のとおりです。

workspace/
├── README.md
├── atcatalog
│   ├── __init__.py
│   ├── __init__.pyc
│   ├── static
│   ├── templates
│   └── views
│       ├── __init__.py
│       ├── __init__.pyc
│       ├── publang.py
│       ├── publang.pyc
│       ├── pubtext.py
│       ├── pubtext.pyc
│       ├── userlang.py
│       ├── userlang.pyc
│       ├── users.py
│       ├── users.pyc
│       ├── usertext.py
│       └── usertext.pyc
├── requirements.txt
├── run.py
└── test.py

最初はプロジェクトディレクトリ内に仮想環境があり、それをvirtualenvwrapperを使用して〜/ Envsに移動しましたが、問題は解決しませんでした。 run.pyとtest.pyは特別なものではなく、どちらもatcatalogからアプリをインポートします。私は仮想環境ディレクトリを省略する方法も見つけようとしましたが、グーグルは答えを返しませんでした(驚くほど)。十分にテストされたサイトパッケージをテストすることがカバレッジの目的ではないと思います。だから私はそれらを実行から除外します。

カバレッジを回避してサイトパッケージをテストするにはどうすればよいですか?

39

おかげで tknickman わかりました:どちらかを使用

coverage run --source <path to project dir> test.py

または、次の内容で、カバレッジを実行するディレクトリにある設定ファイル.coveragercを作成します。

[run]
source =
    <path to project dir>

これにより、プロジェクトディレクトリの下に仮想環境がインストールされなくなります。あなたが使用できるプロジェクトディレクトリの下に仮想環境がインストールされている場合

coverage run --source <project path> --omit <pattern> test.py

省略すると、次のようなファイルパターンが必要になることに注意してください。

~/projectdir/venv/*

パスの代わりに。

対応する.coveragercは次のようになります。

[run]
source=
    <path to project dir>
omit=
    <path to project dir>/<name of virtual env>/*

標準ライブラリのパッケージのように、site-packagesの下にインストールされたパッケージはデフォルトではカバーされるべきではないと私はまだ思います。

48

py.test を使用して、setup.cfgファイルでテストオプションを指定してみてください。まず、pytest install pytestを実行する必要があります。

例えば:

[pytest]
norecursedirs = build docs/_build *.Egg .tox *.venv
python_files = tests/functional* tests/integration*
addopts =
    #--verbose
    --tb short
    # Turn on --capture to have brief, less noisy output
    # You will only see output if the test fails
    # Use --capture no if you want to see it all or have problems debugging
    --capture fd
    # --capture no
    # show extra test summary info as specified by chars (f)ailed, (E)error,      (s)skipped, (x)failed, (X)passed.
    - rfEsxX
    --junitxml junit.xml
    --cov workspace --cov-report xml --cov-report term-missing

ここでpy.testの構成についての詳細を読むことができます: https://pytest.org/latest/customize.html

5
tknickman

Pytestを使用している場合、setup.cfgでテストする排他的なパスまたはファイルを指定できます( ドキュメントを参照 ):

[pytest]
# a directory
testpaths = tests

# exact file(s)
python_files = tests/test1.py tests/test2.py

python_filesパラメータとtestpathsパラメータを含めた場合、python_filesのみが使用されます。

0
Evan Siroky