From 6496131b799afc711b96fc0464ec0f8c0c9ba785 Mon Sep 17 00:00:00 2001 From: Thomas Hisch Date: Tue, 13 Feb 2018 14:46:11 +0100 Subject: [PATCH 1/2] Show deselection count before tests are exectued Fixes #1527 --- _pytest/terminal.py | 10 ++++------ changelog/3213.feature | 1 + testing/test_cacheprovider.py | 2 +- testing/test_terminal.py | 27 ++++++++++++++++++++++++++- 4 files changed, 32 insertions(+), 8 deletions(-) create mode 100644 changelog/3213.feature diff --git a/_pytest/terminal.py b/_pytest/terminal.py index d37dd2c43..69d4ab8ad 100644 --- a/_pytest/terminal.py +++ b/_pytest/terminal.py @@ -361,6 +361,7 @@ class TerminalReporter(object): errors = len(self.stats.get('error', [])) skipped = len(self.stats.get('skipped', [])) + deselected = len(self.stats.get('deselected', [])) if final: line = "collected " else: @@ -368,6 +369,8 @@ class TerminalReporter(object): line += str(self._numcollected) + " item" + ('' if self._numcollected == 1 else 's') if errors: line += " / %d errors" % errors + if deselected: + line += " / %d deselected" % deselected if skipped: line += " / %d skipped" % skipped if self.isatty: @@ -377,6 +380,7 @@ class TerminalReporter(object): else: self.write_line(line) + @pytest.hookimpl(trylast=True) def pytest_collection_modifyitems(self): self.report_collect(True) @@ -484,7 +488,6 @@ class TerminalReporter(object): if exitstatus == EXIT_INTERRUPTED: self._report_keyboardinterrupt() del self._keyboardinterrupt_memo - self.summary_deselected() self.summary_stats() def pytest_keyboard_interrupt(self, excinfo): @@ -649,11 +652,6 @@ class TerminalReporter(object): if self.verbosity == -1: self.write_line(msg, **markup) - def summary_deselected(self): - if 'deselected' in self.stats: - self.write_sep("=", "%d tests deselected" % ( - len(self.stats['deselected'])), bold=True) - def repr_pythonversion(v=None): if v is None: diff --git a/changelog/3213.feature b/changelog/3213.feature new file mode 100644 index 000000000..755942f1b --- /dev/null +++ b/changelog/3213.feature @@ -0,0 +1 @@ +Output item deselection count before tests are run. \ No newline at end of file diff --git a/testing/test_cacheprovider.py b/testing/test_cacheprovider.py index 038fd229e..d33719920 100644 --- a/testing/test_cacheprovider.py +++ b/testing/test_cacheprovider.py @@ -361,7 +361,7 @@ class TestLastFailed(object): result = testdir.runpytest('--lf') result.stdout.fnmatch_lines([ - 'collected 4 items', + 'collected 4 items / 2 deselected', 'run-last-failure: rerun previous 2 failures', '*2 failed, 2 deselected in*', ]) diff --git a/testing/test_terminal.py b/testing/test_terminal.py index e95a3ed2b..f23dffe25 100644 --- a/testing/test_terminal.py +++ b/testing/test_terminal.py @@ -431,11 +431,36 @@ class TestTerminalFunctional(object): ) result = testdir.runpytest("-k", "test_two:", testpath) result.stdout.fnmatch_lines([ + "collected 3 items / 1 deselected", "*test_deselected.py ..*", - "=* 1 test*deselected *=", ]) assert result.ret == 0 + def test_show_deselected_items_using_markexpr_before_test_execution( + self, testdir): + testdir.makepyfile(""" + import pytest + + @pytest.mark.foo + def test_foobar(): + pass + + @pytest.mark.bar + def test_bar(): + pass + + def test_pass(): + pass + """) + result = testdir.runpytest('-m', 'not foo') + result.stdout.fnmatch_lines([ + "collected 3 items / 1 deselected", + "*test_show_des*.py ..*", + "*= 2 passed, 1 deselected in * =*", + ]) + assert "= 1 deselected =" not in result.stdout.str() + assert result.ret == 0 + def test_no_skip_summary_if_failure(self, testdir): testdir.makepyfile(""" import pytest From df2f019997d77004a29d6f784f1fa76ef02265cf Mon Sep 17 00:00:00 2001 From: Bruno Oliveira Date: Thu, 15 Feb 2018 19:45:05 -0200 Subject: [PATCH 2/2] Slight rewording in the CHANGELOG --- changelog/3213.feature | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/changelog/3213.feature b/changelog/3213.feature index 755942f1b..1b25793a7 100644 --- a/changelog/3213.feature +++ b/changelog/3213.feature @@ -1 +1 @@ -Output item deselection count before tests are run. \ No newline at end of file +Deselected item count is now shown before tests are run, e.g. ``collected X items / Y deselected``.