mirror of
https://github.com/PyCQA/flake8.git
synced 2026-04-12 15:44:17 +00:00
Add integration tests for aggregate_options
This commit is contained in:
parent
2cba89c568
commit
17a7826dc7
1 changed files with 48 additions and 0 deletions
48
tests/integration/test_aggregator.py
Normal file
48
tests/integration/test_aggregator.py
Normal file
|
|
@ -0,0 +1,48 @@
|
||||||
|
"""Test aggregation of config files and command-line options."""
|
||||||
|
import os
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
from flake8.main import cli
|
||||||
|
from flake8.options import aggregator
|
||||||
|
from flake8.options import manager
|
||||||
|
|
||||||
|
CLI_SPECIFIED_CONFIG = 'tests/fixtures/config_files/cli-specified.ini'
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def optmanager():
|
||||||
|
"""Create a new OptionManager."""
|
||||||
|
option_manager = manager.OptionManager(
|
||||||
|
prog='flake8',
|
||||||
|
version='3.0.0',
|
||||||
|
)
|
||||||
|
cli.register_default_options(option_manager)
|
||||||
|
return option_manager
|
||||||
|
|
||||||
|
|
||||||
|
def test_aggregate_options_with_config(optmanager):
|
||||||
|
"""Verify we aggregate options and config values appropriately."""
|
||||||
|
arguments = ['flake8', '--config', CLI_SPECIFIED_CONFIG, '--select',
|
||||||
|
'E11,E34,E402,W,F', '--exclude', 'tests/*']
|
||||||
|
options, args = aggregator.aggregate_options(optmanager, arguments)
|
||||||
|
|
||||||
|
assert options.config == CLI_SPECIFIED_CONFIG
|
||||||
|
assert options.select == ['E11', 'E34', 'E402', 'W', 'F']
|
||||||
|
assert options.ignore == ['E123', 'W234', 'E111']
|
||||||
|
assert options.exclude == [os.path.abspath('tests/*')]
|
||||||
|
|
||||||
|
|
||||||
|
def test_aggregate_options_when_isolated(optmanager):
|
||||||
|
"""Verify we aggregate options and config values appropriately."""
|
||||||
|
arguments = ['flake8', '--isolated', '--select', 'E11,E34,E402,W,F',
|
||||||
|
'--exclude', 'tests/*']
|
||||||
|
optmanager.extend_default_ignore(['E8'])
|
||||||
|
options, args = aggregator.aggregate_options(optmanager, arguments)
|
||||||
|
|
||||||
|
assert options.isolated is True
|
||||||
|
assert options.select == ['E11', 'E34', 'E402', 'W', 'F']
|
||||||
|
assert sorted(options.ignore) == [
|
||||||
|
'E121', 'E123', 'E126', 'E226', 'E24', 'E704', 'E8',
|
||||||
|
]
|
||||||
|
assert options.exclude == [os.path.abspath('tests/*')]
|
||||||
Loading…
Add table
Add a link
Reference in a new issue