- Rebase and re-add tidy-up-embeddedfile.patch, it was only partially merged
upstream. OBS-URL: https://build.opensuse.org/package/show/devel:languages:python:pytest/python-pytest?expand=0&rev=62
This commit is contained in:
parent
2054858c86
commit
83b0a6b3e6
@ -1,3 +1,9 @@
|
||||
-------------------------------------------------------------------
|
||||
Tue Jun 9 07:43:57 UTC 2020 - Steve Kowalik <steven.kowalik@suse.com>
|
||||
|
||||
- Rebase and re-add tidy-up-embeddedfile.patch, it was only partially merged
|
||||
upstream.
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Fri Jun 5 09:03:56 UTC 2020 - Ondřej Súkup <mimi.vx@gmail.com>
|
||||
|
||||
|
@ -33,6 +33,7 @@ Summary: Python testing tool with autodiscovery and detailed asserts
|
||||
License: MIT
|
||||
URL: https://github.com/pytest-dev/pytest
|
||||
Source: https://files.pythonhosted.org/packages/source/p/pytest/pytest-%{version}.tar.gz
|
||||
Patch0: tidy-up-embeddedfile.patch
|
||||
BuildRequires: %{python_module setuptools >= 40.0}
|
||||
BuildRequires: %{python_module setuptools_scm}
|
||||
BuildRequires: fdupes
|
||||
@ -87,6 +88,7 @@ pytest is a cross-project Python testing tool. It provides:
|
||||
|
||||
%prep
|
||||
%setup -q -n pytest-%{version}
|
||||
%autopatch -p1
|
||||
|
||||
%build
|
||||
%python_build
|
||||
|
202
tidy-up-embeddedfile.patch
Normal file
202
tidy-up-embeddedfile.patch
Normal file
@ -0,0 +1,202 @@
|
||||
From 29e4cb5d45f44379aba948c2cd791b3b97210e31 Mon Sep 17 00:00:00 2001
|
||||
From: Ran Benita <ran@unusedvar.com>
|
||||
Date: Sat, 7 Mar 2020 18:38:22 +0200
|
||||
Subject: [PATCH] Remove safe_text_dupfile() and simplify EncodedFile
|
||||
|
||||
I tried to understand what the `safe_text_dupfile()` function and
|
||||
`EncodedFile` class do. Outside tests, `EncodedFile` is only used by
|
||||
`safe_text_dupfile`, and `safe_text_dupfile` is only used by
|
||||
`FDCaptureBinary.__init__()`. I then started to eliminate always-true
|
||||
conditions based on the single call site, and in the end nothing was
|
||||
left except of a couple workarounds that are still needed.
|
||||
---
|
||||
src/_pytest/capture.py | 66 ++++++++++--------------------------
|
||||
testing/test_capture.py | 75 ++++++-----------------------------------
|
||||
2 files changed, 28 insertions(+), 113 deletions(-)
|
||||
|
||||
Index: pytest-5.4.3/src/_pytest/capture.py
|
||||
===================================================================
|
||||
--- pytest-5.4.3.orig/src/_pytest/capture.py
|
||||
+++ pytest-5.4.3/src/_pytest/capture.py
|
||||
@@ -390,54 +390,21 @@ class CaptureFixture:
|
||||
yield
|
||||
|
||||
|
||||
-def safe_text_dupfile(f, mode, default_encoding="UTF8"):
|
||||
- """ return an open text file object that's a duplicate of f on the
|
||||
- FD-level if possible.
|
||||
- """
|
||||
- encoding = getattr(f, "encoding", None)
|
||||
- try:
|
||||
- fd = f.fileno()
|
||||
- except Exception:
|
||||
- if "b" not in getattr(f, "mode", "") and hasattr(f, "encoding"):
|
||||
- # we seem to have a text stream, let's just use it
|
||||
- return f
|
||||
- else:
|
||||
- newfd = os.dup(fd)
|
||||
- if "b" not in mode:
|
||||
- mode += "b"
|
||||
- f = os.fdopen(newfd, mode, 0) # no buffering
|
||||
- return EncodedFile(f, encoding or default_encoding)
|
||||
-
|
||||
-
|
||||
-class EncodedFile:
|
||||
- errors = "strict" # possibly needed by py3 code (issue555)
|
||||
-
|
||||
- def __init__(self, buffer: BinaryIO, encoding: str) -> None:
|
||||
- self.buffer = buffer
|
||||
- self.encoding = encoding
|
||||
-
|
||||
- def write(self, s: str) -> int:
|
||||
- if not isinstance(s, str):
|
||||
- raise TypeError(
|
||||
- "write() argument must be str, not {}".format(type(s).__name__)
|
||||
- )
|
||||
- return self.buffer.write(s.encode(self.encoding, "replace"))
|
||||
-
|
||||
- def writelines(self, lines: Iterable[str]) -> None:
|
||||
- self.buffer.writelines(x.encode(self.encoding, "replace") for x in lines)
|
||||
+class EncodedFile(io.TextIOWrapper):
|
||||
+ __slots__ = ()
|
||||
|
||||
@property
|
||||
def name(self) -> str:
|
||||
- """Ensure that file.name is a string."""
|
||||
+ # Ensure that file.name is a string. Workaround for a Python bug
|
||||
+ # fixed in >=3.7.4: https://bugs.python.org/issue36015
|
||||
return repr(self.buffer)
|
||||
|
||||
@property
|
||||
def mode(self) -> str:
|
||||
+ # TextIOWrapper doesn't expose a mode, but at least some of our
|
||||
+ # tests check it.
|
||||
return self.buffer.mode.replace("b", "")
|
||||
|
||||
- def __getattr__(self, name):
|
||||
- return getattr(object.__getattribute__(self, "buffer"), name)
|
||||
-
|
||||
|
||||
CaptureResult = collections.namedtuple("CaptureResult", ["out", "err"])
|
||||
|
||||
@@ -552,9 +519,12 @@ class FDCaptureBinary:
|
||||
self.syscapture = SysCapture(targetfd)
|
||||
else:
|
||||
if tmpfile is None:
|
||||
- f = TemporaryFile()
|
||||
- with f:
|
||||
- tmpfile = safe_text_dupfile(f, mode="wb+")
|
||||
+ tmpfile = EncodedFile(
|
||||
+ TemporaryFile(buffering=0),
|
||||
+ encoding="utf-8",
|
||||
+ errors="replace",
|
||||
+ write_through=True,
|
||||
+ )
|
||||
if targetfd in patchsysdict:
|
||||
self.syscapture = SysCapture(targetfd, tmpfile)
|
||||
else:
|
||||
@@ -583,7 +553,7 @@ class FDCaptureBinary:
|
||||
|
||||
def snap(self):
|
||||
self.tmpfile.seek(0)
|
||||
- res = self.tmpfile.read()
|
||||
+ res = self.tmpfile.buffer.read()
|
||||
self.tmpfile.seek(0)
|
||||
self.tmpfile.truncate()
|
||||
return res
|
||||
@@ -623,10 +593,10 @@ class FDCapture(FDCaptureBinary):
|
||||
EMPTY_BUFFER = str() # type: ignore
|
||||
|
||||
def snap(self):
|
||||
- res = super().snap()
|
||||
- enc = getattr(self.tmpfile, "encoding", None)
|
||||
- if enc and isinstance(res, bytes):
|
||||
- res = str(res, enc, "replace")
|
||||
+ self.tmpfile.seek(0)
|
||||
+ res = self.tmpfile.read()
|
||||
+ self.tmpfile.seek(0)
|
||||
+ self.tmpfile.truncate()
|
||||
return res
|
||||
|
||||
def writeorg(self, data):
|
||||
Index: pytest-5.4.3/testing/test_capture.py
|
||||
===================================================================
|
||||
--- pytest-5.4.3.orig/testing/test_capture.py
|
||||
+++ pytest-5.4.3/testing/test_capture.py
|
||||
@@ -887,49 +887,6 @@ def tmpfile(testdir) -> Generator[Binary
|
||||
f.close()
|
||||
|
||||
|
||||
-@needsosdup
|
||||
-def test_dupfile(tmpfile) -> None:
|
||||
- flist = [] # type: List[TextIO]
|
||||
- for i in range(5):
|
||||
- nf = capture.safe_text_dupfile(tmpfile, "wb")
|
||||
- assert nf != tmpfile
|
||||
- assert nf.fileno() != tmpfile.fileno()
|
||||
- assert nf not in flist
|
||||
- print(i, end="", file=nf)
|
||||
- flist.append(nf)
|
||||
-
|
||||
- fname_open = flist[0].name
|
||||
- assert fname_open == repr(flist[0].buffer)
|
||||
-
|
||||
- for i in range(5):
|
||||
- f = flist[i]
|
||||
- f.close()
|
||||
- fname_closed = flist[0].name
|
||||
- assert fname_closed == repr(flist[0].buffer)
|
||||
- assert fname_closed != fname_open
|
||||
- tmpfile.seek(0)
|
||||
- s = tmpfile.read()
|
||||
- assert "01234" in repr(s)
|
||||
- tmpfile.close()
|
||||
- assert fname_closed == repr(flist[0].buffer)
|
||||
-
|
||||
-
|
||||
-def test_dupfile_on_bytesio():
|
||||
- bio = io.BytesIO()
|
||||
- f = capture.safe_text_dupfile(bio, "wb")
|
||||
- f.write("hello")
|
||||
- assert bio.getvalue() == b"hello"
|
||||
- assert "BytesIO object" in f.name
|
||||
-
|
||||
-
|
||||
-def test_dupfile_on_textio():
|
||||
- sio = StringIO()
|
||||
- f = capture.safe_text_dupfile(sio, "wb")
|
||||
- f.write("hello")
|
||||
- assert sio.getvalue() == "hello"
|
||||
- assert not hasattr(f, "name")
|
||||
-
|
||||
-
|
||||
@contextlib.contextmanager
|
||||
def lsof_check():
|
||||
pid = os.getpid()
|
||||
@@ -1377,8 +1334,8 @@ def test_error_attribute_issue555(testdi
|
||||
"""
|
||||
import sys
|
||||
def test_capattr():
|
||||
- assert sys.stdout.errors == "strict"
|
||||
- assert sys.stderr.errors == "strict"
|
||||
+ assert sys.stdout.errors == "replace"
|
||||
+ assert sys.stderr.errors == "replace"
|
||||
"""
|
||||
)
|
||||
reprec = testdir.inline_run()
|
||||
@@ -1453,15 +1410,6 @@ def test_crash_on_closing_tmpfile_py27(t
|
||||
result.stdout.no_fnmatch_line("*IOError*")
|
||||
|
||||
|
||||
-def test_pickling_and_unpickling_encoded_file():
|
||||
- # See https://bitbucket.org/pytest-dev/pytest/pull-request/194
|
||||
- # pickle.loads() raises infinite recursion if
|
||||
- # EncodedFile.__getattr__ is not implemented properly
|
||||
- ef = capture.EncodedFile(None, None)
|
||||
- ef_as_str = pickle.dumps(ef)
|
||||
- pickle.loads(ef_as_str)
|
||||
-
|
||||
-
|
||||
def test_global_capture_with_live_logging(testdir):
|
||||
# Issue 3819
|
||||
# capture should work with live cli logging
|
Loading…
Reference in New Issue
Block a user