Merge pull request #2913 from nicoddemus/merge-master-into-features
Merge master into features
This commit is contained in:
		
						commit
						d1af369800
					
				|  | @ -248,7 +248,7 @@ class TracebackEntry(object): | |||
|             line = str(self.statement).lstrip() | ||||
|         except KeyboardInterrupt: | ||||
|             raise | ||||
|         except: | ||||
|         except:  # noqa | ||||
|             line = "???" | ||||
|         return "  File %r:%d in %s\n  %s\n" % (fn, self.lineno + 1, name, line) | ||||
| 
 | ||||
|  | @ -336,16 +336,16 @@ class Traceback(list): | |||
|             # XXX needs a test | ||||
|             key = entry.frame.code.path, id(entry.frame.code.raw), entry.lineno | ||||
|             # print "checking for recursion at", key | ||||
|             l = cache.setdefault(key, []) | ||||
|             if l: | ||||
|             values = cache.setdefault(key, []) | ||||
|             if values: | ||||
|                 f = entry.frame | ||||
|                 loc = f.f_locals | ||||
|                 for otherloc in l: | ||||
|                 for otherloc in values: | ||||
|                     if f.is_true(f.eval(co_equal, | ||||
|                                         __recursioncache_locals_1=loc, | ||||
|                                         __recursioncache_locals_2=otherloc)): | ||||
|                         return i | ||||
|             l.append(entry.frame.f_locals) | ||||
|             values.append(entry.frame.f_locals) | ||||
|         return None | ||||
| 
 | ||||
| 
 | ||||
|  | @ -476,12 +476,12 @@ class FormattedExcinfo(object): | |||
|             s = str(source.getstatement(len(source) - 1)) | ||||
|         except KeyboardInterrupt: | ||||
|             raise | ||||
|         except: | ||||
|         except:  # noqa | ||||
|             try: | ||||
|                 s = str(source[-1]) | ||||
|             except KeyboardInterrupt: | ||||
|                 raise | ||||
|             except: | ||||
|             except:  # noqa | ||||
|                 return 0 | ||||
|         return 4 + (len(s) - len(s.lstrip())) | ||||
| 
 | ||||
|  |  | |||
|  | @ -255,7 +255,7 @@ def findsource(obj): | |||
|         sourcelines, lineno = py.std.inspect.findsource(obj) | ||||
|     except py.builtin._sysex: | ||||
|         raise | ||||
|     except: | ||||
|     except:  # noqa | ||||
|         return None, -1 | ||||
|     source = Source() | ||||
|     source.lines = [line.rstrip() for line in sourcelines] | ||||
|  | @ -320,22 +320,22 @@ def get_statement_startend2(lineno, node): | |||
|     import ast | ||||
|     # flatten all statements and except handlers into one lineno-list | ||||
|     # AST's line numbers start indexing at 1 | ||||
|     l = [] | ||||
|     values = [] | ||||
|     for x in ast.walk(node): | ||||
|         if isinstance(x, _ast.stmt) or isinstance(x, _ast.ExceptHandler): | ||||
|             l.append(x.lineno - 1) | ||||
|             values.append(x.lineno - 1) | ||||
|             for name in "finalbody", "orelse": | ||||
|                 val = getattr(x, name, None) | ||||
|                 if val: | ||||
|                     # treat the finally/orelse part as its own statement | ||||
|                     l.append(val[0].lineno - 1 - 1) | ||||
|     l.sort() | ||||
|     insert_index = bisect_right(l, lineno) | ||||
|     start = l[insert_index - 1] | ||||
|     if insert_index >= len(l): | ||||
|                     values.append(val[0].lineno - 1 - 1) | ||||
|     values.sort() | ||||
|     insert_index = bisect_right(values, lineno) | ||||
|     start = values[insert_index - 1] | ||||
|     if insert_index >= len(values): | ||||
|         end = None | ||||
|     else: | ||||
|         end = l[insert_index] | ||||
|         end = values[insert_index] | ||||
|     return start, end | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -210,7 +210,7 @@ class AssertionRewritingHook(object): | |||
|             mod.__cached__ = pyc | ||||
|             mod.__loader__ = self | ||||
|             py.builtin.exec_(co, mod.__dict__) | ||||
|         except: | ||||
|         except:  # noqa | ||||
|             if name in sys.modules: | ||||
|                 del sys.modules[name] | ||||
|             raise | ||||
|  |  | |||
|  | @ -54,11 +54,11 @@ def _split_explanation(explanation): | |||
|     """ | ||||
|     raw_lines = (explanation or u('')).split('\n') | ||||
|     lines = [raw_lines[0]] | ||||
|     for l in raw_lines[1:]: | ||||
|         if l and l[0] in ['{', '}', '~', '>']: | ||||
|             lines.append(l) | ||||
|     for values in raw_lines[1:]: | ||||
|         if values and values[0] in ['{', '}', '~', '>']: | ||||
|             lines.append(values) | ||||
|         else: | ||||
|             lines[-1] += '\\n' + l | ||||
|             lines[-1] += '\\n' + values | ||||
|     return lines | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -1152,10 +1152,10 @@ class Config(object): | |||
|                 return [] | ||||
|         if type == "pathlist": | ||||
|             dp = py.path.local(self.inicfg.config.path).dirpath() | ||||
|             l = [] | ||||
|             values = [] | ||||
|             for relpath in shlex.split(value): | ||||
|                 l.append(dp.join(relpath, abs=True)) | ||||
|             return l | ||||
|                 values.append(dp.join(relpath, abs=True)) | ||||
|             return values | ||||
|         elif type == "args": | ||||
|             return shlex.split(value) | ||||
|         elif type == "linelist": | ||||
|  | @ -1172,13 +1172,13 @@ class Config(object): | |||
|         except KeyError: | ||||
|             return None | ||||
|         modpath = py.path.local(mod.__file__).dirpath() | ||||
|         l = [] | ||||
|         values = [] | ||||
|         for relroot in relroots: | ||||
|             if not isinstance(relroot, py.path.local): | ||||
|                 relroot = relroot.replace("/", py.path.local.sep) | ||||
|                 relroot = modpath.join(relroot, abs=True) | ||||
|             l.append(relroot) | ||||
|         return l | ||||
|             values.append(relroot) | ||||
|         return values | ||||
| 
 | ||||
|     def _get_override_ini_value(self, name): | ||||
|         value = None | ||||
|  |  | |||
|  | @ -458,13 +458,13 @@ class FixtureRequest(FuncargnamesCompatAttr): | |||
| 
 | ||||
|     def _get_fixturestack(self): | ||||
|         current = self | ||||
|         l = [] | ||||
|         values = [] | ||||
|         while 1: | ||||
|             fixturedef = getattr(current, "_fixturedef", None) | ||||
|             if fixturedef is None: | ||||
|                 l.reverse() | ||||
|                 return l | ||||
|             l.append(fixturedef) | ||||
|                 values.reverse() | ||||
|                 return values | ||||
|             values.append(fixturedef) | ||||
|             current = current._parent_request | ||||
| 
 | ||||
|     def _getfixturevalue(self, fixturedef): | ||||
|  | @ -746,7 +746,7 @@ class FixtureDef: | |||
|                 try: | ||||
|                     func = self._finalizer.pop() | ||||
|                     func() | ||||
|                 except: | ||||
|                 except:  # noqa | ||||
|                     exceptions.append(sys.exc_info()) | ||||
|             if exceptions: | ||||
|                 e = exceptions[0] | ||||
|  |  | |||
|  | @ -112,7 +112,7 @@ def wrap_session(config, doit): | |||
|                     excinfo.typename, excinfo.value.msg)) | ||||
|             config.hook.pytest_keyboard_interrupt(excinfo=excinfo) | ||||
|             session.exitstatus = EXIT_INTERRUPTED | ||||
|         except: | ||||
|         except:  # noqa | ||||
|             excinfo = _pytest._code.ExceptionInfo() | ||||
|             config.notify_exception(excinfo, config.option) | ||||
|             session.exitstatus = EXIT_INTERNALERROR | ||||
|  |  | |||
|  | @ -296,12 +296,12 @@ class MarkGenerator: | |||
|                 return | ||||
|         except AttributeError: | ||||
|             pass | ||||
|         self._markers = l = set() | ||||
|         self._markers = values = set() | ||||
|         for line in self._config.getini("markers"): | ||||
|             marker, _ = line.split(":", 1) | ||||
|             marker = marker.rstrip() | ||||
|             x = marker.split("(", 1)[0] | ||||
|             l.add(x) | ||||
|             values.add(x) | ||||
|         if name not in self._markers: | ||||
|             raise AttributeError("%r not a registered marker" % (name,)) | ||||
| 
 | ||||
|  |  | |||
|  | @ -174,9 +174,9 @@ class PytestArg: | |||
|         return hookrecorder | ||||
| 
 | ||||
| 
 | ||||
| def get_public_names(l): | ||||
|     """Only return names from iterator l without a leading underscore.""" | ||||
|     return [x for x in l if x[0] != "_"] | ||||
| def get_public_names(values): | ||||
|     """Only return names from iterator values without a leading underscore.""" | ||||
|     return [x for x in values if x[0] != "_"] | ||||
| 
 | ||||
| 
 | ||||
| class ParsedCall: | ||||
|  | @ -250,9 +250,9 @@ class HookRecorder: | |||
|         pytest.fail("\n".join(lines)) | ||||
| 
 | ||||
|     def getcall(self, name): | ||||
|         l = self.getcalls(name) | ||||
|         assert len(l) == 1, (name, l) | ||||
|         return l[0] | ||||
|         values = self.getcalls(name) | ||||
|         assert len(values) == 1, (name, values) | ||||
|         return values[0] | ||||
| 
 | ||||
|     # functionality for test reports | ||||
| 
 | ||||
|  | @ -263,7 +263,7 @@ class HookRecorder: | |||
|     def matchreport(self, inamepart="", | ||||
|                     names="pytest_runtest_logreport pytest_collectreport", when=None): | ||||
|         """ return a testreport whose dotted import path matches """ | ||||
|         l = [] | ||||
|         values = [] | ||||
|         for rep in self.getreports(names=names): | ||||
|             try: | ||||
|                 if not when and rep.when != "call" and rep.passed: | ||||
|  | @ -274,14 +274,14 @@ class HookRecorder: | |||
|             if when and getattr(rep, 'when', None) != when: | ||||
|                 continue | ||||
|             if not inamepart or inamepart in rep.nodeid.split("::"): | ||||
|                 l.append(rep) | ||||
|         if not l: | ||||
|                 values.append(rep) | ||||
|         if not values: | ||||
|             raise ValueError("could not find test report matching %r: " | ||||
|                              "no test reports at all!" % (inamepart,)) | ||||
|         if len(l) > 1: | ||||
|         if len(values) > 1: | ||||
|             raise ValueError( | ||||
|                 "found 2 or more testreports matching %r: %s" % (inamepart, l)) | ||||
|         return l[0] | ||||
|                 "found 2 or more testreports matching %r: %s" % (inamepart, values)) | ||||
|         return values[0] | ||||
| 
 | ||||
|     def getfailures(self, | ||||
|                     names='pytest_runtest_logreport pytest_collectreport'): | ||||
|  | @ -652,8 +652,8 @@ class Testdir: | |||
| 
 | ||||
|         """ | ||||
|         p = self.makepyfile(source) | ||||
|         l = list(cmdlineargs) + [p] | ||||
|         return self.inline_run(*l) | ||||
|         values = list(cmdlineargs) + [p] | ||||
|         return self.inline_run(*values) | ||||
| 
 | ||||
|     def inline_genitems(self, *args): | ||||
|         """Run ``pytest.main(['--collectonly'])`` in-process. | ||||
|  |  | |||
|  | @ -325,7 +325,7 @@ class PyCollector(PyobjMixin, main.Collector): | |||
|         for basecls in inspect.getmro(self.obj.__class__): | ||||
|             dicts.append(basecls.__dict__) | ||||
|         seen = {} | ||||
|         l = [] | ||||
|         values = [] | ||||
|         for dic in dicts: | ||||
|             for name, obj in list(dic.items()): | ||||
|                 if name in seen: | ||||
|  | @ -336,9 +336,9 @@ class PyCollector(PyobjMixin, main.Collector): | |||
|                     continue | ||||
|                 if not isinstance(res, list): | ||||
|                     res = [res] | ||||
|                 l.extend(res) | ||||
|         l.sort(key=lambda item: item.reportinfo()[:2]) | ||||
|         return l | ||||
|                 values.extend(res) | ||||
|         values.sort(key=lambda item: item.reportinfo()[:2]) | ||||
|         return values | ||||
| 
 | ||||
|     def makeitem(self, name, obj): | ||||
|         warnings.warn(deprecated.COLLECTOR_MAKEITEM, stacklevel=2) | ||||
|  | @ -600,7 +600,7 @@ class Generator(FunctionMixin, PyCollector): | |||
|         self.session._setupstate.prepare(self) | ||||
|         # see FunctionMixin.setup and test_setupstate_is_preserved_134 | ||||
|         self._preservedparent = self.parent.obj | ||||
|         l = [] | ||||
|         values = [] | ||||
|         seen = {} | ||||
|         for i, x in enumerate(self.obj()): | ||||
|             name, call, args = self.getcallargs(x) | ||||
|  | @ -613,9 +613,9 @@ class Generator(FunctionMixin, PyCollector): | |||
|             if name in seen: | ||||
|                 raise ValueError("%r generated tests with non-unique name %r" % (self, name)) | ||||
|             seen[name] = True | ||||
|             l.append(self.Function(name, self, args=args, callobj=call)) | ||||
|             values.append(self.Function(name, self, args=args, callobj=call)) | ||||
|         self.warn('C1', deprecated.YIELD_TESTS) | ||||
|         return l | ||||
|         return values | ||||
| 
 | ||||
|     def getcallargs(self, obj): | ||||
|         if not isinstance(obj, (tuple, list)): | ||||
|  |  | |||
|  | @ -85,7 +85,7 @@ class ApproxNumpy(ApproxBase): | |||
| 
 | ||||
|         try: | ||||
|             actual = np.asarray(actual) | ||||
|         except: | ||||
|         except:  # noqa | ||||
|             raise TypeError("cannot compare '{0}' to numpy.ndarray".format(actual)) | ||||
| 
 | ||||
|         if actual.shape != self.expected.shape: | ||||
|  |  | |||
|  | @ -197,7 +197,7 @@ class CallInfo: | |||
|         except KeyboardInterrupt: | ||||
|             self.stop = time() | ||||
|             raise | ||||
|         except: | ||||
|         except:  # noqa | ||||
|             self.excinfo = ExceptionInfo() | ||||
|         self.stop = time() | ||||
| 
 | ||||
|  |  | |||
|  | @ -366,10 +366,10 @@ def folded_skips(skipped): | |||
|         if when == 'setup' and 'skip' in keywords and 'pytestmark' not in keywords: | ||||
|             key = (key[0], None, key[2], ) | ||||
|         d.setdefault(key, []).append(event) | ||||
|     l = [] | ||||
|     values = [] | ||||
|     for key, events in d.items(): | ||||
|         l.append((len(events),) + key) | ||||
|     return l | ||||
|         values.append((len(events),) + key) | ||||
|     return values | ||||
| 
 | ||||
| 
 | ||||
| def show_skipped(terminalreporter, lines): | ||||
|  |  | |||
|  | @ -459,9 +459,9 @@ class TerminalReporter: | |||
|             line = self.config.cwd_relative_nodeid(nodeid) | ||||
|             if domain and line.endswith(domain): | ||||
|                 line = line[:-len(domain)] | ||||
|                 l = domain.split("[") | ||||
|                 l[0] = l[0].replace('.', '::')  # don't replace '.' in params | ||||
|                 line += "[".join(l) | ||||
|                 values = domain.split("[") | ||||
|                 values[0] = values[0].replace('.', '::')  # don't replace '.' in params | ||||
|                 line += "[".join(values) | ||||
|             return line | ||||
|         # collect_fspath comes from testid which has a "/"-normalized path | ||||
| 
 | ||||
|  | @ -493,11 +493,11 @@ class TerminalReporter: | |||
|     # summaries for sessionfinish | ||||
|     # | ||||
|     def getreports(self, name): | ||||
|         l = [] | ||||
|         values = [] | ||||
|         for x in self.stats.get(name, []): | ||||
|             if not hasattr(x, '_pdbshown'): | ||||
|                 l.append(x) | ||||
|         return l | ||||
|                 values.append(x) | ||||
|         return values | ||||
| 
 | ||||
|     def summary_warnings(self): | ||||
|         if self.hasopt("w"): | ||||
|  | @ -608,8 +608,8 @@ def repr_pythonversion(v=None): | |||
|         return str(v) | ||||
| 
 | ||||
| 
 | ||||
| def flatten(l): | ||||
|     for x in l: | ||||
| def flatten(values): | ||||
|     for x in values: | ||||
|         if isinstance(x, (list, tuple)): | ||||
|             for y in flatten(x): | ||||
|                 yield y | ||||
|  | @ -650,7 +650,7 @@ def build_summary_stats_line(stats): | |||
| 
 | ||||
| 
 | ||||
| def _plugin_nameversions(plugininfo): | ||||
|     l = [] | ||||
|     values = [] | ||||
|     for plugin, dist in plugininfo: | ||||
|         # gets us name and version! | ||||
|         name = '{dist.project_name}-{dist.version}'.format(dist=dist) | ||||
|  | @ -659,6 +659,6 @@ def _plugin_nameversions(plugininfo): | |||
|             name = name[7:] | ||||
|         # we decided to print python package names | ||||
|         # they can have more than one plugin | ||||
|         if name not in l: | ||||
|             l.append(name) | ||||
|     return l | ||||
|         if name not in values: | ||||
|             values.append(name) | ||||
|     return values | ||||
|  |  | |||
|  | @ -108,13 +108,13 @@ class TestCaseFunction(Function): | |||
|         except TypeError: | ||||
|             try: | ||||
|                 try: | ||||
|                     l = traceback.format_exception(*rawexcinfo) | ||||
|                     l.insert(0, "NOTE: Incompatible Exception Representation, " | ||||
|                     values = traceback.format_exception(*rawexcinfo) | ||||
|                     values.insert(0, "NOTE: Incompatible Exception Representation, " | ||||
|                                   "displaying natively:\n\n") | ||||
|                     fail("".join(l), pytrace=False) | ||||
|                     fail("".join(values), pytrace=False) | ||||
|                 except (fail.Exception, KeyboardInterrupt): | ||||
|                     raise | ||||
|                 except: | ||||
|                 except:  # noqa | ||||
|                     fail("ERROR: Unknown Incompatible Exception " | ||||
|                          "representation:\n%r" % (rawexcinfo,), pytrace=False) | ||||
|             except KeyboardInterrupt: | ||||
|  |  | |||
|  | @ -0,0 +1 @@ | |||
| Clarify language of proposal for fixtures parameters | ||||
|  | @ -0,0 +1 @@ | |||
| List python 3.6 in the documented supported versions in the getting started document. | ||||
|  | @ -201,6 +201,9 @@ list:: | |||
| Note that when calling ``metafunc.parametrize`` multiple times with different parameter sets, all parameter names across  | ||||
| those sets cannot be duplicated, otherwise an error will be raised. | ||||
| 
 | ||||
| More examples | ||||
| ------------- | ||||
| 
 | ||||
| For further examples, you might want to look at :ref:`more | ||||
| parametrization examples <paramexamples>`. | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,8 +1,13 @@ | |||
| :orphan: | ||||
| 
 | ||||
| ========================= | ||||
| Parametrize with fixtures | ||||
| ========================= | ||||
| =================================== | ||||
| PROPOSAL: Parametrize with fixtures | ||||
| =================================== | ||||
| 
 | ||||
| .. warning:: | ||||
| 
 | ||||
|     This document outlines a proposal around using fixtures as input | ||||
|     of parametrized tests or fixtures. | ||||
| 
 | ||||
| Problem | ||||
| ------- | ||||
|  | @ -108,8 +113,13 @@ the following values. | |||
| Alternative approach | ||||
| -------------------- | ||||
| 
 | ||||
| A new helper function named ``fixture_request`` tells pytest to yield all | ||||
| parameters of a fixture. | ||||
| A new helper function named ``fixture_request`` would tell pytest to yield | ||||
| all parameters marked as a fixture. | ||||
| 
 | ||||
| .. note:: | ||||
| 
 | ||||
|     The `pytest-lazy-fixture <https://pypi.python.org/pypi/pytest-lazy-fixture>`_ plugin implements a very | ||||
|     similar solution to the proposal below, make sure to check it out. | ||||
| 
 | ||||
| .. code-block:: python | ||||
| 
 | ||||
|  |  | |||
|  | @ -76,8 +76,8 @@ def test_excinfo_getstatement(): | |||
|     linenumbers = [_pytest._code.getrawcode(f).co_firstlineno - 1 + 4, | ||||
|                    _pytest._code.getrawcode(f).co_firstlineno - 1 + 1, | ||||
|                    _pytest._code.getrawcode(g).co_firstlineno - 1 + 1, ] | ||||
|     l = list(excinfo.traceback) | ||||
|     foundlinenumbers = [x.lineno for x in l] | ||||
|     values = list(excinfo.traceback) | ||||
|     foundlinenumbers = [x.lineno for x in values] | ||||
|     assert foundlinenumbers == linenumbers | ||||
|     # for x in info: | ||||
|     #    print "%s:%d  %s" %(x.path.relto(root), x.lineno, x.statement) | ||||
|  | @ -243,7 +243,7 @@ class TestTraceback_f_g_h(object): | |||
|         def f(n): | ||||
|             try: | ||||
|                 do_stuff() | ||||
|             except: | ||||
|             except:  # noqa | ||||
|                 reraise_me() | ||||
| 
 | ||||
|         excinfo = pytest.raises(RuntimeError, f, 8) | ||||
|  | @ -430,7 +430,7 @@ class TestFormattedExcinfo(object): | |||
|             exec(source.compile()) | ||||
|         except KeyboardInterrupt: | ||||
|             raise | ||||
|         except: | ||||
|         except:  # noqa | ||||
|             return _pytest._code.ExceptionInfo() | ||||
|         assert 0, "did not raise" | ||||
| 
 | ||||
|  | @ -1213,7 +1213,7 @@ def test_exception_repr_extraction_error_on_recursion(): | |||
| 
 | ||||
|     try: | ||||
|         a(numpy_like()) | ||||
|     except: | ||||
|     except:  # noqa | ||||
|         from _pytest._code.code import ExceptionInfo | ||||
|         from _pytest.pytester import LineMatcher | ||||
|         exc_info = ExceptionInfo() | ||||
|  | @ -1237,7 +1237,7 @@ def test_no_recursion_index_on_recursion_error(): | |||
|                 return getattr(self, '_' + attr) | ||||
| 
 | ||||
|         RecursionDepthError().trigger | ||||
|     except: | ||||
|     except:  # noqa | ||||
|         from _pytest._code.code import ExceptionInfo | ||||
|         exc_info = ExceptionInfo() | ||||
|         assert 'maximum recursion' in str(exc_info.getrepr()) | ||||
|  |  | |||
|  | @ -155,8 +155,8 @@ class TestAccesses(object): | |||
|         assert len(self.source) == 4 | ||||
| 
 | ||||
|     def test_iter(self): | ||||
|         l = [x for x in self.source] | ||||
|         assert len(l) == 4 | ||||
|         values = [x for x in self.source] | ||||
|         assert len(values) == 4 | ||||
| 
 | ||||
| 
 | ||||
| class TestSourceParsingAndCompiling(object): | ||||
|  | @ -329,8 +329,8 @@ def test_getstartingblock_singleline(): | |||
| 
 | ||||
|     x = A('x', 'y') | ||||
| 
 | ||||
|     l = [i for i in x.source.lines if i.strip()] | ||||
|     assert len(l) == 1 | ||||
|     values = [i for i in x.source.lines if i.strip()] | ||||
|     assert len(values) == 1 | ||||
| 
 | ||||
| 
 | ||||
| def test_getline_finally(): | ||||
|  |  | |||
|  | @ -22,5 +22,5 @@ def test_getstartingblock_multiline(): | |||
|           , | ||||
|           'z') | ||||
| 
 | ||||
|     l = [i for i in x.source.lines if i.strip()] | ||||
|     assert len(l) == 4 | ||||
|     values = [i for i in x.source.lines if i.strip()] | ||||
|     assert len(values) == 4 | ||||
|  |  | |||
|  | @ -868,11 +868,11 @@ class TestConftestCustomization(object): | |||
| 
 | ||||
|     def test_makeitem_non_underscore(self, testdir, monkeypatch): | ||||
|         modcol = testdir.getmodulecol("def _hello(): pass") | ||||
|         l = [] | ||||
|         values = [] | ||||
|         monkeypatch.setattr(pytest.Module, 'makeitem', | ||||
|                             lambda self, name, obj: l.append(name)) | ||||
|         l = modcol.collect() | ||||
|         assert '_hello' not in l | ||||
|                             lambda self, name, obj: values.append(name)) | ||||
|         values = modcol.collect() | ||||
|         assert '_hello' not in values | ||||
| 
 | ||||
|     def test_issue2369_collect_module_fileext(self, testdir): | ||||
|         """Ensure we can collect files with weird file extensions as Python | ||||
|  |  | |||
|  | @ -544,12 +544,12 @@ class TestRequestBasic(object): | |||
|     def test_getfixturevalue(self, testdir, getfixmethod): | ||||
|         item = testdir.getitem(""" | ||||
|             import pytest | ||||
|             l = [2] | ||||
|             values = [2] | ||||
|             @pytest.fixture | ||||
|             def something(request): return 1 | ||||
|             @pytest.fixture | ||||
|             def other(request): | ||||
|                 return l.pop() | ||||
|                 return values.pop() | ||||
|             def test_func(something): pass | ||||
|         """) | ||||
|         import contextlib | ||||
|  | @ -618,15 +618,15 @@ class TestRequestBasic(object): | |||
|     def test_request_addfinalizer_failing_setup(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [1] | ||||
|             values = [1] | ||||
|             @pytest.fixture | ||||
|             def myfix(request): | ||||
|                 request.addfinalizer(l.pop) | ||||
|                 request.addfinalizer(values.pop) | ||||
|                 assert 0 | ||||
|             def test_fix(myfix): | ||||
|                 pass | ||||
|             def test_finalizer_ran(): | ||||
|                 assert not l | ||||
|                 assert not values | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-s") | ||||
|         reprec.assertoutcome(failed=1, passed=1) | ||||
|  | @ -634,30 +634,30 @@ class TestRequestBasic(object): | |||
|     def test_request_addfinalizer_failing_setup_module(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [1, 2] | ||||
|             values = [1, 2] | ||||
|             @pytest.fixture(scope="module") | ||||
|             def myfix(request): | ||||
|                 request.addfinalizer(l.pop) | ||||
|                 request.addfinalizer(l.pop) | ||||
|                 request.addfinalizer(values.pop) | ||||
|                 request.addfinalizer(values.pop) | ||||
|                 assert 0 | ||||
|             def test_fix(myfix): | ||||
|                 pass | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-s") | ||||
|         mod = reprec.getcalls("pytest_runtest_setup")[0].item.module | ||||
|         assert not mod.l | ||||
|         assert not mod.values | ||||
| 
 | ||||
|     def test_request_addfinalizer_partial_setup_failure(self, testdir): | ||||
|         p = testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture | ||||
|             def something(request): | ||||
|                 request.addfinalizer(lambda: l.append(None)) | ||||
|                 request.addfinalizer(lambda: values.append(None)) | ||||
|             def test_func(something, missingarg): | ||||
|                 pass | ||||
|             def test_second(): | ||||
|                 assert len(l) == 1 | ||||
|                 assert len(values) == 1 | ||||
|         """) | ||||
|         result = testdir.runpytest(p) | ||||
|         result.stdout.fnmatch_lines([ | ||||
|  | @ -671,7 +671,7 @@ class TestRequestBasic(object): | |||
|         """ | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def _excepts(where): | ||||
|                 raise Exception('Error in %s fixture' % where) | ||||
|             @pytest.fixture | ||||
|  | @ -679,17 +679,17 @@ class TestRequestBasic(object): | |||
|                 return request | ||||
|             @pytest.fixture | ||||
|             def something(subrequest): | ||||
|                 subrequest.addfinalizer(lambda: l.append(1)) | ||||
|                 subrequest.addfinalizer(lambda: l.append(2)) | ||||
|                 subrequest.addfinalizer(lambda: values.append(1)) | ||||
|                 subrequest.addfinalizer(lambda: values.append(2)) | ||||
|                 subrequest.addfinalizer(lambda: _excepts('something')) | ||||
|             @pytest.fixture | ||||
|             def excepts(subrequest): | ||||
|                 subrequest.addfinalizer(lambda: _excepts('excepts')) | ||||
|                 subrequest.addfinalizer(lambda: l.append(3)) | ||||
|                 subrequest.addfinalizer(lambda: values.append(3)) | ||||
|             def test_first(something, excepts): | ||||
|                 pass | ||||
|             def test_second(): | ||||
|                 assert l == [3, 2, 1] | ||||
|                 assert values == [3, 2, 1] | ||||
|         """) | ||||
|         result = testdir.runpytest() | ||||
|         result.stdout.fnmatch_lines([ | ||||
|  | @ -744,13 +744,13 @@ class TestRequestBasic(object): | |||
|     def test_setupdecorator_and_xunit(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(scope='module', autouse=True) | ||||
|             def setup_module(): | ||||
|                 l.append("module") | ||||
|                 values.append("module") | ||||
|             @pytest.fixture(autouse=True) | ||||
|             def setup_function(): | ||||
|                 l.append("function") | ||||
|                 values.append("function") | ||||
| 
 | ||||
|             def test_func(): | ||||
|                 pass | ||||
|  | @ -758,14 +758,14 @@ class TestRequestBasic(object): | |||
|             class TestClass(object): | ||||
|                 @pytest.fixture(scope="class", autouse=True) | ||||
|                 def setup_class(self): | ||||
|                     l.append("class") | ||||
|                     values.append("class") | ||||
|                 @pytest.fixture(autouse=True) | ||||
|                 def setup_method(self): | ||||
|                     l.append("method") | ||||
|                     values.append("method") | ||||
|                 def test_method(self): | ||||
|                     pass | ||||
|             def test_all(): | ||||
|                 assert l == ["module", "function", "class", | ||||
|                 assert values == ["module", "function", "class", | ||||
|                              "function", "method", "function"] | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-v") | ||||
|  | @ -926,10 +926,10 @@ class TestRequestCachedSetup(object): | |||
|     def test_request_cachedsetup_extrakey(self, testdir): | ||||
|         item1 = testdir.getitem("def test_func(): pass") | ||||
|         req1 = fixtures.FixtureRequest(item1) | ||||
|         l = ["hello", "world"] | ||||
|         values = ["hello", "world"] | ||||
| 
 | ||||
|         def setup(): | ||||
|             return l.pop() | ||||
|             return values.pop() | ||||
| 
 | ||||
|         ret1 = req1.cached_setup(setup, extrakey=1) | ||||
|         ret2 = req1.cached_setup(setup, extrakey=2) | ||||
|  | @ -943,24 +943,24 @@ class TestRequestCachedSetup(object): | |||
|     def test_request_cachedsetup_cache_deletion(self, testdir): | ||||
|         item1 = testdir.getitem("def test_func(): pass") | ||||
|         req1 = fixtures.FixtureRequest(item1) | ||||
|         l = [] | ||||
|         values = [] | ||||
| 
 | ||||
|         def setup(): | ||||
|             l.append("setup") | ||||
|             values.append("setup") | ||||
| 
 | ||||
|         def teardown(val): | ||||
|             l.append("teardown") | ||||
|             values.append("teardown") | ||||
| 
 | ||||
|         req1.cached_setup(setup, teardown, scope="function") | ||||
|         assert l == ['setup'] | ||||
|         assert values == ['setup'] | ||||
|         # artificial call of finalizer | ||||
|         setupstate = req1._pyfuncitem.session._setupstate | ||||
|         setupstate._callfinalizers(item1) | ||||
|         assert l == ["setup", "teardown"] | ||||
|         assert values == ["setup", "teardown"] | ||||
|         req1.cached_setup(setup, teardown, scope="function") | ||||
|         assert l == ["setup", "teardown", "setup"] | ||||
|         assert values == ["setup", "teardown", "setup"] | ||||
|         setupstate._callfinalizers(item1) | ||||
|         assert l == ["setup", "teardown", "setup", "teardown"] | ||||
|         assert values == ["setup", "teardown", "setup", "teardown"] | ||||
| 
 | ||||
|     def test_request_cached_setup_two_args(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|  | @ -1002,17 +1002,17 @@ class TestRequestCachedSetup(object): | |||
|     def test_request_cached_setup_functional(self, testdir): | ||||
|         testdir.makepyfile(test_0=""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture | ||||
|             def something(request): | ||||
|                 val = request.cached_setup(fsetup, fteardown) | ||||
|                 return val | ||||
|             def fsetup(mycache=[1]): | ||||
|                 l.append(mycache.pop()) | ||||
|                 return l | ||||
|                 values.append(mycache.pop()) | ||||
|                 return values | ||||
|             def fteardown(something): | ||||
|                 l.remove(something[0]) | ||||
|                 l.append(2) | ||||
|                 values.remove(something[0]) | ||||
|                 values.append(2) | ||||
|             def test_list_once(something): | ||||
|                 assert something == [1] | ||||
|             def test_list_twice(something): | ||||
|  | @ -1021,7 +1021,7 @@ class TestRequestCachedSetup(object): | |||
|         testdir.makepyfile(test_1=""" | ||||
|             import test_0 # should have run already | ||||
|             def test_check_test0_has_teardown_correct(): | ||||
|                 assert test_0.l == [2] | ||||
|                 assert test_0.values == [2] | ||||
|         """) | ||||
|         result = testdir.runpytest("-v") | ||||
|         result.stdout.fnmatch_lines([ | ||||
|  | @ -1146,10 +1146,10 @@ class TestFixtureUsages(object): | |||
|     def test_funcarg_parametrized_and_used_twice(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(params=[1,2]) | ||||
|             def arg1(request): | ||||
|                 l.append(1) | ||||
|                 values.append(1) | ||||
|                 return request.param | ||||
| 
 | ||||
|             @pytest.fixture() | ||||
|  | @ -1158,7 +1158,7 @@ class TestFixtureUsages(object): | |||
| 
 | ||||
|             def test_add(arg1, arg2): | ||||
|                 assert arg2 == arg1 + 1 | ||||
|                 assert len(l) == arg1 | ||||
|                 assert len(values) == arg1 | ||||
|         """) | ||||
|         result = testdir.runpytest() | ||||
|         result.stdout.fnmatch_lines([ | ||||
|  | @ -1199,8 +1199,8 @@ class TestFixtureUsages(object): | |||
| 
 | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         l = reprec.getfailedcollections() | ||||
|         assert len(l) == 1 | ||||
|         values = reprec.getfailedcollections() | ||||
|         assert len(values) == 1 | ||||
| 
 | ||||
|     def test_request_can_be_overridden(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|  | @ -1219,20 +1219,20 @@ class TestFixtureUsages(object): | |||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
| 
 | ||||
|             @pytest.fixture(scope="class") | ||||
|             def myfix(request): | ||||
|                 request.cls.hello = "world" | ||||
|                 l.append(1) | ||||
|                 values.append(1) | ||||
| 
 | ||||
|             class TestClass(object): | ||||
|                 def test_one(self): | ||||
|                     assert self.hello == "world" | ||||
|                     assert len(l) == 1 | ||||
|                     assert len(values) == 1 | ||||
|                 def test_two(self): | ||||
|                     assert self.hello == "world" | ||||
|                     assert len(l) == 1 | ||||
|                     assert len(values) == 1 | ||||
|             pytest.mark.usefixtures("myfix")(TestClass) | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|  | @ -1286,7 +1286,7 @@ class TestFixtureUsages(object): | |||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def f(): | ||||
|                 yield 1 | ||||
|                 yield 2 | ||||
|  | @ -1300,14 +1300,14 @@ class TestFixtureUsages(object): | |||
|                 return request.param | ||||
| 
 | ||||
|             def test_1(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|             def test_2(arg2): | ||||
|                 l.append(arg2*10) | ||||
|                 values.append(arg2*10) | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-v") | ||||
|         reprec.assertoutcome(passed=4) | ||||
|         l = reprec.getcalls("pytest_runtest_call")[0].item.module.l | ||||
|         assert l == [1, 2, 10, 20] | ||||
|         values = reprec.getcalls("pytest_runtest_call")[0].item.module.values | ||||
|         assert values == [1, 2, 10, 20] | ||||
| 
 | ||||
| 
 | ||||
| class TestFixtureManagerParseFactories(object): | ||||
|  | @ -1457,19 +1457,19 @@ class TestAutouseDiscovery(object): | |||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             class TestA(object): | ||||
|                 l = [] | ||||
|                 values = [] | ||||
|                 @pytest.fixture(autouse=True) | ||||
|                 def setup1(self): | ||||
|                     self.l.append(1) | ||||
|                     self.values.append(1) | ||||
|                 def test_setup1(self): | ||||
|                     assert self.l == [1] | ||||
|                     assert self.values == [1] | ||||
|             class TestB(object): | ||||
|                 l = [] | ||||
|                 values = [] | ||||
|                 @pytest.fixture(autouse=True) | ||||
|                 def setup2(self): | ||||
|                     self.l.append(1) | ||||
|                     self.values.append(1) | ||||
|                 def test_setup2(self): | ||||
|                     assert self.l == [1] | ||||
|                     assert self.values == [1] | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(passed=2) | ||||
|  | @ -1552,22 +1552,22 @@ class TestAutouseDiscovery(object): | |||
|     def test_autouse_in_module_and_two_classes(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(autouse=True) | ||||
|             def append1(): | ||||
|                 l.append("module") | ||||
|                 values.append("module") | ||||
|             def test_x(): | ||||
|                 assert l == ["module"] | ||||
|                 assert values == ["module"] | ||||
| 
 | ||||
|             class TestA(object): | ||||
|                 @pytest.fixture(autouse=True) | ||||
|                 def append2(self): | ||||
|                     l.append("A") | ||||
|                     values.append("A") | ||||
|                 def test_hello(self): | ||||
|                     assert l == ["module", "module", "A"], l | ||||
|                     assert values == ["module", "module", "A"], values | ||||
|             class TestA2(object): | ||||
|                 def test_world(self): | ||||
|                     assert l == ["module", "module", "A", "module"], l | ||||
|                     assert values == ["module", "module", "A", "module"], values | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(passed=3) | ||||
|  | @ -1611,23 +1611,23 @@ class TestAutouseManagement(object): | |||
|     def test_funcarg_and_setup(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(scope="module") | ||||
|             def arg(): | ||||
|                 l.append(1) | ||||
|                 values.append(1) | ||||
|                 return 0 | ||||
|             @pytest.fixture(scope="module", autouse=True) | ||||
|             def something(arg): | ||||
|                 l.append(2) | ||||
|                 values.append(2) | ||||
| 
 | ||||
|             def test_hello(arg): | ||||
|                 assert len(l) == 2 | ||||
|                 assert l == [1,2] | ||||
|                 assert len(values) == 2 | ||||
|                 assert values == [1,2] | ||||
|                 assert arg == 0 | ||||
| 
 | ||||
|             def test_hello2(arg): | ||||
|                 assert len(l) == 2 | ||||
|                 assert l == [1,2] | ||||
|                 assert len(values) == 2 | ||||
|                 assert values == [1,2] | ||||
|                 assert arg == 0 | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|  | @ -1636,20 +1636,20 @@ class TestAutouseManagement(object): | |||
|     def test_uses_parametrized_resource(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(params=[1,2]) | ||||
|             def arg(request): | ||||
|                 return request.param | ||||
| 
 | ||||
|             @pytest.fixture(autouse=True) | ||||
|             def something(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
| 
 | ||||
|             def test_hello(): | ||||
|                 if len(l) == 1: | ||||
|                     assert l == [1] | ||||
|                 elif len(l) == 2: | ||||
|                     assert l == [1, 2] | ||||
|                 if len(values) == 1: | ||||
|                     assert values == [1] | ||||
|                 elif len(values) == 2: | ||||
|                     assert values == [1, 2] | ||||
|                 else: | ||||
|                     0/0 | ||||
| 
 | ||||
|  | @ -1661,7 +1661,7 @@ class TestAutouseManagement(object): | |||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
| 
 | ||||
|             @pytest.fixture(scope="session", params=[1,2]) | ||||
|             def arg(request): | ||||
|  | @ -1670,14 +1670,14 @@ class TestAutouseManagement(object): | |||
|             @pytest.fixture(scope="function", autouse=True) | ||||
|             def append(request, arg): | ||||
|                 if request.function.__name__ == "test_some": | ||||
|                     l.append(arg) | ||||
|                     values.append(arg) | ||||
| 
 | ||||
|             def test_some(): | ||||
|                 pass | ||||
| 
 | ||||
|             def test_result(arg): | ||||
|                 assert len(l) == arg | ||||
|                 assert l[:arg] == [1,2][:arg] | ||||
|                 assert len(values) == arg | ||||
|                 assert values[:arg] == [1,2][:arg] | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-v", "-s") | ||||
|         reprec.assertoutcome(passed=4) | ||||
|  | @ -1687,7 +1687,7 @@ class TestAutouseManagement(object): | |||
|             import pytest | ||||
|             import pprint | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
| 
 | ||||
|             @pytest.fixture(scope="function", params=[1,2]) | ||||
|             def farg(request): | ||||
|  | @ -1700,7 +1700,7 @@ class TestAutouseManagement(object): | |||
|             @pytest.fixture(scope="function", autouse=True) | ||||
|             def append(request, farg, carg): | ||||
|                 def fin(): | ||||
|                     l.append("fin_%s%s" % (carg, farg)) | ||||
|                     values.append("fin_%s%s" % (carg, farg)) | ||||
|                 request.addfinalizer(fin) | ||||
|         """) | ||||
|         testdir.makepyfile(""" | ||||
|  | @ -1717,26 +1717,26 @@ class TestAutouseManagement(object): | |||
|         reprec = testdir.inline_run("-v", "-s", confcut) | ||||
|         reprec.assertoutcome(passed=8) | ||||
|         config = reprec.getcalls("pytest_unconfigure")[0].config | ||||
|         l = config.pluginmanager._getconftestmodules(p)[0].l | ||||
|         assert l == ["fin_a1", "fin_a2", "fin_b1", "fin_b2"] * 2 | ||||
|         values = config.pluginmanager._getconftestmodules(p)[0].values | ||||
|         assert values == ["fin_a1", "fin_a2", "fin_b1", "fin_b2"] * 2 | ||||
| 
 | ||||
|     def test_scope_ordering(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(scope="function", autouse=True) | ||||
|             def fappend2(): | ||||
|                 l.append(2) | ||||
|                 values.append(2) | ||||
|             @pytest.fixture(scope="class", autouse=True) | ||||
|             def classappend3(): | ||||
|                 l.append(3) | ||||
|                 values.append(3) | ||||
|             @pytest.fixture(scope="module", autouse=True) | ||||
|             def mappend(): | ||||
|                 l.append(1) | ||||
|                 values.append(1) | ||||
| 
 | ||||
|             class TestHallo(object): | ||||
|                 def test_method(self): | ||||
|                     assert l == [1,3,2] | ||||
|                     assert values == [1,3,2] | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(passed=1) | ||||
|  | @ -1744,23 +1744,23 @@ class TestAutouseManagement(object): | |||
|     def test_parametrization_setup_teardown_ordering(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def pytest_generate_tests(metafunc): | ||||
|                 if metafunc.cls is not None: | ||||
|                     metafunc.parametrize("item", [1,2], scope="class") | ||||
|             class TestClass(object): | ||||
|                 @pytest.fixture(scope="class", autouse=True) | ||||
|                 def addteardown(self, item, request): | ||||
|                     l.append("setup-%d" % item) | ||||
|                     request.addfinalizer(lambda: l.append("teardown-%d" % item)) | ||||
|                     values.append("setup-%d" % item) | ||||
|                     request.addfinalizer(lambda: values.append("teardown-%d" % item)) | ||||
|                 def test_step1(self, item): | ||||
|                     l.append("step1-%d" % item) | ||||
|                     values.append("step1-%d" % item) | ||||
|                 def test_step2(self, item): | ||||
|                     l.append("step2-%d" % item) | ||||
|                     values.append("step2-%d" % item) | ||||
| 
 | ||||
|             def test_finish(): | ||||
|                 print (l) | ||||
|                 assert l == ["setup-1", "step1-1", "step2-1", "teardown-1", | ||||
|                 print (values) | ||||
|                 assert values == ["setup-1", "step1-1", "step2-1", "teardown-1", | ||||
|                              "setup-2", "step1-2", "step2-2", "teardown-2",] | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|  | @ -1770,15 +1770,15 @@ class TestAutouseManagement(object): | |||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(autouse=True) | ||||
|             def fix1(): | ||||
|                 l.append(1) | ||||
|                 values.append(1) | ||||
|             @pytest.fixture() | ||||
|             def arg1(): | ||||
|                 l.append(2) | ||||
|                 values.append(2) | ||||
|             def test_hello(arg1): | ||||
|                 assert l == [1,2] | ||||
|                 assert values == [1,2] | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(passed=1) | ||||
|  | @ -1789,20 +1789,20 @@ class TestAutouseManagement(object): | |||
|     def test_ordering_dependencies_torndown_first(self, testdir, param1, param2): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(%(param1)s) | ||||
|             def arg1(request): | ||||
|                 request.addfinalizer(lambda: l.append("fin1")) | ||||
|                 l.append("new1") | ||||
|                 request.addfinalizer(lambda: values.append("fin1")) | ||||
|                 values.append("new1") | ||||
|             @pytest.fixture(%(param2)s) | ||||
|             def arg2(request, arg1): | ||||
|                 request.addfinalizer(lambda: l.append("fin2")) | ||||
|                 l.append("new2") | ||||
|                 request.addfinalizer(lambda: values.append("fin2")) | ||||
|                 values.append("new2") | ||||
| 
 | ||||
|             def test_arg(arg2): | ||||
|                 pass | ||||
|             def test_check(): | ||||
|                 assert l == ["new1", "new2", "fin2", "fin1"] | ||||
|                 assert values == ["new1", "new2", "fin2", "fin1"] | ||||
|         """ % locals()) | ||||
|         reprec = testdir.inline_run("-s") | ||||
|         reprec.assertoutcome(passed=2) | ||||
|  | @ -1815,11 +1815,11 @@ class TestFixtureMarker(object): | |||
|             @pytest.fixture(params=["a", "b", "c"]) | ||||
|             def arg(request): | ||||
|                 return request.param | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def test_param(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|             def test_result(): | ||||
|                 assert l == list("abc") | ||||
|                 assert values == list("abc") | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(passed=4) | ||||
|  | @ -1863,21 +1863,21 @@ class TestFixtureMarker(object): | |||
|     def test_scope_session(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(scope="module") | ||||
|             def arg(): | ||||
|                 l.append(1) | ||||
|                 values.append(1) | ||||
|                 return 1 | ||||
| 
 | ||||
|             def test_1(arg): | ||||
|                 assert arg == 1 | ||||
|             def test_2(arg): | ||||
|                 assert arg == 1 | ||||
|                 assert len(l) == 1 | ||||
|                 assert len(values) == 1 | ||||
|             class TestClass(object): | ||||
|                 def test3(self, arg): | ||||
|                     assert arg == 1 | ||||
|                     assert len(l) == 1 | ||||
|                     assert len(values) == 1 | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(passed=3) | ||||
|  | @ -1885,10 +1885,10 @@ class TestFixtureMarker(object): | |||
|     def test_scope_session_exc(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(scope="session") | ||||
|             def fix(): | ||||
|                 l.append(1) | ||||
|                 values.append(1) | ||||
|                 pytest.skip('skipping') | ||||
| 
 | ||||
|             def test_1(fix): | ||||
|  | @ -1896,7 +1896,7 @@ class TestFixtureMarker(object): | |||
|             def test_2(fix): | ||||
|                 pass | ||||
|             def test_last(): | ||||
|                 assert l == [1] | ||||
|                 assert values == [1] | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(skipped=2, passed=1) | ||||
|  | @ -1904,11 +1904,11 @@ class TestFixtureMarker(object): | |||
|     def test_scope_session_exc_two_fix(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             m = [] | ||||
|             @pytest.fixture(scope="session") | ||||
|             def a(): | ||||
|                 l.append(1) | ||||
|                 values.append(1) | ||||
|                 pytest.skip('skipping') | ||||
|             @pytest.fixture(scope="session") | ||||
|             def b(a): | ||||
|  | @ -1919,7 +1919,7 @@ class TestFixtureMarker(object): | |||
|             def test_2(b): | ||||
|                 pass | ||||
|             def test_last(): | ||||
|                 assert l == [1] | ||||
|                 assert values == [1] | ||||
|                 assert m == [] | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|  | @ -1957,21 +1957,21 @@ class TestFixtureMarker(object): | |||
|     def test_scope_module_uses_session(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(scope="module") | ||||
|             def arg(): | ||||
|                 l.append(1) | ||||
|                 values.append(1) | ||||
|                 return 1 | ||||
| 
 | ||||
|             def test_1(arg): | ||||
|                 assert arg == 1 | ||||
|             def test_2(arg): | ||||
|                 assert arg == 1 | ||||
|                 assert len(l) == 1 | ||||
|                 assert len(values) == 1 | ||||
|             class TestClass(object): | ||||
|                 def test3(self, arg): | ||||
|                     assert arg == 1 | ||||
|                     assert len(l) == 1 | ||||
|                     assert len(values) == 1 | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(passed=3) | ||||
|  | @ -2066,17 +2066,17 @@ class TestFixtureMarker(object): | |||
|             @pytest.fixture(scope="module", params=["a", "b", "c"]) | ||||
|             def arg(request): | ||||
|                 return request.param | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def test_param(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-v") | ||||
|         reprec.assertoutcome(passed=3) | ||||
|         l = reprec.getcalls("pytest_runtest_call")[0].item.module.l | ||||
|         assert len(l) == 3 | ||||
|         assert "a" in l | ||||
|         assert "b" in l | ||||
|         assert "c" in l | ||||
|         values = reprec.getcalls("pytest_runtest_call")[0].item.module.values | ||||
|         assert len(values) == 3 | ||||
|         assert "a" in values | ||||
|         assert "b" in values | ||||
|         assert "c" in values | ||||
| 
 | ||||
|     def test_scope_mismatch(self, testdir): | ||||
|         testdir.makeconftest(""" | ||||
|  | @ -2107,16 +2107,16 @@ class TestFixtureMarker(object): | |||
|             def arg(request): | ||||
|                 return request.param | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def test_1(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|             def test_2(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-v") | ||||
|         reprec.assertoutcome(passed=4) | ||||
|         l = reprec.getcalls("pytest_runtest_call")[0].item.module.l | ||||
|         assert l == [1, 1, 2, 2] | ||||
|         values = reprec.getcalls("pytest_runtest_call")[0].item.module.values | ||||
|         assert values == [1, 1, 2, 2] | ||||
| 
 | ||||
|     def test_module_parametrized_ordering(self, testdir): | ||||
|         testdir.makeconftest(""" | ||||
|  | @ -2168,7 +2168,7 @@ class TestFixtureMarker(object): | |||
|         testdir.makeconftest(""" | ||||
|             import pytest | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
| 
 | ||||
|             @pytest.fixture(scope="function", params=[1,2]) | ||||
|             def farg(request): | ||||
|  | @ -2181,7 +2181,7 @@ class TestFixtureMarker(object): | |||
|             @pytest.fixture(scope="function", autouse=True) | ||||
|             def append(request, farg, carg): | ||||
|                 def fin(): | ||||
|                     l.append("fin_%s%s" % (carg, farg)) | ||||
|                     values.append("fin_%s%s" % (carg, farg)) | ||||
|                 request.addfinalizer(fin) | ||||
|         """) | ||||
|         testdir.makepyfile(""" | ||||
|  | @ -2219,30 +2219,30 @@ class TestFixtureMarker(object): | |||
|             @pytest.fixture(scope="function", params=[1, 2]) | ||||
|             def arg(request): | ||||
|                 param = request.param | ||||
|                 request.addfinalizer(lambda: l.append("fin:%s" % param)) | ||||
|                 l.append("create:%s" % param) | ||||
|                 request.addfinalizer(lambda: values.append("fin:%s" % param)) | ||||
|                 values.append("create:%s" % param) | ||||
|                 return request.param | ||||
| 
 | ||||
|             @pytest.fixture(scope="module", params=["mod1", "mod2"]) | ||||
|             def modarg(request): | ||||
|                 param = request.param | ||||
|                 request.addfinalizer(lambda: l.append("fin:%s" % param)) | ||||
|                 l.append("create:%s" % param) | ||||
|                 request.addfinalizer(lambda: values.append("fin:%s" % param)) | ||||
|                 values.append("create:%s" % param) | ||||
|                 return request.param | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def test_1(arg): | ||||
|                 l.append("test1") | ||||
|                 values.append("test1") | ||||
|             def test_2(modarg): | ||||
|                 l.append("test2") | ||||
|                 values.append("test2") | ||||
|             def test_3(arg, modarg): | ||||
|                 l.append("test3") | ||||
|                 values.append("test3") | ||||
|             def test_4(modarg, arg): | ||||
|                 l.append("test4") | ||||
|                 values.append("test4") | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-v") | ||||
|         reprec.assertoutcome(passed=12) | ||||
|         l = reprec.getcalls("pytest_runtest_call")[0].item.module.l | ||||
|         values = reprec.getcalls("pytest_runtest_call")[0].item.module.values | ||||
|         expected = [ | ||||
|             'create:1', 'test1', 'fin:1', 'create:2', 'test1', | ||||
|             'fin:2', 'create:mod1', 'test2', 'create:1', 'test3', | ||||
|  | @ -2253,8 +2253,8 @@ class TestFixtureMarker(object): | |||
|             'test4', 'fin:1', 'create:2', 'test4', 'fin:2', | ||||
|             'fin:mod2'] | ||||
|         import pprint | ||||
|         pprint.pprint(list(zip(l, expected))) | ||||
|         assert l == expected | ||||
|         pprint.pprint(list(zip(values, expected))) | ||||
|         assert values == expected | ||||
| 
 | ||||
|     def test_parametrized_fixture_teardown_order(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|  | @ -2263,29 +2263,29 @@ class TestFixtureMarker(object): | |||
|             def param1(request): | ||||
|                 return request.param | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
| 
 | ||||
|             class TestClass(object): | ||||
|                 @classmethod | ||||
|                 @pytest.fixture(scope="class", autouse=True) | ||||
|                 def setup1(self, request, param1): | ||||
|                     l.append(1) | ||||
|                     values.append(1) | ||||
|                     request.addfinalizer(self.teardown1) | ||||
|                 @classmethod | ||||
|                 def teardown1(self): | ||||
|                     assert l.pop() == 1 | ||||
|                     assert values.pop() == 1 | ||||
|                 @pytest.fixture(scope="class", autouse=True) | ||||
|                 def setup2(self, request, param1): | ||||
|                     l.append(2) | ||||
|                     values.append(2) | ||||
|                     request.addfinalizer(self.teardown2) | ||||
|                 @classmethod | ||||
|                 def teardown2(self): | ||||
|                     assert l.pop() == 2 | ||||
|                     assert values.pop() == 2 | ||||
|                 def test(self): | ||||
|                     pass | ||||
| 
 | ||||
|             def test_finish(): | ||||
|                 assert not l | ||||
|                 assert not values | ||||
|         """) | ||||
|         result = testdir.runpytest("-v") | ||||
|         result.stdout.fnmatch_lines(""" | ||||
|  | @ -2350,42 +2350,42 @@ class TestFixtureMarker(object): | |||
|     def test_request_is_clean(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(params=[1, 2]) | ||||
|             def fix(request): | ||||
|                 request.addfinalizer(lambda: l.append(request.param)) | ||||
|                 request.addfinalizer(lambda: values.append(request.param)) | ||||
|             def test_fix(fix): | ||||
|                 pass | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-s") | ||||
|         l = reprec.getcalls("pytest_runtest_call")[0].item.module.l | ||||
|         assert l == [1, 2] | ||||
|         values = reprec.getcalls("pytest_runtest_call")[0].item.module.values | ||||
|         assert values == [1, 2] | ||||
| 
 | ||||
|     def test_parametrize_separated_lifecycle(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(scope="module", params=[1, 2]) | ||||
|             def arg(request): | ||||
|                 x = request.param | ||||
|                 request.addfinalizer(lambda: l.append("fin%s" % x)) | ||||
|                 request.addfinalizer(lambda: values.append("fin%s" % x)) | ||||
|                 return request.param | ||||
|             def test_1(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|             def test_2(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-vs") | ||||
|         reprec.assertoutcome(passed=4) | ||||
|         l = reprec.getcalls("pytest_runtest_call")[0].item.module.l | ||||
|         values = reprec.getcalls("pytest_runtest_call")[0].item.module.values | ||||
|         import pprint | ||||
|         pprint.pprint(l) | ||||
|         # assert len(l) == 6 | ||||
|         assert l[0] == l[1] == 1 | ||||
|         assert l[2] == "fin1" | ||||
|         assert l[3] == l[4] == 2 | ||||
|         assert l[5] == "fin2" | ||||
|         pprint.pprint(values) | ||||
|         # assert len(values) == 6 | ||||
|         assert values[0] == values[1] == 1 | ||||
|         assert values[2] == "fin1" | ||||
|         assert values[3] == values[4] == 2 | ||||
|         assert values[5] == "fin2" | ||||
| 
 | ||||
|     def test_parametrize_function_scoped_finalizers_called(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|  | @ -2394,17 +2394,17 @@ class TestFixtureMarker(object): | |||
|             @pytest.fixture(scope="function", params=[1, 2]) | ||||
|             def arg(request): | ||||
|                 x = request.param | ||||
|                 request.addfinalizer(lambda: l.append("fin%s" % x)) | ||||
|                 request.addfinalizer(lambda: values.append("fin%s" % x)) | ||||
|                 return request.param | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def test_1(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|             def test_2(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|             def test_3(): | ||||
|                 assert len(l) == 8 | ||||
|                 assert l == [1, "fin1", 2, "fin2", 1, "fin1", 2, "fin2"] | ||||
|                 assert len(values) == 8 | ||||
|                 assert values == [1, "fin1", 2, "fin2", 1, "fin1", 2, "fin2"] | ||||
|         """) | ||||
|         reprec = testdir.inline_run("-v") | ||||
|         reprec.assertoutcome(passed=5) | ||||
|  | @ -2414,7 +2414,7 @@ class TestFixtureMarker(object): | |||
|     def test_finalizer_order_on_parametrization(self, scope, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
| 
 | ||||
|             @pytest.fixture(scope=%(scope)r, params=["1"]) | ||||
|             def fix1(request): | ||||
|  | @ -2423,13 +2423,13 @@ class TestFixtureMarker(object): | |||
|             @pytest.fixture(scope=%(scope)r) | ||||
|             def fix2(request, base): | ||||
|                 def cleanup_fix2(): | ||||
|                     assert not l, "base should not have been finalized" | ||||
|                     assert not values, "base should not have been finalized" | ||||
|                 request.addfinalizer(cleanup_fix2) | ||||
| 
 | ||||
|             @pytest.fixture(scope=%(scope)r) | ||||
|             def base(request, fix1): | ||||
|                 def cleanup_base(): | ||||
|                     l.append("fin_base") | ||||
|                     values.append("fin_base") | ||||
|                     print ("finalizing base") | ||||
|                 request.addfinalizer(cleanup_base) | ||||
| 
 | ||||
|  | @ -2447,27 +2447,27 @@ class TestFixtureMarker(object): | |||
|     def test_class_scope_parametrization_ordering(self, testdir): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             @pytest.fixture(params=["John", "Doe"], scope="class") | ||||
|             def human(request): | ||||
|                 request.addfinalizer(lambda: l.append("fin %s" % request.param)) | ||||
|                 request.addfinalizer(lambda: values.append("fin %s" % request.param)) | ||||
|                 return request.param | ||||
| 
 | ||||
|             class TestGreetings(object): | ||||
|                 def test_hello(self, human): | ||||
|                     l.append("test_hello") | ||||
|                     values.append("test_hello") | ||||
| 
 | ||||
|             class TestMetrics(object): | ||||
|                 def test_name(self, human): | ||||
|                     l.append("test_name") | ||||
|                     values.append("test_name") | ||||
| 
 | ||||
|                 def test_population(self, human): | ||||
|                     l.append("test_population") | ||||
|                     values.append("test_population") | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(passed=6) | ||||
|         l = reprec.getcalls("pytest_runtest_call")[0].item.module.l | ||||
|         assert l == ["test_hello", "fin John", "test_hello", "fin Doe", | ||||
|         values = reprec.getcalls("pytest_runtest_call")[0].item.module.values | ||||
|         assert values == ["test_hello", "fin John", "test_hello", "fin Doe", | ||||
|                           "test_name", "test_population", "fin John", | ||||
|                           "test_name", "test_population", "fin Doe"] | ||||
| 
 | ||||
|  | @ -2481,21 +2481,21 @@ class TestFixtureMarker(object): | |||
| 
 | ||||
|             @pytest.fixture(scope="module", autouse=True) | ||||
|             def mysetup(request, arg): | ||||
|                 request.addfinalizer(lambda: l.append("fin%s" % arg)) | ||||
|                 l.append("setup%s" % arg) | ||||
|                 request.addfinalizer(lambda: values.append("fin%s" % arg)) | ||||
|                 values.append("setup%s" % arg) | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def test_1(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|             def test_2(arg): | ||||
|                 l.append(arg) | ||||
|                 values.append(arg) | ||||
|             def test_3(): | ||||
|                 import pprint | ||||
|                 pprint.pprint(l) | ||||
|                 pprint.pprint(values) | ||||
|                 if arg == 1: | ||||
|                     assert l == ["setup1", 1, 1, ] | ||||
|                     assert values == ["setup1", 1, 1, ] | ||||
|                 elif arg == 2: | ||||
|                     assert l == ["setup1", 1, 1, "fin1", | ||||
|                     assert values == ["setup1", 1, 1, "fin1", | ||||
|                                  "setup2", 2, 2, ] | ||||
| 
 | ||||
|         """) | ||||
|  | @ -2656,13 +2656,13 @@ class TestErrors(object): | |||
|                 request.addfinalizer(f) | ||||
|                 return object() | ||||
| 
 | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def test_1(fix1): | ||||
|                 l.append(fix1) | ||||
|                 values.append(fix1) | ||||
|             def test_2(fix1): | ||||
|                 l.append(fix1) | ||||
|                 values.append(fix1) | ||||
|             def test_3(): | ||||
|                 assert l[0] != l[1] | ||||
|                 assert values[0] != values[1] | ||||
|         """) | ||||
|         result = testdir.runpytest() | ||||
|         result.stdout.fnmatch_lines(""" | ||||
|  |  | |||
|  | @ -93,8 +93,8 @@ class TestMockDecoration(object): | |||
|         def f(x): | ||||
|             pass | ||||
| 
 | ||||
|         l = getfuncargnames(f) | ||||
|         assert l == ("x",) | ||||
|         values = getfuncargnames(f) | ||||
|         assert values == ("x",) | ||||
| 
 | ||||
|     def test_wrapped_getfuncargnames_patching(self): | ||||
|         from _pytest.compat import getfuncargnames | ||||
|  | @ -110,8 +110,8 @@ class TestMockDecoration(object): | |||
|         def f(x, y, z): | ||||
|             pass | ||||
| 
 | ||||
|         l = getfuncargnames(f) | ||||
|         assert l == ("y", "z") | ||||
|         values = getfuncargnames(f) | ||||
|         assert values == ("y", "z") | ||||
| 
 | ||||
|     def test_unittest_mock(self, testdir): | ||||
|         pytest.importorskip("unittest.mock") | ||||
|  |  | |||
|  | @ -1071,21 +1071,21 @@ class TestMetafuncFunctional(object): | |||
|     def test_parametrize_scope_overrides(self, testdir, scope, length): | ||||
|         testdir.makepyfile(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def pytest_generate_tests(metafunc): | ||||
|                 if "arg" in metafunc.funcargnames: | ||||
|                     metafunc.parametrize("arg", [1,2], indirect=True, | ||||
|                                          scope=%r) | ||||
|             @pytest.fixture | ||||
|             def arg(request): | ||||
|                 l.append(request.param) | ||||
|                 values.append(request.param) | ||||
|                 return request.param | ||||
|             def test_hello(arg): | ||||
|                 assert arg in (1,2) | ||||
|             def test_world(arg): | ||||
|                 assert arg in (1,2) | ||||
|             def test_checklength(): | ||||
|                 assert len(l) == %d | ||||
|                 assert len(values) == %d | ||||
|         """ % (scope, length)) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(passed=5) | ||||
|  |  | |||
|  | @ -229,9 +229,9 @@ class TestImportHookInstallation(object): | |||
|                     return pkg.helper.tool | ||||
|             """, | ||||
|             'pkg/other.py': """ | ||||
|                 l = [3, 2] | ||||
|                 values = [3, 2] | ||||
|                 def tool(): | ||||
|                     assert l.pop() == 3 | ||||
|                     assert values.pop() == 3 | ||||
|             """, | ||||
|             'conftest.py': """ | ||||
|                 pytest_plugins = ['pkg.plugin'] | ||||
|  | @ -248,7 +248,7 @@ class TestImportHookInstallation(object): | |||
|         result = testdir.runpytest_subprocess('--assert=rewrite') | ||||
|         result.stdout.fnmatch_lines(['>*assert a == b*', | ||||
|                                      'E*assert 2 == 3*', | ||||
|                                      '>*assert l.pop() == 3*', | ||||
|                                      '>*assert values.pop() == 3*', | ||||
|                                      'E*AssertionError']) | ||||
| 
 | ||||
|     def test_register_assert_rewrite_checks_types(self): | ||||
|  | @ -263,13 +263,13 @@ class TestBinReprIntegration(object): | |||
|     def test_pytest_assertrepr_compare_called(self, testdir): | ||||
|         testdir.makeconftest(""" | ||||
|             import pytest | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def pytest_assertrepr_compare(op, left, right): | ||||
|                 l.append((op, left, right)) | ||||
|                 values.append((op, left, right)) | ||||
| 
 | ||||
|             @pytest.fixture | ||||
|             def list(request): | ||||
|                 return l | ||||
|                 return values | ||||
|         """) | ||||
|         testdir.makepyfile(""" | ||||
|             def test_hello(): | ||||
|  |  | |||
|  | @ -473,8 +473,8 @@ class TestAssertionRewrite(object): | |||
|     def test_len(self): | ||||
| 
 | ||||
|         def f(): | ||||
|             l = list(range(10)) | ||||
|             assert len(l) == 11 | ||||
|             values = list(range(10)) | ||||
|             assert len(values) == 11 | ||||
| 
 | ||||
|         assert getmsg(f).startswith("""assert 10 == 11 | ||||
|  +  where 10 = len([""") | ||||
|  |  | |||
|  | @ -704,9 +704,9 @@ class TestNodekeywords(object): | |||
|             def test_pass(): pass | ||||
|             def test_fail(): assert 0 | ||||
|         """) | ||||
|         l = list(modcol.keywords) | ||||
|         assert modcol.name in l | ||||
|         for x in l: | ||||
|         values = list(modcol.keywords) | ||||
|         assert modcol.name in values | ||||
|         for x in values: | ||||
|             assert not x.startswith("_") | ||||
|         assert modcol.name in repr(modcol.keywords) | ||||
| 
 | ||||
|  |  | |||
|  | @ -123,11 +123,11 @@ class TestConfigCmdlineParsing(object): | |||
| class TestConfigAPI(object): | ||||
|     def test_config_trace(self, testdir): | ||||
|         config = testdir.parseconfig() | ||||
|         l = [] | ||||
|         config.trace.root.setwriter(l.append) | ||||
|         values = [] | ||||
|         config.trace.root.setwriter(values.append) | ||||
|         config.trace("hello") | ||||
|         assert len(l) == 1 | ||||
|         assert l[0] == "hello [config]\n" | ||||
|         assert len(values) == 1 | ||||
|         assert values[0] == "hello [config]\n" | ||||
| 
 | ||||
|     def test_config_getoption(self, testdir): | ||||
|         testdir.makeconftest(""" | ||||
|  | @ -209,10 +209,10 @@ class TestConfigAPI(object): | |||
|             paths=hello world/sub.py | ||||
|         """) | ||||
|         config = testdir.parseconfig() | ||||
|         l = config.getini("paths") | ||||
|         assert len(l) == 2 | ||||
|         assert l[0] == p.dirpath('hello') | ||||
|         assert l[1] == p.dirpath('world/sub.py') | ||||
|         values = config.getini("paths") | ||||
|         assert len(values) == 2 | ||||
|         assert values[0] == p.dirpath('hello') | ||||
|         assert values[1] == p.dirpath('world/sub.py') | ||||
|         pytest.raises(ValueError, config.getini, 'other') | ||||
| 
 | ||||
|     def test_addini_args(self, testdir): | ||||
|  | @ -226,11 +226,11 @@ class TestConfigAPI(object): | |||
|             args=123 "123 hello" "this" | ||||
|         """) | ||||
|         config = testdir.parseconfig() | ||||
|         l = config.getini("args") | ||||
|         assert len(l) == 3 | ||||
|         assert l == ["123", "123 hello", "this"] | ||||
|         l = config.getini("a2") | ||||
|         assert l == list("123") | ||||
|         values = config.getini("args") | ||||
|         assert len(values) == 3 | ||||
|         assert values == ["123", "123 hello", "this"] | ||||
|         values = config.getini("a2") | ||||
|         assert values == list("123") | ||||
| 
 | ||||
|     def test_addini_linelist(self, testdir): | ||||
|         testdir.makeconftest(""" | ||||
|  | @ -244,11 +244,11 @@ class TestConfigAPI(object): | |||
|                 second line | ||||
|         """) | ||||
|         config = testdir.parseconfig() | ||||
|         l = config.getini("xy") | ||||
|         assert len(l) == 2 | ||||
|         assert l == ["123 345", "second line"] | ||||
|         l = config.getini("a2") | ||||
|         assert l == [] | ||||
|         values = config.getini("xy") | ||||
|         assert len(values) == 2 | ||||
|         assert values == ["123 345", "second line"] | ||||
|         values = config.getini("a2") | ||||
|         assert values == [] | ||||
| 
 | ||||
|     @pytest.mark.parametrize('str_val, bool_val', | ||||
|                              [('True', True), ('no', False), ('no-ini', True)]) | ||||
|  | @ -275,13 +275,13 @@ class TestConfigAPI(object): | |||
|             xy= 123 | ||||
|         """) | ||||
|         config = testdir.parseconfig() | ||||
|         l = config.getini("xy") | ||||
|         assert len(l) == 1 | ||||
|         assert l == ["123"] | ||||
|         values = config.getini("xy") | ||||
|         assert len(values) == 1 | ||||
|         assert values == ["123"] | ||||
|         config.addinivalue_line("xy", "456") | ||||
|         l = config.getini("xy") | ||||
|         assert len(l) == 2 | ||||
|         assert l == ["123", "456"] | ||||
|         values = config.getini("xy") | ||||
|         assert len(values) == 2 | ||||
|         assert values == ["123", "456"] | ||||
| 
 | ||||
|     def test_addinivalue_line_new(self, testdir): | ||||
|         testdir.makeconftest(""" | ||||
|  | @ -291,13 +291,13 @@ class TestConfigAPI(object): | |||
|         config = testdir.parseconfig() | ||||
|         assert not config.getini("xy") | ||||
|         config.addinivalue_line("xy", "456") | ||||
|         l = config.getini("xy") | ||||
|         assert len(l) == 1 | ||||
|         assert l == ["456"] | ||||
|         values = config.getini("xy") | ||||
|         assert len(values) == 1 | ||||
|         assert values == ["456"] | ||||
|         config.addinivalue_line("xy", "123") | ||||
|         l = config.getini("xy") | ||||
|         assert len(l) == 2 | ||||
|         assert l == ["456", "123"] | ||||
|         values = config.getini("xy") | ||||
|         assert len(values) == 2 | ||||
|         assert values == ["456", "123"] | ||||
| 
 | ||||
|     def test_confcutdir_check_isdir(self, testdir): | ||||
|         """Give an error if --confcutdir is not a valid directory (#2078)""" | ||||
|  | @ -596,13 +596,13 @@ def test_load_initial_conftest_last_ordering(testdir): | |||
|     m = My() | ||||
|     pm.register(m) | ||||
|     hc = pm.hook.pytest_load_initial_conftests | ||||
|     l = hc._nonwrappers + hc._wrappers | ||||
|     values = hc._nonwrappers + hc._wrappers | ||||
|     expected = [ | ||||
|         "_pytest.config", | ||||
|         'test_config', | ||||
|         '_pytest.capture', | ||||
|     ] | ||||
|     assert [x.function.__module__ for x in l] == expected | ||||
|     assert [x.function.__module__ for x in values] == expected | ||||
| 
 | ||||
| 
 | ||||
| def test_get_plugin_specs_as_list(): | ||||
|  | @ -623,17 +623,17 @@ def test_get_plugin_specs_as_list(): | |||
| class TestWarning(object): | ||||
|     def test_warn_config(self, testdir): | ||||
|         testdir.makeconftest(""" | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def pytest_configure(config): | ||||
|                 config.warn("C1", "hello") | ||||
|             def pytest_logwarning(code, message): | ||||
|                 if message == "hello" and code == "C1": | ||||
|                     l.append(1) | ||||
|                     values.append(1) | ||||
|         """) | ||||
|         testdir.makepyfile(""" | ||||
|             def test_proper(pytestconfig): | ||||
|                 import conftest | ||||
|                 assert conftest.l == [1] | ||||
|                 assert conftest.values == [1] | ||||
|         """) | ||||
|         reprec = testdir.inline_run() | ||||
|         reprec.assertoutcome(passed=1) | ||||
|  |  | |||
|  | @ -87,8 +87,8 @@ def test_doubledash_considered(testdir): | |||
|     conf.join("conftest.py").ensure() | ||||
|     conftest = PytestPluginManager() | ||||
|     conftest_setinitial(conftest, [conf.basename, conf.basename]) | ||||
|     l = conftest._getconftestmodules(conf) | ||||
|     assert len(l) == 1 | ||||
|     values = conftest._getconftestmodules(conf) | ||||
|     assert len(values) == 1 | ||||
| 
 | ||||
| 
 | ||||
| def test_issue151_load_all_conftests(testdir): | ||||
|  | @ -130,28 +130,28 @@ def test_conftestcutdir(testdir): | |||
|     p = testdir.mkdir("x") | ||||
|     conftest = PytestPluginManager() | ||||
|     conftest_setinitial(conftest, [testdir.tmpdir], confcutdir=p) | ||||
|     l = conftest._getconftestmodules(p) | ||||
|     assert len(l) == 0 | ||||
|     l = conftest._getconftestmodules(conf.dirpath()) | ||||
|     assert len(l) == 0 | ||||
|     values = conftest._getconftestmodules(p) | ||||
|     assert len(values) == 0 | ||||
|     values = conftest._getconftestmodules(conf.dirpath()) | ||||
|     assert len(values) == 0 | ||||
|     assert conf not in conftest._conftestpath2mod | ||||
|     # but we can still import a conftest directly | ||||
|     conftest._importconftest(conf) | ||||
|     l = conftest._getconftestmodules(conf.dirpath()) | ||||
|     assert l[0].__file__.startswith(str(conf)) | ||||
|     values = conftest._getconftestmodules(conf.dirpath()) | ||||
|     assert values[0].__file__.startswith(str(conf)) | ||||
|     # and all sub paths get updated properly | ||||
|     l = conftest._getconftestmodules(p) | ||||
|     assert len(l) == 1 | ||||
|     assert l[0].__file__.startswith(str(conf)) | ||||
|     values = conftest._getconftestmodules(p) | ||||
|     assert len(values) == 1 | ||||
|     assert values[0].__file__.startswith(str(conf)) | ||||
| 
 | ||||
| 
 | ||||
| def test_conftestcutdir_inplace_considered(testdir): | ||||
|     conf = testdir.makeconftest("") | ||||
|     conftest = PytestPluginManager() | ||||
|     conftest_setinitial(conftest, [conf.dirpath()], confcutdir=conf.dirpath()) | ||||
|     l = conftest._getconftestmodules(conf.dirpath()) | ||||
|     assert len(l) == 1 | ||||
|     assert l[0].__file__.startswith(str(conf)) | ||||
|     values = conftest._getconftestmodules(conf.dirpath()) | ||||
|     assert len(values) == 1 | ||||
|     assert values[0].__file__.startswith(str(conf)) | ||||
| 
 | ||||
| 
 | ||||
| @pytest.mark.parametrize("name", 'test tests whatever .dotdir'.split()) | ||||
|  |  | |||
|  | @ -468,11 +468,11 @@ class TestFunctional(object): | |||
|         assert marker.kwargs == {'x': 1, 'y': 2, 'z': 4} | ||||
| 
 | ||||
|         # test the new __iter__ interface | ||||
|         l = list(marker) | ||||
|         assert len(l) == 3 | ||||
|         assert l[0].args == ("pos0",) | ||||
|         assert l[1].args == () | ||||
|         assert l[2].args == ("pos1", ) | ||||
|         values = list(marker) | ||||
|         assert len(values) == 3 | ||||
|         assert values[0].args == ("pos0",) | ||||
|         assert values[1].args == () | ||||
|         assert values[2].args == ("pos1", ) | ||||
| 
 | ||||
|     @pytest.mark.xfail(reason='unfixed') | ||||
|     def test_merging_markers_deep(self, testdir): | ||||
|  | @ -564,9 +564,9 @@ class TestFunctional(object): | |||
|                 def test_func(): | ||||
|                     pass | ||||
|         """) | ||||
|         l = reprec.getfailedcollections() | ||||
|         assert len(l) == 1 | ||||
|         assert "TypeError" in str(l[0].longrepr) | ||||
|         values = reprec.getfailedcollections() | ||||
|         assert len(values) == 1 | ||||
|         assert "TypeError" in str(values[0].longrepr) | ||||
| 
 | ||||
|     def test_mark_dynamically_in_funcarg(self, testdir): | ||||
|         testdir.makeconftest(""" | ||||
|  | @ -575,8 +575,8 @@ class TestFunctional(object): | |||
|             def arg(request): | ||||
|                 request.applymarker(pytest.mark.hello) | ||||
|             def pytest_terminal_summary(terminalreporter): | ||||
|                 l = terminalreporter.stats['passed'] | ||||
|                 terminalreporter.writer.line("keyword: %s" % l[0].keywords) | ||||
|                 values = terminalreporter.stats['passed'] | ||||
|                 terminalreporter.writer.line("keyword: %s" % values[0].keywords) | ||||
|         """) | ||||
|         testdir.makepyfile(""" | ||||
|             def test_func(arg): | ||||
|  | @ -599,10 +599,10 @@ class TestFunctional(object): | |||
|         item, = items | ||||
|         keywords = item.keywords | ||||
|         marker = keywords['hello'] | ||||
|         l = list(marker) | ||||
|         assert len(l) == 2 | ||||
|         assert l[0].args == ("pos0",) | ||||
|         assert l[1].args == ("pos1",) | ||||
|         values = list(marker) | ||||
|         assert len(values) == 2 | ||||
|         assert values[0].args == ("pos0",) | ||||
|         assert values[1].args == ("pos1",) | ||||
| 
 | ||||
|     def test_no_marker_match_on_unmarked_names(self, testdir): | ||||
|         p = testdir.makepyfile(""" | ||||
|  |  | |||
|  | @ -8,18 +8,18 @@ def setup_module(mod): | |||
| 
 | ||||
| def test_nose_setup(testdir): | ||||
|     p = testdir.makepyfile(""" | ||||
|         l = [] | ||||
|         values = [] | ||||
|         from nose.tools import with_setup | ||||
| 
 | ||||
|         @with_setup(lambda: l.append(1), lambda: l.append(2)) | ||||
|         @with_setup(lambda: values.append(1), lambda: values.append(2)) | ||||
|         def test_hello(): | ||||
|             assert l == [1] | ||||
|             assert values == [1] | ||||
| 
 | ||||
|         def test_world(): | ||||
|             assert l == [1,2] | ||||
|             assert values == [1,2] | ||||
| 
 | ||||
|         test_hello.setup = lambda: l.append(1) | ||||
|         test_hello.teardown = lambda: l.append(2) | ||||
|         test_hello.setup = lambda: values.append(1) | ||||
|         test_hello.teardown = lambda: values.append(2) | ||||
|     """) | ||||
|     result = testdir.runpytest(p, '-p', 'nose') | ||||
|     result.assert_outcomes(passed=2) | ||||
|  | @ -27,15 +27,15 @@ def test_nose_setup(testdir): | |||
| 
 | ||||
| def test_setup_func_with_setup_decorator(): | ||||
|     from _pytest.nose import call_optional | ||||
|     l = [] | ||||
|     values = [] | ||||
| 
 | ||||
|     class A(object): | ||||
|         @pytest.fixture(autouse=True) | ||||
|         def f(self): | ||||
|             l.append(1) | ||||
|             values.append(1) | ||||
| 
 | ||||
|     call_optional(A(), "f") | ||||
|     assert not l | ||||
|     assert not values | ||||
| 
 | ||||
| 
 | ||||
| def test_setup_func_not_callable(): | ||||
|  | @ -51,24 +51,24 @@ def test_nose_setup_func(testdir): | |||
|     p = testdir.makepyfile(""" | ||||
|         from nose.tools import with_setup | ||||
| 
 | ||||
|         l = [] | ||||
|         values = [] | ||||
| 
 | ||||
|         def my_setup(): | ||||
|             a = 1 | ||||
|             l.append(a) | ||||
|             values.append(a) | ||||
| 
 | ||||
|         def my_teardown(): | ||||
|             b = 2 | ||||
|             l.append(b) | ||||
|             values.append(b) | ||||
| 
 | ||||
|         @with_setup(my_setup, my_teardown) | ||||
|         def test_hello(): | ||||
|             print (l) | ||||
|             assert l == [1] | ||||
|             print (values) | ||||
|             assert values == [1] | ||||
| 
 | ||||
|         def test_world(): | ||||
|             print (l) | ||||
|             assert l == [1,2] | ||||
|             print (values) | ||||
|             assert values == [1,2] | ||||
| 
 | ||||
|     """) | ||||
|     result = testdir.runpytest(p, '-p', 'nose') | ||||
|  | @ -79,18 +79,18 @@ def test_nose_setup_func_failure(testdir): | |||
|     p = testdir.makepyfile(""" | ||||
|         from nose.tools import with_setup | ||||
| 
 | ||||
|         l = [] | ||||
|         values = [] | ||||
|         my_setup = lambda x: 1 | ||||
|         my_teardown = lambda x: 2 | ||||
| 
 | ||||
|         @with_setup(my_setup, my_teardown) | ||||
|         def test_hello(): | ||||
|             print (l) | ||||
|             assert l == [1] | ||||
|             print (values) | ||||
|             assert values == [1] | ||||
| 
 | ||||
|         def test_world(): | ||||
|             print (l) | ||||
|             assert l == [1,2] | ||||
|             print (values) | ||||
|             assert values == [1,2] | ||||
| 
 | ||||
|     """) | ||||
|     result = testdir.runpytest(p, '-p', 'nose') | ||||
|  | @ -101,13 +101,13 @@ def test_nose_setup_func_failure(testdir): | |||
| 
 | ||||
| def test_nose_setup_func_failure_2(testdir): | ||||
|     testdir.makepyfile(""" | ||||
|         l = [] | ||||
|         values = [] | ||||
| 
 | ||||
|         my_setup = 1 | ||||
|         my_teardown = 2 | ||||
| 
 | ||||
|         def test_hello(): | ||||
|             assert l == [] | ||||
|             assert values == [] | ||||
| 
 | ||||
|         test_hello.setup = my_setup | ||||
|         test_hello.teardown = my_teardown | ||||
|  | @ -121,26 +121,26 @@ def test_nose_setup_partial(testdir): | |||
|     p = testdir.makepyfile(""" | ||||
|         from functools import partial | ||||
| 
 | ||||
|         l = [] | ||||
|         values = [] | ||||
| 
 | ||||
|         def my_setup(x): | ||||
|             a = x | ||||
|             l.append(a) | ||||
|             values.append(a) | ||||
| 
 | ||||
|         def my_teardown(x): | ||||
|             b = x | ||||
|             l.append(b) | ||||
|             values.append(b) | ||||
| 
 | ||||
|         my_setup_partial = partial(my_setup, 1) | ||||
|         my_teardown_partial = partial(my_teardown, 2) | ||||
| 
 | ||||
|         def test_hello(): | ||||
|             print (l) | ||||
|             assert l == [1] | ||||
|             print (values) | ||||
|             assert values == [1] | ||||
| 
 | ||||
|         def test_world(): | ||||
|             print (l) | ||||
|             assert l == [1,2] | ||||
|             print (values) | ||||
|             assert values == [1,2] | ||||
| 
 | ||||
|         test_hello.setup = my_setup_partial | ||||
|         test_hello.teardown = my_teardown_partial | ||||
|  | @ -251,19 +251,19 @@ def test_module_level_setup(testdir): | |||
| 
 | ||||
| def test_nose_style_setup_teardown(testdir): | ||||
|     testdir.makepyfile(""" | ||||
|         l = [] | ||||
|         values = [] | ||||
| 
 | ||||
|         def setup_module(): | ||||
|             l.append(1) | ||||
|             values.append(1) | ||||
| 
 | ||||
|         def teardown_module(): | ||||
|             del l[0] | ||||
|             del values[0] | ||||
| 
 | ||||
|         def test_hello(): | ||||
|             assert l == [1] | ||||
|             assert values == [1] | ||||
| 
 | ||||
|         def test_world(): | ||||
|             assert l == [1] | ||||
|             assert values == [1] | ||||
|         """) | ||||
|     result = testdir.runpytest('-p', 'nose') | ||||
|     result.stdout.fnmatch_lines([ | ||||
|  |  | |||
|  | @ -85,23 +85,23 @@ class TestPytestPluginInteractions(object): | |||
| 
 | ||||
|     def test_configure(self, testdir): | ||||
|         config = testdir.parseconfig() | ||||
|         l = [] | ||||
|         values = [] | ||||
| 
 | ||||
|         class A(object): | ||||
|             def pytest_configure(self, config): | ||||
|                 l.append(self) | ||||
|                 values.append(self) | ||||
| 
 | ||||
|         config.pluginmanager.register(A()) | ||||
|         assert len(l) == 0 | ||||
|         assert len(values) == 0 | ||||
|         config._do_configure() | ||||
|         assert len(l) == 1 | ||||
|         assert len(values) == 1 | ||||
|         config.pluginmanager.register(A())  # leads to a configured() plugin | ||||
|         assert len(l) == 2 | ||||
|         assert l[0] != l[1] | ||||
|         assert len(values) == 2 | ||||
|         assert values[0] != values[1] | ||||
| 
 | ||||
|         config._ensure_unconfigure() | ||||
|         config.pluginmanager.register(A()) | ||||
|         assert len(l) == 2 | ||||
|         assert len(values) == 2 | ||||
| 
 | ||||
|     def test_hook_tracing(self): | ||||
|         pytestpm = get_config().pluginmanager  # fully initialized with plugins | ||||
|  | @ -116,19 +116,19 @@ class TestPytestPluginInteractions(object): | |||
|                 saveindent.append(pytestpm.trace.root.indent) | ||||
|                 raise ValueError() | ||||
| 
 | ||||
|         l = [] | ||||
|         pytestpm.trace.root.setwriter(l.append) | ||||
|         values = [] | ||||
|         pytestpm.trace.root.setwriter(values.append) | ||||
|         undo = pytestpm.enable_tracing() | ||||
|         try: | ||||
|             indent = pytestpm.trace.root.indent | ||||
|             p = api1() | ||||
|             pytestpm.register(p) | ||||
|             assert pytestpm.trace.root.indent == indent | ||||
|             assert len(l) >= 2 | ||||
|             assert 'pytest_plugin_registered' in l[0] | ||||
|             assert 'finish' in l[1] | ||||
|             assert len(values) >= 2 | ||||
|             assert 'pytest_plugin_registered' in values[0] | ||||
|             assert 'finish' in values[1] | ||||
| 
 | ||||
|             l[:] = [] | ||||
|             values[:] = [] | ||||
|             with pytest.raises(ValueError): | ||||
|                 pytestpm.register(api2()) | ||||
|             assert pytestpm.trace.root.indent == indent | ||||
|  | @ -218,12 +218,12 @@ class TestPytestPluginManager(object): | |||
|         mod = py.std.types.ModuleType("x.y.pytest_hello") | ||||
|         pm.register(mod) | ||||
|         assert pm.is_registered(mod) | ||||
|         l = pm.get_plugins() | ||||
|         assert mod in l | ||||
|         values = pm.get_plugins() | ||||
|         assert mod in values | ||||
|         pytest.raises(ValueError, "pm.register(mod)") | ||||
|         pytest.raises(ValueError, lambda: pm.register(mod)) | ||||
|         # assert not pm.is_registered(mod2) | ||||
|         assert pm.get_plugins() == l | ||||
|         assert pm.get_plugins() == values | ||||
| 
 | ||||
|     def test_canonical_import(self, monkeypatch): | ||||
|         mod = py.std.types.ModuleType("pytest_xyz") | ||||
|  | @ -257,8 +257,8 @@ class TestPytestPluginManager(object): | |||
| 
 | ||||
|         # check that it is not registered twice | ||||
|         pytestpm.consider_module(mod) | ||||
|         l = reprec.getcalls("pytest_plugin_registered") | ||||
|         assert len(l) == 1 | ||||
|         values = reprec.getcalls("pytest_plugin_registered") | ||||
|         assert len(values) == 1 | ||||
| 
 | ||||
|     def test_consider_env_fails_to_import(self, monkeypatch, pytestpm): | ||||
|         monkeypatch.setenv('PYTEST_PLUGINS', 'nonexisting', prepend=",") | ||||
|  |  | |||
|  | @ -30,10 +30,10 @@ class TestWarningsRecorderChecker(object): | |||
|             assert len(rec.list) == 2 | ||||
|             warn = rec.pop() | ||||
|             assert str(warn.message) == "hello" | ||||
|             l = rec.list | ||||
|             values = rec.list | ||||
|             rec.clear() | ||||
|             assert len(rec.list) == 0 | ||||
|             assert l is rec.list | ||||
|             assert values is rec.list | ||||
|             pytest.raises(AssertionError, "rec.pop()") | ||||
| 
 | ||||
|     def test_typechecking(self): | ||||
|  |  | |||
|  | @ -13,12 +13,12 @@ class TestSetupState(object): | |||
|     def test_setup(self, testdir): | ||||
|         ss = runner.SetupState() | ||||
|         item = testdir.getitem("def test_func(): pass") | ||||
|         l = [1] | ||||
|         values = [1] | ||||
|         ss.prepare(item) | ||||
|         ss.addfinalizer(l.pop, colitem=item) | ||||
|         assert l | ||||
|         ss.addfinalizer(values.pop, colitem=item) | ||||
|         assert values | ||||
|         ss._pop_and_teardown() | ||||
|         assert not l | ||||
|         assert not values | ||||
| 
 | ||||
|     def test_teardown_exact_stack_empty(self, testdir): | ||||
|         item = testdir.getitem("def test_func(): pass") | ||||
|  |  | |||
|  | @ -39,20 +39,20 @@ def test_module_and_function_setup(testdir): | |||
| 
 | ||||
| def test_module_setup_failure_no_teardown(testdir): | ||||
|     reprec = testdir.inline_runsource(""" | ||||
|         l = [] | ||||
|         values = [] | ||||
|         def setup_module(module): | ||||
|             l.append(1) | ||||
|             values.append(1) | ||||
|             0/0 | ||||
| 
 | ||||
|         def test_nothing(): | ||||
|             pass | ||||
| 
 | ||||
|         def teardown_module(module): | ||||
|             l.append(2) | ||||
|             values.append(2) | ||||
|     """) | ||||
|     reprec.assertoutcome(failed=1) | ||||
|     calls = reprec.getcalls("pytest_runtest_setup") | ||||
|     assert calls[0].item.module.l == [1] | ||||
|     assert calls[0].item.module.values == [1] | ||||
| 
 | ||||
| 
 | ||||
| def test_setup_function_failure_no_teardown(testdir): | ||||
|  |  | |||
|  | @ -45,9 +45,9 @@ class SessionTests(object): | |||
|             a = 1 | ||||
|         """) | ||||
|         reprec = testdir.inline_run(tfile) | ||||
|         l = reprec.getfailedcollections() | ||||
|         assert len(l) == 1 | ||||
|         out = str(l[0].longrepr) | ||||
|         values = reprec.getfailedcollections() | ||||
|         assert len(values) == 1 | ||||
|         out = str(values[0].longrepr) | ||||
|         assert out.find('does_not_work') != -1 | ||||
| 
 | ||||
|     def test_raises_output(self, testdir): | ||||
|  | @ -75,9 +75,9 @@ class SessionTests(object): | |||
| 
 | ||||
|     def test_syntax_error_module(self, testdir): | ||||
|         reprec = testdir.inline_runsource("this is really not python") | ||||
|         l = reprec.getfailedcollections() | ||||
|         assert len(l) == 1 | ||||
|         out = str(l[0].longrepr) | ||||
|         values = reprec.getfailedcollections() | ||||
|         assert len(values) == 1 | ||||
|         out = str(values[0].longrepr) | ||||
|         assert out.find(str('not python')) != -1 | ||||
| 
 | ||||
|     def test_exit_first_problem(self, testdir): | ||||
|  | @ -144,15 +144,15 @@ class TestNewSession(SessionTests): | |||
| 
 | ||||
|     def test_order_of_execution(self, testdir): | ||||
|         reprec = testdir.inline_runsource(""" | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def test_1(): | ||||
|                 l.append(1) | ||||
|                 values.append(1) | ||||
|             def test_2(): | ||||
|                 l.append(2) | ||||
|                 values.append(2) | ||||
|             def test_3(): | ||||
|                 assert l == [1,2] | ||||
|                 assert values == [1,2] | ||||
|             class Testmygroup(object): | ||||
|                 reslist = l | ||||
|                 reslist = values | ||||
|                 def test_1(self): | ||||
|                     self.reslist.append(1) | ||||
|                 def test_2(self): | ||||
|  | @ -242,13 +242,13 @@ def test_exclude(testdir): | |||
| def test_sessionfinish_with_start(testdir): | ||||
|     testdir.makeconftest(""" | ||||
|         import os | ||||
|         l = [] | ||||
|         values = [] | ||||
|         def pytest_sessionstart(): | ||||
|             l.append(os.getcwd()) | ||||
|             values.append(os.getcwd()) | ||||
|             os.chdir("..") | ||||
| 
 | ||||
|         def pytest_sessionfinish(): | ||||
|             assert l[0] == os.getcwd() | ||||
|             assert values[0] == os.getcwd() | ||||
| 
 | ||||
|     """) | ||||
|     res = testdir.runpytest("--collect-only") | ||||
|  |  | |||
|  | @ -685,9 +685,9 @@ def test_skip_reasons_folding(): | |||
|     ev3.longrepr = longrepr | ||||
|     ev3.skipped = True | ||||
| 
 | ||||
|     l = folded_skips([ev1, ev2, ev3]) | ||||
|     assert len(l) == 1 | ||||
|     num, fspath, lineno, reason = l[0] | ||||
|     values = folded_skips([ev1, ev2, ev3]) | ||||
|     assert len(values) == 1 | ||||
|     num, fspath, lineno, reason = values[0] | ||||
|     assert num == 3 | ||||
|     assert fspath == path | ||||
|     assert lineno == lineno | ||||
|  |  | |||
|  | @ -24,12 +24,12 @@ class Option(object): | |||
| 
 | ||||
|     @property | ||||
|     def args(self): | ||||
|         l = [] | ||||
|         values = [] | ||||
|         if self.verbose: | ||||
|             l.append('-v') | ||||
|             values.append('-v') | ||||
|         if self.fulltrace: | ||||
|             l.append('--fulltrace') | ||||
|         return l | ||||
|             values.append('--fulltrace') | ||||
|         return values | ||||
| 
 | ||||
| 
 | ||||
| def pytest_generate_tests(metafunc): | ||||
|  |  | |||
|  | @ -73,19 +73,19 @@ def test_setup(testdir): | |||
| 
 | ||||
| def test_setUpModule(testdir): | ||||
|     testpath = testdir.makepyfile(""" | ||||
|         l = [] | ||||
|         values = [] | ||||
| 
 | ||||
|         def setUpModule(): | ||||
|             l.append(1) | ||||
|             values.append(1) | ||||
| 
 | ||||
|         def tearDownModule(): | ||||
|             del l[0] | ||||
|             del values[0] | ||||
| 
 | ||||
|         def test_hello(): | ||||
|             assert l == [1] | ||||
|             assert values == [1] | ||||
| 
 | ||||
|         def test_world(): | ||||
|             assert l == [1] | ||||
|             assert values == [1] | ||||
|         """) | ||||
|     result = testdir.runpytest(testpath) | ||||
|     result.stdout.fnmatch_lines([ | ||||
|  | @ -95,13 +95,13 @@ def test_setUpModule(testdir): | |||
| 
 | ||||
| def test_setUpModule_failing_no_teardown(testdir): | ||||
|     testpath = testdir.makepyfile(""" | ||||
|         l = [] | ||||
|         values = [] | ||||
| 
 | ||||
|         def setUpModule(): | ||||
|             0/0 | ||||
| 
 | ||||
|         def tearDownModule(): | ||||
|             l.append(1) | ||||
|             values.append(1) | ||||
| 
 | ||||
|         def test_hello(): | ||||
|             pass | ||||
|  | @ -109,7 +109,7 @@ def test_setUpModule_failing_no_teardown(testdir): | |||
|     reprec = testdir.inline_run(testpath) | ||||
|     reprec.assertoutcome(passed=0, failed=1) | ||||
|     call = reprec.getcalls("pytest_runtest_setup")[0] | ||||
|     assert not call.item.module.l | ||||
|     assert not call.item.module.values | ||||
| 
 | ||||
| 
 | ||||
| def test_new_instances(testdir): | ||||
|  | @ -129,14 +129,14 @@ def test_teardown(testdir): | |||
|     testpath = testdir.makepyfile(""" | ||||
|         import unittest | ||||
|         class MyTestCase(unittest.TestCase): | ||||
|             l = [] | ||||
|             values = [] | ||||
|             def test_one(self): | ||||
|                 pass | ||||
|             def tearDown(self): | ||||
|                 self.l.append(None) | ||||
|                 self.values.append(None) | ||||
|         class Second(unittest.TestCase): | ||||
|             def test_check(self): | ||||
|                 self.assertEqual(MyTestCase.l, [None]) | ||||
|                 self.assertEqual(MyTestCase.values, [None]) | ||||
|     """) | ||||
|     reprec = testdir.inline_run(testpath) | ||||
|     passed, skipped, failed = reprec.countoutcomes() | ||||
|  |  | |||
|  | @ -144,6 +144,8 @@ def test_unicode(testdir, pyfile_with_warnings): | |||
| @pytest.mark.skipif(sys.version_info >= (3, 0), | ||||
|                     reason='warnings message is broken as it is not str instance') | ||||
| def test_py2_unicode(testdir, pyfile_with_warnings): | ||||
|     if getattr(sys, "pypy_version_info", ())[:2] == (5, 9) and sys.platform.startswith('win'): | ||||
|         pytest.xfail("fails with unicode error on PyPy2 5.9 and Windows (#2905)") | ||||
|     testdir.makepyfile(''' | ||||
|         # -*- coding: utf8 -*- | ||||
|         import warnings | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue