busser-behave 0.1.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.cane +0 -0
- data/.gitignore +17 -0
- data/.tailor +4 -0
- data/.travis.yml +11 -0
- data/CHANGELOG.md +3 -0
- data/Gemfile +3 -0
- data/LICENSE +15 -0
- data/README.md +41 -0
- data/Rakefile +68 -0
- data/busser-behave.gemspec +30 -0
- data/features/plugin_install_command.feature +11 -0
- data/features/plugin_list_command.feature +8 -0
- data/features/support/env.rb +13 -0
- data/features/test_command.feature +31 -0
- data/lib/busser/behave/version.rb +26 -0
- data/lib/busser/runner_plugin/behave.rb +37 -0
- data/vendor/behave/CHANGES.rst +483 -0
- data/vendor/behave/LICENSE +23 -0
- data/vendor/behave/MANIFEST.in +37 -0
- data/vendor/behave/PROJECT_INFO.rst +21 -0
- data/vendor/behave/README.rst +112 -0
- data/vendor/behave/VERSION.txt +1 -0
- data/vendor/behave/behave.ini +22 -0
- data/vendor/behave/behave/__init__.py +30 -0
- data/vendor/behave/behave/__main__.py +187 -0
- data/vendor/behave/behave/_stepimport.py +185 -0
- data/vendor/behave/behave/_types.py +134 -0
- data/vendor/behave/behave/api/__init__.py +7 -0
- data/vendor/behave/behave/api/async_step.py +283 -0
- data/vendor/behave/behave/capture.py +227 -0
- data/vendor/behave/behave/compat/__init__.py +5 -0
- data/vendor/behave/behave/compat/collections.py +20 -0
- data/vendor/behave/behave/configuration.py +788 -0
- data/vendor/behave/behave/contrib/__init__.py +0 -0
- data/vendor/behave/behave/contrib/scenario_autoretry.py +73 -0
- data/vendor/behave/behave/formatter/__init__.py +12 -0
- data/vendor/behave/behave/formatter/_builtins.py +39 -0
- data/vendor/behave/behave/formatter/_registry.py +135 -0
- data/vendor/behave/behave/formatter/ansi_escapes.py +91 -0
- data/vendor/behave/behave/formatter/base.py +200 -0
- data/vendor/behave/behave/formatter/formatters.py +57 -0
- data/vendor/behave/behave/formatter/json.py +253 -0
- data/vendor/behave/behave/formatter/null.py +12 -0
- data/vendor/behave/behave/formatter/plain.py +158 -0
- data/vendor/behave/behave/formatter/pretty.py +351 -0
- data/vendor/behave/behave/formatter/progress.py +287 -0
- data/vendor/behave/behave/formatter/rerun.py +114 -0
- data/vendor/behave/behave/formatter/sphinx_steps.py +372 -0
- data/vendor/behave/behave/formatter/sphinx_util.py +118 -0
- data/vendor/behave/behave/formatter/steps.py +497 -0
- data/vendor/behave/behave/formatter/tags.py +178 -0
- data/vendor/behave/behave/i18n.py +614 -0
- data/vendor/behave/behave/importer.py +102 -0
- data/vendor/behave/behave/json_parser.py +264 -0
- data/vendor/behave/behave/log_capture.py +233 -0
- data/vendor/behave/behave/matchers.py +402 -0
- data/vendor/behave/behave/model.py +1737 -0
- data/vendor/behave/behave/model_core.py +416 -0
- data/vendor/behave/behave/model_describe.py +105 -0
- data/vendor/behave/behave/parser.py +615 -0
- data/vendor/behave/behave/reporter/__init__.py +0 -0
- data/vendor/behave/behave/reporter/base.py +45 -0
- data/vendor/behave/behave/reporter/junit.py +473 -0
- data/vendor/behave/behave/reporter/summary.py +94 -0
- data/vendor/behave/behave/runner.py +753 -0
- data/vendor/behave/behave/runner_util.py +417 -0
- data/vendor/behave/behave/step_registry.py +112 -0
- data/vendor/behave/behave/tag_expression.py +111 -0
- data/vendor/behave/behave/tag_matcher.py +465 -0
- data/vendor/behave/behave/textutil.py +137 -0
- data/vendor/behave/behave/userdata.py +130 -0
- data/vendor/behave/behave4cmd0/__all_steps__.py +12 -0
- data/vendor/behave/behave4cmd0/__init__.py +5 -0
- data/vendor/behave/behave4cmd0/__setup.py +11 -0
- data/vendor/behave/behave4cmd0/command_shell.py +216 -0
- data/vendor/behave/behave4cmd0/command_shell_proc.py +256 -0
- data/vendor/behave/behave4cmd0/command_steps.py +532 -0
- data/vendor/behave/behave4cmd0/command_util.py +147 -0
- data/vendor/behave/behave4cmd0/failing_steps.py +49 -0
- data/vendor/behave/behave4cmd0/log/__init__.py +1 -0
- data/vendor/behave/behave4cmd0/log/steps.py +395 -0
- data/vendor/behave/behave4cmd0/note_steps.py +29 -0
- data/vendor/behave/behave4cmd0/passing_steps.py +36 -0
- data/vendor/behave/behave4cmd0/pathutil.py +146 -0
- data/vendor/behave/behave4cmd0/setup_command_shell.py +24 -0
- data/vendor/behave/behave4cmd0/textutil.py +304 -0
- data/vendor/behave/bin/behave +44 -0
- data/vendor/behave/bin/behave.cmd +10 -0
- data/vendor/behave/bin/behave.junit_filter.py +85 -0
- data/vendor/behave/bin/behave.step_durations.py +163 -0
- data/vendor/behave/bin/behave2cucumber_json.py +63 -0
- data/vendor/behave/bin/behave_cmd.py +44 -0
- data/vendor/behave/bin/convert_i18n_yaml.py +77 -0
- data/vendor/behave/bin/explore_platform_encoding.py +24 -0
- data/vendor/behave/bin/i18n.yml +621 -0
- data/vendor/behave/bin/invoke +8 -0
- data/vendor/behave/bin/invoke.cmd +9 -0
- data/vendor/behave/bin/json.format.py +167 -0
- data/vendor/behave/bin/jsonschema_validate.py +122 -0
- data/vendor/behave/bin/make_localpi.py +279 -0
- data/vendor/behave/bin/project_bootstrap.sh +30 -0
- data/vendor/behave/bin/toxcmd.py +270 -0
- data/vendor/behave/bin/toxcmd3.py +270 -0
- data/vendor/behave/conftest.py +27 -0
- data/vendor/behave/docs/Makefile +154 -0
- data/vendor/behave/docs/_static/agogo.css +501 -0
- data/vendor/behave/docs/_static/behave_logo.png +0 -0
- data/vendor/behave/docs/_static/behave_logo1.png +0 -0
- data/vendor/behave/docs/_static/behave_logo2.png +0 -0
- data/vendor/behave/docs/_static/behave_logo3.png +0 -0
- data/vendor/behave/docs/_themes/LICENSE +45 -0
- data/vendor/behave/docs/_themes/kr/layout.html +17 -0
- data/vendor/behave/docs/_themes/kr/relations.html +19 -0
- data/vendor/behave/docs/_themes/kr/static/flasky.css_t +480 -0
- data/vendor/behave/docs/_themes/kr/static/small_flask.css +90 -0
- data/vendor/behave/docs/_themes/kr/theme.conf +7 -0
- data/vendor/behave/docs/_themes/kr_small/layout.html +22 -0
- data/vendor/behave/docs/_themes/kr_small/static/flasky.css_t +287 -0
- data/vendor/behave/docs/_themes/kr_small/theme.conf +10 -0
- data/vendor/behave/docs/api.rst +408 -0
- data/vendor/behave/docs/appendix.rst +19 -0
- data/vendor/behave/docs/behave.rst +640 -0
- data/vendor/behave/docs/behave.rst-template +86 -0
- data/vendor/behave/docs/behave_ecosystem.rst +81 -0
- data/vendor/behave/docs/comparison.rst +85 -0
- data/vendor/behave/docs/conf.py +293 -0
- data/vendor/behave/docs/context_attributes.rst +66 -0
- data/vendor/behave/docs/django.rst +192 -0
- data/vendor/behave/docs/formatters.rst +61 -0
- data/vendor/behave/docs/gherkin.rst +673 -0
- data/vendor/behave/docs/index.rst +57 -0
- data/vendor/behave/docs/install.rst +60 -0
- data/vendor/behave/docs/more_info.rst +184 -0
- data/vendor/behave/docs/new_and_noteworthy.rst +18 -0
- data/vendor/behave/docs/new_and_noteworthy_v1.2.4.rst +11 -0
- data/vendor/behave/docs/new_and_noteworthy_v1.2.5.rst +814 -0
- data/vendor/behave/docs/new_and_noteworthy_v1.2.6.rst +255 -0
- data/vendor/behave/docs/parse_builtin_types.rst +59 -0
- data/vendor/behave/docs/philosophy.rst +235 -0
- data/vendor/behave/docs/regular_expressions.rst +71 -0
- data/vendor/behave/docs/related.rst +14 -0
- data/vendor/behave/docs/test_domains.rst +62 -0
- data/vendor/behave/docs/tutorial.rst +636 -0
- data/vendor/behave/docs/update_behave_rst.py +100 -0
- data/vendor/behave/etc/json/behave.json-schema +172 -0
- data/vendor/behave/etc/junit.xml/behave_junit.xsd +103 -0
- data/vendor/behave/etc/junit.xml/junit-4.xsd +92 -0
- data/vendor/behave/examples/async_step/README.txt +8 -0
- data/vendor/behave/examples/async_step/behave.ini +14 -0
- data/vendor/behave/examples/async_step/features/async_dispatch.feature +8 -0
- data/vendor/behave/examples/async_step/features/async_run.feature +6 -0
- data/vendor/behave/examples/async_step/features/environment.py +28 -0
- data/vendor/behave/examples/async_step/features/steps/async_dispatch_steps.py +26 -0
- data/vendor/behave/examples/async_step/features/steps/async_steps34.py +10 -0
- data/vendor/behave/examples/async_step/features/steps/async_steps35.py +10 -0
- data/vendor/behave/examples/async_step/testrun_example.async_dispatch.txt +11 -0
- data/vendor/behave/examples/async_step/testrun_example.async_run.txt +9 -0
- data/vendor/behave/examples/env_vars/README.rst +26 -0
- data/vendor/behave/examples/env_vars/behave.ini +15 -0
- data/vendor/behave/examples/env_vars/behave_run.output_example.txt +12 -0
- data/vendor/behave/examples/env_vars/features/env_var.feature +6 -0
- data/vendor/behave/examples/env_vars/features/steps/env_var_steps.py +38 -0
- data/vendor/behave/features/README.txt +12 -0
- data/vendor/behave/features/background.feature +392 -0
- data/vendor/behave/features/capture_stderr.feature +172 -0
- data/vendor/behave/features/capture_stdout.feature +125 -0
- data/vendor/behave/features/cmdline.lang_list.feature +33 -0
- data/vendor/behave/features/configuration.default_paths.feature +116 -0
- data/vendor/behave/features/context.global_params.feature +35 -0
- data/vendor/behave/features/context.local_params.feature +17 -0
- data/vendor/behave/features/directory_layout.advanced.feature +147 -0
- data/vendor/behave/features/directory_layout.basic.feature +75 -0
- data/vendor/behave/features/directory_layout.basic2.feature +87 -0
- data/vendor/behave/features/environment.py +53 -0
- data/vendor/behave/features/exploratory_testing.with_table.feature +141 -0
- data/vendor/behave/features/feature.description.feature +0 -0
- data/vendor/behave/features/feature.exclude_from_run.feature +96 -0
- data/vendor/behave/features/formatter.help.feature +30 -0
- data/vendor/behave/features/formatter.json.feature +420 -0
- data/vendor/behave/features/formatter.progress3.feature +235 -0
- data/vendor/behave/features/formatter.rerun.feature +296 -0
- data/vendor/behave/features/formatter.steps.feature +181 -0
- data/vendor/behave/features/formatter.steps_catalog.feature +100 -0
- data/vendor/behave/features/formatter.steps_doc.feature +140 -0
- data/vendor/behave/features/formatter.steps_usage.feature +404 -0
- data/vendor/behave/features/formatter.tags.feature +134 -0
- data/vendor/behave/features/formatter.tags_location.feature +183 -0
- data/vendor/behave/features/formatter.user_defined.feature +196 -0
- data/vendor/behave/features/i18n.unicode_problems.feature +445 -0
- data/vendor/behave/features/logcapture.clear_handlers.feature +114 -0
- data/vendor/behave/features/logcapture.feature +188 -0
- data/vendor/behave/features/logcapture.filter.feature +130 -0
- data/vendor/behave/features/logging.no_capture.feature +99 -0
- data/vendor/behave/features/logging.setup_format.feature +157 -0
- data/vendor/behave/features/logging.setup_level.feature +168 -0
- data/vendor/behave/features/logging.setup_with_configfile.feature +137 -0
- data/vendor/behave/features/parser.background.sad_cases.feature +129 -0
- data/vendor/behave/features/parser.feature.sad_cases.feature +144 -0
- data/vendor/behave/features/runner.abort_by_user.feature +305 -0
- data/vendor/behave/features/runner.continue_after_failed_step.feature +136 -0
- data/vendor/behave/features/runner.default_format.feature +175 -0
- data/vendor/behave/features/runner.dry_run.feature +184 -0
- data/vendor/behave/features/runner.feature_listfile.feature +223 -0
- data/vendor/behave/features/runner.hook_errors.feature +382 -0
- data/vendor/behave/features/runner.multiple_formatters.feature +285 -0
- data/vendor/behave/features/runner.scenario_autoretry.feature +131 -0
- data/vendor/behave/features/runner.select_files_by_regexp.example.feature +71 -0
- data/vendor/behave/features/runner.select_files_by_regexp.feature +84 -0
- data/vendor/behave/features/runner.select_scenarios_by_file_location.feature +403 -0
- data/vendor/behave/features/runner.select_scenarios_by_name.feature +289 -0
- data/vendor/behave/features/runner.select_scenarios_by_tag.feature +225 -0
- data/vendor/behave/features/runner.stop_after_failure.feature +122 -0
- data/vendor/behave/features/runner.tag_logic.feature +67 -0
- data/vendor/behave/features/runner.unknown_formatter.feature +23 -0
- data/vendor/behave/features/runner.use_stage_implementations.feature +126 -0
- data/vendor/behave/features/scenario.description.feature +171 -0
- data/vendor/behave/features/scenario.exclude_from_run.feature +217 -0
- data/vendor/behave/features/scenario_outline.basics.feature +100 -0
- data/vendor/behave/features/scenario_outline.improved.feature +177 -0
- data/vendor/behave/features/scenario_outline.name_annotation.feature +157 -0
- data/vendor/behave/features/scenario_outline.parametrized.feature +401 -0
- data/vendor/behave/features/scenario_outline.tagged_examples.feature +118 -0
- data/vendor/behave/features/step.async_steps.feature +225 -0
- data/vendor/behave/features/step.duplicated_step.feature +106 -0
- data/vendor/behave/features/step.execute_steps.feature +59 -0
- data/vendor/behave/features/step.execute_steps.with_table.feature +65 -0
- data/vendor/behave/features/step.import_other_step_module.feature +103 -0
- data/vendor/behave/features/step.pending_steps.feature +128 -0
- data/vendor/behave/features/step.undefined_steps.feature +307 -0
- data/vendor/behave/features/step.use_step_library.feature +44 -0
- data/vendor/behave/features/step_dialect.generic_steps.feature +189 -0
- data/vendor/behave/features/step_dialect.given_when_then.feature +89 -0
- data/vendor/behave/features/step_param.builtin_types.with_float.feature +239 -0
- data/vendor/behave/features/step_param.builtin_types.with_integer.feature +305 -0
- data/vendor/behave/features/step_param.custom_types.feature +134 -0
- data/vendor/behave/features/steps/behave_active_tags_steps.py +86 -0
- data/vendor/behave/features/steps/behave_context_steps.py +67 -0
- data/vendor/behave/features/steps/behave_model_tag_logic_steps.py +105 -0
- data/vendor/behave/features/steps/behave_model_util.py +105 -0
- data/vendor/behave/features/steps/behave_select_files_steps.py +83 -0
- data/vendor/behave/features/steps/behave_tag_expression_steps.py +166 -0
- data/vendor/behave/features/steps/behave_undefined_steps.py +101 -0
- data/vendor/behave/features/steps/use_steplib_behave4cmd.py +12 -0
- data/vendor/behave/features/summary.undefined_steps.feature +114 -0
- data/vendor/behave/features/tags.active_tags.feature +385 -0
- data/vendor/behave/features/tags.default_tags.feature +104 -0
- data/vendor/behave/features/tags.tag_expression.feature +105 -0
- data/vendor/behave/features/userdata.feature +331 -0
- data/vendor/behave/invoke.yaml +21 -0
- data/vendor/behave/issue.features/README.txt +17 -0
- data/vendor/behave/issue.features/environment.py +97 -0
- data/vendor/behave/issue.features/issue0030.feature +21 -0
- data/vendor/behave/issue.features/issue0031.feature +16 -0
- data/vendor/behave/issue.features/issue0032.feature +28 -0
- data/vendor/behave/issue.features/issue0035.feature +74 -0
- data/vendor/behave/issue.features/issue0040.feature +154 -0
- data/vendor/behave/issue.features/issue0041.feature +135 -0
- data/vendor/behave/issue.features/issue0042.feature +230 -0
- data/vendor/behave/issue.features/issue0044.feature +51 -0
- data/vendor/behave/issue.features/issue0046.feature +77 -0
- data/vendor/behave/issue.features/issue0052.feature +66 -0
- data/vendor/behave/issue.features/issue0059.feature +29 -0
- data/vendor/behave/issue.features/issue0063.feature +102 -0
- data/vendor/behave/issue.features/issue0064.feature +97 -0
- data/vendor/behave/issue.features/issue0065.feature +18 -0
- data/vendor/behave/issue.features/issue0066.feature +80 -0
- data/vendor/behave/issue.features/issue0067.feature +90 -0
- data/vendor/behave/issue.features/issue0069.feature +64 -0
- data/vendor/behave/issue.features/issue0072.feature +32 -0
- data/vendor/behave/issue.features/issue0073.feature +228 -0
- data/vendor/behave/issue.features/issue0075.feature +18 -0
- data/vendor/behave/issue.features/issue0077.feature +89 -0
- data/vendor/behave/issue.features/issue0080.feature +49 -0
- data/vendor/behave/issue.features/issue0081.feature +138 -0
- data/vendor/behave/issue.features/issue0083.feature +69 -0
- data/vendor/behave/issue.features/issue0084.feature +69 -0
- data/vendor/behave/issue.features/issue0085.feature +119 -0
- data/vendor/behave/issue.features/issue0092.feature +66 -0
- data/vendor/behave/issue.features/issue0096.feature +173 -0
- data/vendor/behave/issue.features/issue0099.feature +130 -0
- data/vendor/behave/issue.features/issue0109.feature +60 -0
- data/vendor/behave/issue.features/issue0111.feature +53 -0
- data/vendor/behave/issue.features/issue0112.feature +64 -0
- data/vendor/behave/issue.features/issue0114.feature +118 -0
- data/vendor/behave/issue.features/issue0116.feature +71 -0
- data/vendor/behave/issue.features/issue0125.feature +49 -0
- data/vendor/behave/issue.features/issue0127.feature +64 -0
- data/vendor/behave/issue.features/issue0139.feature +67 -0
- data/vendor/behave/issue.features/issue0142.feature +37 -0
- data/vendor/behave/issue.features/issue0143.feature +54 -0
- data/vendor/behave/issue.features/issue0145.feature +63 -0
- data/vendor/behave/issue.features/issue0148.feature +105 -0
- data/vendor/behave/issue.features/issue0152.feature +52 -0
- data/vendor/behave/issue.features/issue0159.feature +74 -0
- data/vendor/behave/issue.features/issue0162.feature +86 -0
- data/vendor/behave/issue.features/issue0171.feature +16 -0
- data/vendor/behave/issue.features/issue0172.feature +51 -0
- data/vendor/behave/issue.features/issue0175.feature +91 -0
- data/vendor/behave/issue.features/issue0177.feature +40 -0
- data/vendor/behave/issue.features/issue0181.feature +36 -0
- data/vendor/behave/issue.features/issue0184.feature +144 -0
- data/vendor/behave/issue.features/issue0186.feature +12 -0
- data/vendor/behave/issue.features/issue0188.feature +60 -0
- data/vendor/behave/issue.features/issue0191.feature +178 -0
- data/vendor/behave/issue.features/issue0194.feature +215 -0
- data/vendor/behave/issue.features/issue0197.feature +11 -0
- data/vendor/behave/issue.features/issue0216.feature +129 -0
- data/vendor/behave/issue.features/issue0226.feature +51 -0
- data/vendor/behave/issue.features/issue0228.feature +41 -0
- data/vendor/behave/issue.features/issue0230.feature +46 -0
- data/vendor/behave/issue.features/issue0231.feature +77 -0
- data/vendor/behave/issue.features/issue0238.feature +52 -0
- data/vendor/behave/issue.features/issue0251.feature +15 -0
- data/vendor/behave/issue.features/issue0280.feature +118 -0
- data/vendor/behave/issue.features/issue0288.feature +95 -0
- data/vendor/behave/issue.features/issue0300.feature +49 -0
- data/vendor/behave/issue.features/issue0302.feature +91 -0
- data/vendor/behave/issue.features/issue0309.feature +52 -0
- data/vendor/behave/issue.features/issue0330.feature +124 -0
- data/vendor/behave/issue.features/issue0349.feature +9 -0
- data/vendor/behave/issue.features/issue0361.feature +79 -0
- data/vendor/behave/issue.features/issue0383.feature +76 -0
- data/vendor/behave/issue.features/issue0384.feature +103 -0
- data/vendor/behave/issue.features/issue0385.feature +109 -0
- data/vendor/behave/issue.features/issue0424.feature +66 -0
- data/vendor/behave/issue.features/issue0446.feature +116 -0
- data/vendor/behave/issue.features/issue0449.feature +42 -0
- data/vendor/behave/issue.features/issue0453.feature +42 -0
- data/vendor/behave/issue.features/issue0457.feature +65 -0
- data/vendor/behave/issue.features/issue0462.feature +38 -0
- data/vendor/behave/issue.features/issue0476.feature +39 -0
- data/vendor/behave/issue.features/issue0487.feature +92 -0
- data/vendor/behave/issue.features/issue0506.feature +77 -0
- data/vendor/behave/issue.features/issue0510.feature +51 -0
- data/vendor/behave/issue.features/requirements.txt +12 -0
- data/vendor/behave/issue.features/steps/ansi_steps.py +20 -0
- data/vendor/behave/issue.features/steps/behave_hooks_steps.py +10 -0
- data/vendor/behave/issue.features/steps/use_steplib_behave4cmd.py +13 -0
- data/vendor/behave/more.features/formatter.json.validate_output.feature +37 -0
- data/vendor/behave/more.features/steps/tutorial_steps.py +16 -0
- data/vendor/behave/more.features/steps/use_steplib_behave4cmd.py +7 -0
- data/vendor/behave/more.features/tutorial.feature +6 -0
- data/vendor/behave/py.requirements/README.txt +5 -0
- data/vendor/behave/py.requirements/all.txt +16 -0
- data/vendor/behave/py.requirements/basic.txt +21 -0
- data/vendor/behave/py.requirements/develop.txt +28 -0
- data/vendor/behave/py.requirements/docs.txt +6 -0
- data/vendor/behave/py.requirements/json.txt +7 -0
- data/vendor/behave/py.requirements/more_py26.txt +8 -0
- data/vendor/behave/py.requirements/testing.txt +10 -0
- data/vendor/behave/pytest.ini +24 -0
- data/vendor/behave/setup.cfg +29 -0
- data/vendor/behave/setup.py +118 -0
- data/vendor/behave/setuptools_behave.py +130 -0
- data/vendor/behave/tasks/__behave.py +45 -0
- data/vendor/behave/tasks/__init__.py +55 -0
- data/vendor/behave/tasks/__main__.py +70 -0
- data/vendor/behave/tasks/_setup.py +135 -0
- data/vendor/behave/tasks/_vendor/README.rst +35 -0
- data/vendor/behave/tasks/_vendor/invoke.zip +0 -0
- data/vendor/behave/tasks/_vendor/path.py +1725 -0
- data/vendor/behave/tasks/_vendor/pathlib.py +1280 -0
- data/vendor/behave/tasks/_vendor/six.py +868 -0
- data/vendor/behave/tasks/clean.py +246 -0
- data/vendor/behave/tasks/docs.py +97 -0
- data/vendor/behave/tasks/requirements.txt +17 -0
- data/vendor/behave/tasks/test.py +192 -0
- data/vendor/behave/test/__init__.py +0 -0
- data/vendor/behave/test/_importer_candidate.py +3 -0
- data/vendor/behave/test/reporters/__init__.py +0 -0
- data/vendor/behave/test/reporters/test_summary.py +240 -0
- data/vendor/behave/test/test_ansi_escapes.py +73 -0
- data/vendor/behave/test/test_configuration.py +172 -0
- data/vendor/behave/test/test_formatter.py +265 -0
- data/vendor/behave/test/test_formatter_progress.py +39 -0
- data/vendor/behave/test/test_formatter_rerun.py +97 -0
- data/vendor/behave/test/test_formatter_tags.py +57 -0
- data/vendor/behave/test/test_importer.py +151 -0
- data/vendor/behave/test/test_log_capture.py +29 -0
- data/vendor/behave/test/test_matchers.py +236 -0
- data/vendor/behave/test/test_model.py +871 -0
- data/vendor/behave/test/test_parser.py +1590 -0
- data/vendor/behave/test/test_runner.py +1074 -0
- data/vendor/behave/test/test_step_registry.py +96 -0
- data/vendor/behave/test/test_tag_expression.py +506 -0
- data/vendor/behave/test/test_tag_expression2.py +462 -0
- data/vendor/behave/test/test_tag_matcher.py +729 -0
- data/vendor/behave/test/test_userdata.py +184 -0
- data/vendor/behave/tests/README.txt +12 -0
- data/vendor/behave/tests/__init__.py +0 -0
- data/vendor/behave/tests/api/__ONLY_PY34_or_newer.txt +0 -0
- data/vendor/behave/tests/api/__init__.py +0 -0
- data/vendor/behave/tests/api/_test_async_step34.py +130 -0
- data/vendor/behave/tests/api/_test_async_step35.py +75 -0
- data/vendor/behave/tests/api/test_async_step.py +18 -0
- data/vendor/behave/tests/api/testing_support.py +94 -0
- data/vendor/behave/tests/api/testing_support_async.py +21 -0
- data/vendor/behave/tests/issues/test_issue0336.py +66 -0
- data/vendor/behave/tests/issues/test_issue0449.py +55 -0
- data/vendor/behave/tests/issues/test_issue0453.py +62 -0
- data/vendor/behave/tests/issues/test_issue0458.py +54 -0
- data/vendor/behave/tests/issues/test_issue0495.py +65 -0
- data/vendor/behave/tests/unit/__init__.py +0 -0
- data/vendor/behave/tests/unit/test_behave4cmd_command_shell_proc.py +135 -0
- data/vendor/behave/tests/unit/test_capture.py +280 -0
- data/vendor/behave/tests/unit/test_model_core.py +56 -0
- data/vendor/behave/tests/unit/test_textutil.py +267 -0
- data/vendor/behave/tools/test-features/background.feature +9 -0
- data/vendor/behave/tools/test-features/environment.py +8 -0
- data/vendor/behave/tools/test-features/french.feature +11 -0
- data/vendor/behave/tools/test-features/outline.feature +39 -0
- data/vendor/behave/tools/test-features/parse.feature +10 -0
- data/vendor/behave/tools/test-features/step-data.feature +60 -0
- data/vendor/behave/tools/test-features/steps/steps.py +120 -0
- data/vendor/behave/tools/test-features/tags.feature +18 -0
- data/vendor/behave/tox.ini +159 -0
- metadata +562 -0
@@ -0,0 +1,20 @@
|
|
1
|
+
# -*- coding: utf-8 -*-
|
2
|
+
"""
|
3
|
+
Compatibility of :module:`collections` between different Python versions.
|
4
|
+
"""
|
5
|
+
|
6
|
+
from __future__ import absolute_import
|
7
|
+
import warnings
|
8
|
+
# pylint: disable=unused-import
|
9
|
+
try:
|
10
|
+
# -- SINCE: Python2.7
|
11
|
+
from collections import OrderedDict
|
12
|
+
except ImportError: # pragma: no cover
|
13
|
+
try:
|
14
|
+
# -- BACK-PORTED FOR: Python 2.4 .. 2.6
|
15
|
+
from ordereddict import OrderedDict
|
16
|
+
except ImportError:
|
17
|
+
message = "collections.OrderedDict is missing: Install 'ordereddict'."
|
18
|
+
warnings.warn(message)
|
19
|
+
# -- BACKWARD-COMPATIBLE: Better than nothing (for behave use case).
|
20
|
+
OrderedDict = dict
|
@@ -0,0 +1,788 @@
|
|
1
|
+
# -*- coding: utf-8 -*-
|
2
|
+
|
3
|
+
from __future__ import print_function
|
4
|
+
import argparse
|
5
|
+
import logging
|
6
|
+
import os
|
7
|
+
import re
|
8
|
+
import sys
|
9
|
+
import shlex
|
10
|
+
import six
|
11
|
+
from six.moves import configparser
|
12
|
+
|
13
|
+
from behave.model import ScenarioOutline
|
14
|
+
from behave.model_core import FileLocation
|
15
|
+
from behave.reporter.junit import JUnitReporter
|
16
|
+
from behave.reporter.summary import SummaryReporter
|
17
|
+
from behave.tag_expression import TagExpression
|
18
|
+
from behave.formatter.base import StreamOpener
|
19
|
+
from behave.formatter import _registry as _format_registry
|
20
|
+
from behave.userdata import UserData, parse_user_define
|
21
|
+
from behave._types import Unknown
|
22
|
+
|
23
|
+
# -- PYTHON 2/3 COMPATIBILITY:
|
24
|
+
# SINCE Python 3.2: ConfigParser = SafeConfigParser
|
25
|
+
ConfigParser = configparser.ConfigParser
|
26
|
+
if six.PY2:
|
27
|
+
ConfigParser = configparser.SafeConfigParser
|
28
|
+
|
29
|
+
|
30
|
+
# -----------------------------------------------------------------------------
|
31
|
+
# CONFIGURATION DATA TYPES:
|
32
|
+
# -----------------------------------------------------------------------------
|
33
|
+
class LogLevel(object):
|
34
|
+
names = [
|
35
|
+
"NOTSET", "CRITICAL", "FATAL", "ERROR",
|
36
|
+
"WARNING", "WARN", "INFO", "DEBUG",
|
37
|
+
]
|
38
|
+
|
39
|
+
@staticmethod
|
40
|
+
def parse(levelname, unknown_level=None):
|
41
|
+
"""
|
42
|
+
Convert levelname into a numeric log level.
|
43
|
+
|
44
|
+
:param levelname: Logging levelname (as string)
|
45
|
+
:param unknown_level: Used if levelname is unknown (optional).
|
46
|
+
:return: Numeric log-level or unknown_level, if levelname is unknown.
|
47
|
+
"""
|
48
|
+
return getattr(logging, levelname.upper(), unknown_level)
|
49
|
+
|
50
|
+
@classmethod
|
51
|
+
def parse_type(cls, levelname):
|
52
|
+
level = cls.parse(levelname, Unknown)
|
53
|
+
if level is Unknown:
|
54
|
+
message = "%s is unknown, use: %s" % \
|
55
|
+
(levelname, ", ".join(cls.names[1:]))
|
56
|
+
raise argparse.ArgumentTypeError(message)
|
57
|
+
return level
|
58
|
+
|
59
|
+
@staticmethod
|
60
|
+
def to_string(level):
|
61
|
+
return logging.getLevelName(level)
|
62
|
+
|
63
|
+
|
64
|
+
class ConfigError(Exception):
|
65
|
+
pass
|
66
|
+
|
67
|
+
|
68
|
+
# -----------------------------------------------------------------------------
|
69
|
+
# CONFIGURATION SCHEMA:
|
70
|
+
# -----------------------------------------------------------------------------
|
71
|
+
options = [
|
72
|
+
(("-c", "--no-color"),
|
73
|
+
dict(action="store_false", dest="color",
|
74
|
+
help="Disable the use of ANSI color escapes.")),
|
75
|
+
|
76
|
+
(("--color",),
|
77
|
+
dict(action="store_true", dest="color",
|
78
|
+
help="""Use ANSI color escapes. This is the default
|
79
|
+
behaviour. This switch is used to override a
|
80
|
+
configuration file setting.""")),
|
81
|
+
|
82
|
+
(("-d", "--dry-run"),
|
83
|
+
dict(action="store_true",
|
84
|
+
help="Invokes formatters without executing the steps.")),
|
85
|
+
|
86
|
+
(("-D", "--define"),
|
87
|
+
dict(dest="userdata_defines", type=parse_user_define, action="append",
|
88
|
+
metavar="NAME=VALUE",
|
89
|
+
help="""Define user-specific data for the config.userdata dictionary.
|
90
|
+
Example: -D foo=bar to store it in config.userdata["foo"].""")),
|
91
|
+
|
92
|
+
(("-e", "--exclude"),
|
93
|
+
dict(metavar="PATTERN", dest="exclude_re",
|
94
|
+
help="""Don't run feature files matching regular expression
|
95
|
+
PATTERN.""")),
|
96
|
+
|
97
|
+
(("-i", "--include"),
|
98
|
+
dict(metavar="PATTERN", dest="include_re",
|
99
|
+
help="Only run feature files matching regular expression PATTERN.")),
|
100
|
+
|
101
|
+
(("--no-junit",),
|
102
|
+
dict(action="store_false", dest="junit",
|
103
|
+
help="Don't output JUnit-compatible reports.")),
|
104
|
+
|
105
|
+
(("--junit",),
|
106
|
+
dict(action="store_true",
|
107
|
+
help="""Output JUnit-compatible reports.
|
108
|
+
When junit is enabled, all stdout and stderr
|
109
|
+
will be redirected and dumped to the junit report,
|
110
|
+
regardless of the "--capture" and "--no-capture" options.
|
111
|
+
""")),
|
112
|
+
|
113
|
+
(("--junit-directory",),
|
114
|
+
dict(metavar="PATH", dest="junit_directory",
|
115
|
+
default="reports",
|
116
|
+
help="""Directory in which to store JUnit reports.""")),
|
117
|
+
|
118
|
+
((), # -- CONFIGFILE only
|
119
|
+
dict(dest="default_format",
|
120
|
+
help="Specify default formatter (default: pretty).")),
|
121
|
+
|
122
|
+
|
123
|
+
(("-f", "--format"),
|
124
|
+
dict(action="append",
|
125
|
+
help="""Specify a formatter. If none is specified the default
|
126
|
+
formatter is used. Pass "--format help" to get a
|
127
|
+
list of available formatters.""")),
|
128
|
+
|
129
|
+
(("--steps-catalog",),
|
130
|
+
dict(action="store_true", dest="steps_catalog",
|
131
|
+
help="""Show a catalog of all available step definitions.
|
132
|
+
SAME AS: --format=steps.catalog --dry-run --no-summary -q""")),
|
133
|
+
|
134
|
+
((), # -- CONFIGFILE only
|
135
|
+
dict(dest="scenario_outline_annotation_schema",
|
136
|
+
help="""Specify name annotation schema for scenario outline
|
137
|
+
(default="{name} -- @{row.id} {examples.name}").""")),
|
138
|
+
|
139
|
+
(("-k", "--no-skipped"),
|
140
|
+
dict(action="store_false", dest="show_skipped",
|
141
|
+
help="Don't print skipped steps (due to tags).")),
|
142
|
+
|
143
|
+
(("--show-skipped",),
|
144
|
+
dict(action="store_true",
|
145
|
+
help="""Print skipped steps.
|
146
|
+
This is the default behaviour. This switch is used to
|
147
|
+
override a configuration file setting.""")),
|
148
|
+
|
149
|
+
(("--no-snippets",),
|
150
|
+
dict(action="store_false", dest="show_snippets",
|
151
|
+
help="Don't print snippets for unimplemented steps.")),
|
152
|
+
(("--snippets",),
|
153
|
+
dict(action="store_true", dest="show_snippets",
|
154
|
+
help="""Print snippets for unimplemented steps.
|
155
|
+
This is the default behaviour. This switch is used to
|
156
|
+
override a configuration file setting.""")),
|
157
|
+
|
158
|
+
(("-m", "--no-multiline"),
|
159
|
+
dict(action="store_false", dest="show_multiline",
|
160
|
+
help="""Don't print multiline strings and tables under
|
161
|
+
steps.""")),
|
162
|
+
|
163
|
+
(("--multiline", ),
|
164
|
+
dict(action="store_true", dest="show_multiline",
|
165
|
+
help="""Print multiline strings and tables under steps.
|
166
|
+
This is the default behaviour. This switch is used to
|
167
|
+
override a configuration file setting.""")),
|
168
|
+
|
169
|
+
(("-n", "--name"),
|
170
|
+
dict(action="append",
|
171
|
+
help="""Only execute the feature elements which match part
|
172
|
+
of the given name. If this option is given more
|
173
|
+
than once, it will match against all the given
|
174
|
+
names.""")),
|
175
|
+
|
176
|
+
(("--no-capture",),
|
177
|
+
dict(action="store_false", dest="stdout_capture",
|
178
|
+
help="""Don't capture stdout (any stdout output will be
|
179
|
+
printed immediately.)""")),
|
180
|
+
|
181
|
+
(("--capture",),
|
182
|
+
dict(action="store_true", dest="stdout_capture",
|
183
|
+
help="""Capture stdout (any stdout output will be
|
184
|
+
printed if there is a failure.)
|
185
|
+
This is the default behaviour. This switch is used to
|
186
|
+
override a configuration file setting.""")),
|
187
|
+
|
188
|
+
(("--no-capture-stderr",),
|
189
|
+
dict(action="store_false", dest="stderr_capture",
|
190
|
+
help="""Don't capture stderr (any stderr output will be
|
191
|
+
printed immediately.)""")),
|
192
|
+
|
193
|
+
(("--capture-stderr",),
|
194
|
+
dict(action="store_true", dest="stderr_capture",
|
195
|
+
help="""Capture stderr (any stderr output will be
|
196
|
+
printed if there is a failure.)
|
197
|
+
This is the default behaviour. This switch is used to
|
198
|
+
override a configuration file setting.""")),
|
199
|
+
|
200
|
+
(("--no-logcapture",),
|
201
|
+
dict(action="store_false", dest="log_capture",
|
202
|
+
help="""Don't capture logging. Logging configuration will
|
203
|
+
be left intact.""")),
|
204
|
+
|
205
|
+
(("--logcapture",),
|
206
|
+
dict(action="store_true", dest="log_capture",
|
207
|
+
help="""Capture logging. All logging during a step will be captured
|
208
|
+
and displayed in the event of a failure.
|
209
|
+
This is the default behaviour. This switch is used to
|
210
|
+
override a configuration file setting.""")),
|
211
|
+
|
212
|
+
(("--logging-level",),
|
213
|
+
dict(type=LogLevel.parse_type,
|
214
|
+
help="""Specify a level to capture logging at. The default
|
215
|
+
is INFO - capturing everything.""")),
|
216
|
+
|
217
|
+
(("--logging-format",),
|
218
|
+
dict(help="""Specify custom format to print statements. Uses the
|
219
|
+
same format as used by standard logging handlers. The
|
220
|
+
default is "%%(levelname)s:%%(name)s:%%(message)s".""")),
|
221
|
+
|
222
|
+
(("--logging-datefmt",),
|
223
|
+
dict(help="""Specify custom date/time format to print
|
224
|
+
statements.
|
225
|
+
Uses the same format as used by standard logging
|
226
|
+
handlers.""")),
|
227
|
+
|
228
|
+
(("--logging-filter",),
|
229
|
+
dict(help="""Specify which statements to filter in/out. By default,
|
230
|
+
everything is captured. If the output is too verbose, use
|
231
|
+
this option to filter out needless output.
|
232
|
+
Example: --logging-filter=foo will capture statements issued
|
233
|
+
ONLY to foo or foo.what.ever.sub but not foobar or other
|
234
|
+
logger. Specify multiple loggers with comma:
|
235
|
+
filter=foo,bar,baz.
|
236
|
+
If any logger name is prefixed with a minus, eg filter=-foo,
|
237
|
+
it will be excluded rather than included.""",
|
238
|
+
config_help="""Specify which statements to filter in/out. By default,
|
239
|
+
everything is captured. If the output is too verbose,
|
240
|
+
use this option to filter out needless output.
|
241
|
+
Example: ``logging_filter = foo`` will capture
|
242
|
+
statements issued ONLY to "foo" or "foo.what.ever.sub"
|
243
|
+
but not "foobar" or other logger. Specify multiple
|
244
|
+
loggers with comma: ``logging_filter = foo,bar,baz``.
|
245
|
+
If any logger name is prefixed with a minus, eg
|
246
|
+
``logging_filter = -foo``, it will be excluded rather
|
247
|
+
than included.""")),
|
248
|
+
|
249
|
+
(("--logging-clear-handlers",),
|
250
|
+
dict(action="store_true",
|
251
|
+
help="Clear all other logging handlers.")),
|
252
|
+
|
253
|
+
(("--no-summary",),
|
254
|
+
dict(action="store_false", dest="summary",
|
255
|
+
help="""Don't display the summary at the end of the run.""")),
|
256
|
+
|
257
|
+
(("--summary",),
|
258
|
+
dict(action="store_true", dest="summary",
|
259
|
+
help="""Display the summary at the end of the run.""")),
|
260
|
+
|
261
|
+
(("-o", "--outfile"),
|
262
|
+
dict(action="append", dest="outfiles", metavar="FILE",
|
263
|
+
help="Write to specified file instead of stdout.")),
|
264
|
+
|
265
|
+
((), # -- CONFIGFILE only
|
266
|
+
dict(action="append", dest="paths",
|
267
|
+
help="Specify default feature paths, used when none are provided.")),
|
268
|
+
|
269
|
+
(("-q", "--quiet"),
|
270
|
+
dict(action="store_true",
|
271
|
+
help="Alias for --no-snippets --no-source.")),
|
272
|
+
|
273
|
+
(("-s", "--no-source"),
|
274
|
+
dict(action="store_false", dest="show_source",
|
275
|
+
help="""Don't print the file and line of the step definition with the
|
276
|
+
steps.""")),
|
277
|
+
|
278
|
+
(("--show-source",),
|
279
|
+
dict(action="store_true", dest="show_source",
|
280
|
+
help="""Print the file and line of the step
|
281
|
+
definition with the steps. This is the default
|
282
|
+
behaviour. This switch is used to override a
|
283
|
+
configuration file setting.""")),
|
284
|
+
|
285
|
+
(("--stage",),
|
286
|
+
dict(help="""Defines the current test stage.
|
287
|
+
The test stage name is used as name prefix for the environment
|
288
|
+
file and the steps directory (instead of default path names).
|
289
|
+
""")),
|
290
|
+
|
291
|
+
(("--stop",),
|
292
|
+
dict(action="store_true",
|
293
|
+
help="Stop running tests at the first failure.")),
|
294
|
+
|
295
|
+
# -- DISABLE-UNUSED-OPTION: Not used anywhere.
|
296
|
+
# (("-S", "--strict"),
|
297
|
+
# dict(action="store_true",
|
298
|
+
# help="Fail if there are any undefined or pending steps.")),
|
299
|
+
|
300
|
+
((), # -- CONFIGFILE only
|
301
|
+
dict(dest="default_tags", metavar="TAG_EXPRESSION",
|
302
|
+
help="""Define default tags when non are provided.
|
303
|
+
See --tags for more information.""")),
|
304
|
+
|
305
|
+
(("-t", "--tags"),
|
306
|
+
dict(action="append", metavar="TAG_EXPRESSION",
|
307
|
+
help="""Only execute features or scenarios with tags
|
308
|
+
matching TAG_EXPRESSION. Pass "--tags-help" for
|
309
|
+
more information.""",
|
310
|
+
config_help="""Only execute certain features or scenarios based
|
311
|
+
on the tag expression given. See below for how to code
|
312
|
+
tag expressions in configuration files.""")),
|
313
|
+
|
314
|
+
(("-T", "--no-timings"),
|
315
|
+
dict(action="store_false", dest="show_timings",
|
316
|
+
help="""Don't print the time taken for each step.""")),
|
317
|
+
|
318
|
+
(("--show-timings",),
|
319
|
+
dict(action="store_true", dest="show_timings",
|
320
|
+
help="""Print the time taken, in seconds, of each step after the
|
321
|
+
step has completed. This is the default behaviour. This
|
322
|
+
switch is used to override a configuration file
|
323
|
+
setting.""")),
|
324
|
+
|
325
|
+
(("-v", "--verbose"),
|
326
|
+
dict(action="store_true",
|
327
|
+
help="Show the files and features loaded.")),
|
328
|
+
|
329
|
+
(("-w", "--wip"),
|
330
|
+
dict(action="store_true",
|
331
|
+
help="""Only run scenarios tagged with "wip". Additionally: use the
|
332
|
+
"plain" formatter, do not capture stdout or logging output
|
333
|
+
and stop at the first failure.""")),
|
334
|
+
|
335
|
+
(("-x", "--expand"),
|
336
|
+
dict(action="store_true",
|
337
|
+
help="Expand scenario outline tables in output.")),
|
338
|
+
|
339
|
+
(("--lang",),
|
340
|
+
dict(metavar="LANG",
|
341
|
+
help="Use keywords for a language other than English.")),
|
342
|
+
|
343
|
+
(("--lang-list",),
|
344
|
+
dict(action="store_true",
|
345
|
+
help="List the languages available for --lang.")),
|
346
|
+
|
347
|
+
(("--lang-help",),
|
348
|
+
dict(metavar="LANG",
|
349
|
+
help="List the translations accepted for one language.")),
|
350
|
+
|
351
|
+
(("--tags-help",),
|
352
|
+
dict(action="store_true",
|
353
|
+
help="Show help for tag expressions.")),
|
354
|
+
|
355
|
+
(("--version",),
|
356
|
+
dict(action="store_true", help="Show version.")),
|
357
|
+
]
|
358
|
+
|
359
|
+
# -- OPTIONS: With raw value access semantics in configuration file.
|
360
|
+
raw_value_options = frozenset([
|
361
|
+
"logging_format",
|
362
|
+
"logging_datefmt",
|
363
|
+
# -- MAYBE: "scenario_outline_annotation_schema",
|
364
|
+
])
|
365
|
+
|
366
|
+
|
367
|
+
def read_configuration(path):
|
368
|
+
# pylint: disable=too-many-locals, too-many-branches
|
369
|
+
config = ConfigParser()
|
370
|
+
config.optionxform = str # -- SUPPORT: case-sensitive keys
|
371
|
+
config.read(path)
|
372
|
+
config_dir = os.path.dirname(path)
|
373
|
+
result = {}
|
374
|
+
for fixed, keywords in options:
|
375
|
+
if "dest" in keywords:
|
376
|
+
dest = keywords["dest"]
|
377
|
+
else:
|
378
|
+
for opt in fixed:
|
379
|
+
if opt.startswith("--"):
|
380
|
+
dest = opt[2:].replace("-", "_")
|
381
|
+
else:
|
382
|
+
assert len(opt) == 2
|
383
|
+
dest = opt[1:]
|
384
|
+
if dest in "tags_help lang_list lang_help version".split():
|
385
|
+
continue
|
386
|
+
if not config.has_option("behave", dest):
|
387
|
+
continue
|
388
|
+
action = keywords.get("action", "store")
|
389
|
+
if action == "store":
|
390
|
+
use_raw_value = dest in raw_value_options
|
391
|
+
result[dest] = config.get("behave", dest, raw=use_raw_value)
|
392
|
+
elif action in ("store_true", "store_false"):
|
393
|
+
result[dest] = config.getboolean("behave", dest)
|
394
|
+
elif action == "append":
|
395
|
+
if dest == "userdata_defines":
|
396
|
+
continue # -- SKIP-CONFIGFILE: Command-line only option.
|
397
|
+
result[dest] = \
|
398
|
+
[s.strip() for s in config.get("behave", dest).splitlines()]
|
399
|
+
else:
|
400
|
+
raise ValueError('action "%s" not implemented' % action)
|
401
|
+
|
402
|
+
# -- STEP: format/outfiles coupling
|
403
|
+
if "format" in result:
|
404
|
+
# -- OPTIONS: format/outfiles are coupled in configuration file.
|
405
|
+
formatters = result["format"]
|
406
|
+
formatter_size = len(formatters)
|
407
|
+
outfiles = result.get("outfiles", [])
|
408
|
+
outfiles_size = len(outfiles)
|
409
|
+
if outfiles_size < formatter_size:
|
410
|
+
for formatter_name in formatters[outfiles_size:]:
|
411
|
+
outfile = "%s.output" % formatter_name
|
412
|
+
outfiles.append(outfile)
|
413
|
+
result["outfiles"] = outfiles
|
414
|
+
elif len(outfiles) > formatter_size:
|
415
|
+
print("CONFIG-ERROR: Too many outfiles (%d) provided." %
|
416
|
+
outfiles_size)
|
417
|
+
result["outfiles"] = outfiles[:formatter_size]
|
418
|
+
|
419
|
+
for paths_name in ("paths", "outfiles"):
|
420
|
+
if paths_name in result:
|
421
|
+
# -- Evaluate relative paths relative to location.
|
422
|
+
# NOTE: Absolute paths are preserved by os.path.join().
|
423
|
+
paths = result[paths_name]
|
424
|
+
result[paths_name] = \
|
425
|
+
[os.path.normpath(os.path.join(config_dir, p)) for p in paths]
|
426
|
+
|
427
|
+
# -- STEP: Special additional configuration sections.
|
428
|
+
# SCHEMA: config_section: data_name
|
429
|
+
special_config_section_map = {
|
430
|
+
"behave.formatters": "more_formatters",
|
431
|
+
"behave.userdata": "userdata",
|
432
|
+
}
|
433
|
+
for section_name, data_name in special_config_section_map.items():
|
434
|
+
result[data_name] = {}
|
435
|
+
if config.has_section(section_name):
|
436
|
+
result[data_name].update(config.items(section_name))
|
437
|
+
|
438
|
+
return result
|
439
|
+
|
440
|
+
|
441
|
+
def config_filenames():
|
442
|
+
paths = ["./", os.path.expanduser("~")]
|
443
|
+
if sys.platform in ("cygwin", "win32") and "APPDATA" in os.environ:
|
444
|
+
paths.append(os.path.join(os.environ["APPDATA"]))
|
445
|
+
|
446
|
+
for path in reversed(paths):
|
447
|
+
for filename in reversed(
|
448
|
+
("behave.ini", ".behaverc", "setup.cfg", "tox.ini")):
|
449
|
+
filename = os.path.join(path, filename)
|
450
|
+
if os.path.isfile(filename):
|
451
|
+
yield filename
|
452
|
+
|
453
|
+
|
454
|
+
def load_configuration(defaults, verbose=False):
|
455
|
+
for filename in config_filenames():
|
456
|
+
if verbose:
|
457
|
+
print('Loading config defaults from "%s"' % filename)
|
458
|
+
defaults.update(read_configuration(filename))
|
459
|
+
|
460
|
+
if verbose:
|
461
|
+
print("Using defaults:")
|
462
|
+
for k, v in six.iteritems(defaults):
|
463
|
+
print("%15s %s" % (k, v))
|
464
|
+
|
465
|
+
|
466
|
+
def setup_parser():
|
467
|
+
# construct the parser
|
468
|
+
# usage = "%(prog)s [options] [ [FILE|DIR|URL][:LINE[:LINE]*] ]+"
|
469
|
+
usage = "%(prog)s [options] [ [DIR|FILE|FILE:LINE] ]+"
|
470
|
+
description = """\
|
471
|
+
Run a number of feature tests with behave."""
|
472
|
+
more = """
|
473
|
+
EXAMPLES:
|
474
|
+
behave features/
|
475
|
+
behave features/one.feature features/two.feature
|
476
|
+
behave features/one.feature:10
|
477
|
+
behave @features.txt
|
478
|
+
"""
|
479
|
+
parser = argparse.ArgumentParser(usage=usage, description=description)
|
480
|
+
for fixed, keywords in options:
|
481
|
+
if not fixed:
|
482
|
+
continue # -- CONFIGFILE only.
|
483
|
+
if "config_help" in keywords:
|
484
|
+
keywords = dict(keywords)
|
485
|
+
del keywords["config_help"]
|
486
|
+
parser.add_argument(*fixed, **keywords)
|
487
|
+
parser.add_argument("paths", nargs="*",
|
488
|
+
help="Feature directory, file or file location (FILE:LINE).")
|
489
|
+
return parser
|
490
|
+
|
491
|
+
|
492
|
+
class Configuration(object):
|
493
|
+
"""Configuration object for behave and behave runners."""
|
494
|
+
# pylint: disable=too-many-instance-attributes
|
495
|
+
defaults = dict(
|
496
|
+
color=sys.platform != "win32",
|
497
|
+
show_snippets=True,
|
498
|
+
show_skipped=True,
|
499
|
+
dry_run=False,
|
500
|
+
show_source=True,
|
501
|
+
show_timings=True,
|
502
|
+
stdout_capture=True,
|
503
|
+
stderr_capture=True,
|
504
|
+
log_capture=True,
|
505
|
+
logging_format="%(levelname)s:%(name)s:%(message)s",
|
506
|
+
logging_level=logging.INFO,
|
507
|
+
steps_catalog=False,
|
508
|
+
summary=True,
|
509
|
+
junit=False,
|
510
|
+
stage=None,
|
511
|
+
userdata={},
|
512
|
+
# -- SPECIAL:
|
513
|
+
default_format="pretty", # -- Used when no formatters are configured.
|
514
|
+
default_tags="", # -- Used when no tags are defined.
|
515
|
+
scenario_outline_annotation_schema=u"{name} -- @{row.id} {examples.name}"
|
516
|
+
)
|
517
|
+
cmdline_only_options = set("userdata_defines")
|
518
|
+
|
519
|
+
def __init__(self, command_args=None, load_config=True, verbose=None,
|
520
|
+
**kwargs):
|
521
|
+
"""
|
522
|
+
Constructs a behave configuration object.
|
523
|
+
* loads the configuration defaults (if needed).
|
524
|
+
* process the command-line args
|
525
|
+
* store the configuration results
|
526
|
+
|
527
|
+
:param command_args: Provide command args (as sys.argv).
|
528
|
+
If command_args is None, sys.argv[1:] is used.
|
529
|
+
:type command_args: list<str>, str
|
530
|
+
:param load_config: Indicate if configfile should be loaded (=true)
|
531
|
+
:param verbose: Indicate if diagnostic output is enabled
|
532
|
+
:param kwargs: Used to hand-over/overwrite default values.
|
533
|
+
"""
|
534
|
+
# pylint: disable=too-many-branches, too-many-statements
|
535
|
+
if command_args is None:
|
536
|
+
command_args = sys.argv[1:]
|
537
|
+
elif isinstance(command_args, six.string_types):
|
538
|
+
if six.PY2 and isinstance(command_args, six.text_type):
|
539
|
+
command_args = command_args.encode("utf-8")
|
540
|
+
elif six.PY3 and isinstance(command_args, six.binary_type):
|
541
|
+
command_args = command_args.decode("utf-8")
|
542
|
+
command_args = shlex.split(command_args)
|
543
|
+
if verbose is None:
|
544
|
+
# -- AUTO-DISCOVER: Verbose mode from command-line args.
|
545
|
+
verbose = ("-v" in command_args) or ("--verbose" in command_args)
|
546
|
+
|
547
|
+
self.version = None
|
548
|
+
self.tags_help = None
|
549
|
+
self.lang_list = None
|
550
|
+
self.lang_help = None
|
551
|
+
self.default_tags = None
|
552
|
+
self.junit = None
|
553
|
+
self.logging_format = None
|
554
|
+
self.logging_datefmt = None
|
555
|
+
self.name = None
|
556
|
+
self.scope = None
|
557
|
+
self.steps_catalog = None
|
558
|
+
self.userdata = None
|
559
|
+
self.wip = None
|
560
|
+
|
561
|
+
defaults = self.defaults.copy()
|
562
|
+
for name, value in six.iteritems(kwargs):
|
563
|
+
defaults[name] = value
|
564
|
+
self.defaults = defaults
|
565
|
+
self.formatters = []
|
566
|
+
self.reporters = []
|
567
|
+
self.name_re = None
|
568
|
+
self.outputs = []
|
569
|
+
self.include_re = None
|
570
|
+
self.exclude_re = None
|
571
|
+
self.scenario_outline_annotation_schema = None # pylint: disable=invalid-name
|
572
|
+
self.steps_dir = "steps"
|
573
|
+
self.environment_file = "environment.py"
|
574
|
+
self.userdata_defines = None
|
575
|
+
self.more_formatters = None
|
576
|
+
if load_config:
|
577
|
+
load_configuration(self.defaults, verbose=verbose)
|
578
|
+
parser = setup_parser()
|
579
|
+
parser.set_defaults(**self.defaults)
|
580
|
+
args = parser.parse_args(command_args)
|
581
|
+
for key, value in six.iteritems(args.__dict__):
|
582
|
+
if key.startswith("_") and key not in self.cmdline_only_options:
|
583
|
+
continue
|
584
|
+
setattr(self, key, value)
|
585
|
+
|
586
|
+
self.paths = [os.path.normpath(path) for path in self.paths]
|
587
|
+
self.setup_outputs(args.outfiles)
|
588
|
+
|
589
|
+
if self.steps_catalog:
|
590
|
+
# -- SHOW STEP-CATALOG: As step summary.
|
591
|
+
self.default_format = "steps.catalog"
|
592
|
+
self.format = ["steps.catalog"]
|
593
|
+
self.dry_run = True
|
594
|
+
self.summary = False
|
595
|
+
self.show_skipped = False
|
596
|
+
self.quiet = True
|
597
|
+
|
598
|
+
if self.wip:
|
599
|
+
# Only run scenarios tagged with "wip".
|
600
|
+
# Additionally:
|
601
|
+
# * use the "plain" formatter (per default)
|
602
|
+
# * do not capture stdout or logging output and
|
603
|
+
# * stop at the first failure.
|
604
|
+
self.default_format = "plain"
|
605
|
+
self.tags = ["wip"] + self.default_tags.split()
|
606
|
+
self.color = False
|
607
|
+
self.stop = True
|
608
|
+
self.log_capture = False
|
609
|
+
self.stdout_capture = False
|
610
|
+
|
611
|
+
self.tags = TagExpression(self.tags or self.default_tags.split())
|
612
|
+
|
613
|
+
if self.quiet:
|
614
|
+
self.show_source = False
|
615
|
+
self.show_snippets = False
|
616
|
+
|
617
|
+
if self.exclude_re:
|
618
|
+
self.exclude_re = re.compile(self.exclude_re)
|
619
|
+
|
620
|
+
if self.include_re:
|
621
|
+
self.include_re = re.compile(self.include_re)
|
622
|
+
if self.name:
|
623
|
+
# -- SELECT: Scenario-by-name, build regular expression.
|
624
|
+
self.name_re = self.build_name_re(self.name)
|
625
|
+
|
626
|
+
if self.stage is None: # pylint: disable=access-member-before-definition
|
627
|
+
# -- USE ENVIRONMENT-VARIABLE, if stage is undefined.
|
628
|
+
self.stage = os.environ.get("BEHAVE_STAGE", None)
|
629
|
+
self.setup_stage(self.stage)
|
630
|
+
self.setup_model()
|
631
|
+
self.setup_userdata()
|
632
|
+
|
633
|
+
# -- FINALLY: Setup Reporters and Formatters
|
634
|
+
# NOTE: Reporters and Formatters can now use userdata information.
|
635
|
+
if self.junit:
|
636
|
+
# Buffer the output (it will be put into Junit report)
|
637
|
+
self.stdout_capture = True
|
638
|
+
self.stderr_capture = True
|
639
|
+
self.log_capture = True
|
640
|
+
self.reporters.append(JUnitReporter(self))
|
641
|
+
if self.summary:
|
642
|
+
self.reporters.append(SummaryReporter(self))
|
643
|
+
|
644
|
+
self.setup_formats()
|
645
|
+
unknown_formats = self.collect_unknown_formats()
|
646
|
+
if unknown_formats:
|
647
|
+
parser.error("format=%s is unknown" % ", ".join(unknown_formats))
|
648
|
+
|
649
|
+
|
650
|
+
def setup_outputs(self, args_outfiles=None):
|
651
|
+
if self.outputs:
|
652
|
+
assert not args_outfiles, "ONLY-ONCE"
|
653
|
+
return
|
654
|
+
|
655
|
+
# -- NORMAL CASE: Setup only initially (once).
|
656
|
+
if not args_outfiles:
|
657
|
+
self.outputs.append(StreamOpener(stream=sys.stdout))
|
658
|
+
else:
|
659
|
+
for outfile in args_outfiles:
|
660
|
+
if outfile and outfile != "-":
|
661
|
+
self.outputs.append(StreamOpener(outfile))
|
662
|
+
else:
|
663
|
+
self.outputs.append(StreamOpener(stream=sys.stdout))
|
664
|
+
|
665
|
+
def setup_formats(self):
|
666
|
+
"""Register more, user-defined formatters by name."""
|
667
|
+
if self.more_formatters:
|
668
|
+
for name, scoped_class_name in self.more_formatters.items():
|
669
|
+
_format_registry.register_as(name, scoped_class_name)
|
670
|
+
|
671
|
+
def collect_unknown_formats(self):
|
672
|
+
unknown_formats = []
|
673
|
+
if self.format:
|
674
|
+
for format_name in self.format:
|
675
|
+
if (format_name == "help" or
|
676
|
+
_format_registry.is_formatter_valid(format_name)):
|
677
|
+
continue
|
678
|
+
unknown_formats.append(format_name)
|
679
|
+
return unknown_formats
|
680
|
+
|
681
|
+
@staticmethod
|
682
|
+
def build_name_re(names):
|
683
|
+
"""
|
684
|
+
Build regular expression for scenario selection by name
|
685
|
+
by using a list of name parts or name regular expressions.
|
686
|
+
|
687
|
+
:param names: List of name parts or regular expressions (as text).
|
688
|
+
:return: Compiled regular expression to use.
|
689
|
+
"""
|
690
|
+
# -- NOTE: re.LOCALE is removed in Python 3.6 (deprecated in Python 3.5)
|
691
|
+
# flags = (re.UNICODE | re.LOCALE)
|
692
|
+
pattern = u"|".join(names)
|
693
|
+
return re.compile(pattern, flags=re.UNICODE)
|
694
|
+
|
695
|
+
def exclude(self, filename):
|
696
|
+
if isinstance(filename, FileLocation):
|
697
|
+
filename = six.text_type(filename)
|
698
|
+
|
699
|
+
if self.include_re and self.include_re.search(filename) is None:
|
700
|
+
return True
|
701
|
+
if self.exclude_re and self.exclude_re.search(filename) is not None:
|
702
|
+
return True
|
703
|
+
return False
|
704
|
+
|
705
|
+
def setup_logging(self, level=None, configfile=None, **kwargs):
|
706
|
+
"""
|
707
|
+
Support simple setup of logging subsystem.
|
708
|
+
Ensures that the logging level is set.
|
709
|
+
But note that the logging setup can only occur once.
|
710
|
+
|
711
|
+
SETUP MODES:
|
712
|
+
* :func:`logging.config.fileConfig()`, if ``configfile`` is provided.
|
713
|
+
* :func:`logging.basicConfig()`, otherwise.
|
714
|
+
|
715
|
+
.. code-block: python
|
716
|
+
# -- FILE: features/environment.py
|
717
|
+
def before_all(context):
|
718
|
+
context.config.setup_logging()
|
719
|
+
|
720
|
+
:param level: Logging level of root logger.
|
721
|
+
If None, use :attr:`logging_level` value.
|
722
|
+
:param configfile: Configuration filename for fileConfig() setup.
|
723
|
+
:param kwargs: Passed to :func:`logging.basicConfig()`
|
724
|
+
"""
|
725
|
+
if level is None:
|
726
|
+
level = self.logging_level # pylint: disable=no-member
|
727
|
+
|
728
|
+
if configfile:
|
729
|
+
from logging.config import fileConfig
|
730
|
+
fileConfig(configfile)
|
731
|
+
else:
|
732
|
+
# pylint: disable=no-member
|
733
|
+
format_ = kwargs.pop("format", self.logging_format)
|
734
|
+
datefmt = kwargs.pop("datefmt", self.logging_datefmt)
|
735
|
+
logging.basicConfig(format=format_, datefmt=datefmt, **kwargs)
|
736
|
+
# -- ENSURE: Default log level is set
|
737
|
+
# (even if logging subsystem is already configured).
|
738
|
+
logging.getLogger().setLevel(level)
|
739
|
+
|
740
|
+
def setup_model(self):
|
741
|
+
if self.scenario_outline_annotation_schema:
|
742
|
+
name_schema = six.text_type(self.scenario_outline_annotation_schema)
|
743
|
+
ScenarioOutline.annotation_schema = name_schema.strip()
|
744
|
+
|
745
|
+
def setup_stage(self, stage=None):
|
746
|
+
"""Setup the test stage that selects a different set of
|
747
|
+
steps and environment implementations.
|
748
|
+
|
749
|
+
:param stage: Name of current test stage (as string or None).
|
750
|
+
|
751
|
+
EXAMPLE::
|
752
|
+
|
753
|
+
# -- SETUP DEFAULT TEST STAGE (unnamed):
|
754
|
+
config = Configuration()
|
755
|
+
config.setup_stage()
|
756
|
+
assert config.steps_dir == "steps"
|
757
|
+
assert config.environment_file == "environment.py"
|
758
|
+
|
759
|
+
# -- SETUP PRODUCT TEST STAGE:
|
760
|
+
config.setup_stage("product")
|
761
|
+
assert config.steps_dir == "product_steps"
|
762
|
+
assert config.environment_file == "product_environment.py"
|
763
|
+
"""
|
764
|
+
steps_dir = "steps"
|
765
|
+
environment_file = "environment.py"
|
766
|
+
if stage:
|
767
|
+
# -- USE A TEST STAGE: Select different set of implementations.
|
768
|
+
prefix = stage + "_"
|
769
|
+
steps_dir = prefix + steps_dir
|
770
|
+
environment_file = prefix + environment_file
|
771
|
+
self.steps_dir = steps_dir
|
772
|
+
self.environment_file = environment_file
|
773
|
+
|
774
|
+
def setup_userdata(self):
|
775
|
+
if not isinstance(self.userdata, UserData):
|
776
|
+
self.userdata = UserData(self.userdata)
|
777
|
+
if self.userdata_defines:
|
778
|
+
# -- ENSURE: Cmd-line overrides configuration file parameters.
|
779
|
+
self.userdata.update(self.userdata_defines)
|
780
|
+
|
781
|
+
def update_userdata(self, data):
|
782
|
+
"""Update userdata with data and reapply userdata defines (cmdline).
|
783
|
+
:param data: Provides (partial) userdata (as dict)
|
784
|
+
"""
|
785
|
+
self.userdata.update(data)
|
786
|
+
if self.userdata_defines:
|
787
|
+
# -- REAPPLY: Cmd-line defines (override configuration file data).
|
788
|
+
self.userdata.update(self.userdata_defines)
|