Compare commits
22 Commits
Author | SHA256 | Date | |
---|---|---|---|
269bf91926 | |||
2eb4d7ec82 | |||
7226568526 | |||
5eaa30b4c2 | |||
727b5fc8f4 | |||
4c10e0a116 | |||
0b675b4971 | |||
8662559037 | |||
a978dfee45 | |||
acd3a0468b | |||
3cd2f11ef3 | |||
c4fcdfab2d | |||
1dcb816449 | |||
c1ff8eff80 | |||
|
2e64fc9c76 | ||
1d53e1da87 | |||
|
6022fcd26c | ||
8a8068b3e0 | |||
189f152bae | |||
de2ca649f6 | |||
|
3d475712b3 | ||
|
5a163db66e |
@@ -1,44 +0,0 @@
|
||||
From 66e14cdd101e4214cca6acca8f48b9abe4f75729 Mon Sep 17 00:00:00 2001
|
||||
From: =?UTF-8?q?Ionel=20Cristian=20M=C4=83rie=C8=99?= <contact@ionelmc.ro>
|
||||
Date: Fri, 15 Dec 2023 16:52:07 +0200
|
||||
Subject: [PATCH] More aggressive location stripping. Ref #74.
|
||||
|
||||
---
|
||||
tests/test_pickle_exception.py | 12 ++++++------
|
||||
1 file changed, 6 insertions(+), 6 deletions(-)
|
||||
|
||||
Index: tblib-3.0.0/tests/test_pickle_exception.py
|
||||
===================================================================
|
||||
--- tblib-3.0.0.orig/tests/test_pickle_exception.py
|
||||
+++ tblib-3.0.0/tests/test_pickle_exception.py
|
||||
@@ -29,6 +29,10 @@ class CustomError(Exception):
|
||||
pass
|
||||
|
||||
|
||||
+def strip_locations(tb_text):
|
||||
+ return tb_text.replace(' ~~^~~\n', '').replace(' ^^^^^^^^^^^^^^^^^\n', '')
|
||||
+
|
||||
+
|
||||
@pytest.mark.parametrize('protocol', [None, *list(range(1, pickle.HIGHEST_PROTOCOL + 1))])
|
||||
@pytest.mark.parametrize('how', ['global', 'instance', 'class'])
|
||||
def test_install(clear_dispatch_table, how, protocol):
|
||||
@@ -58,8 +62,8 @@ def test_install(clear_dispatch_table, h
|
||||
else:
|
||||
raise AssertionError
|
||||
|
||||
- expected_format_exception = ''.join(format_exception(type(exc), exc, exc.__traceback__))
|
||||
- print(expected_format_exception)
|
||||
+ expected_format_exception = strip_locations(''.join(format_exception(type(exc), exc, exc.__traceback__)))
|
||||
+
|
||||
# Populate Exception.__dict__, which is used in some cases
|
||||
exc.x = 1
|
||||
exc.__cause__.x = 2
|
||||
@@ -88,7 +92,7 @@ def test_install(clear_dispatch_table, h
|
||||
if has_python311:
|
||||
assert exc.__notes__ == ['note 1', 'note 2']
|
||||
|
||||
- assert expected_format_exception == ''.join(format_exception(type(exc), exc, exc.__traceback__))
|
||||
+ assert expected_format_exception == strip_locations(''.join(format_exception(type(exc), exc, exc.__traceback__)))
|
||||
|
||||
|
||||
@tblib.pickling_support.install
|
BIN
tblib-3.0.0.tar.gz
(Stored with Git LFS)
BIN
tblib-3.0.0.tar.gz
(Stored with Git LFS)
Binary file not shown.
@@ -1,63 +0,0 @@
|
||||
From 9f6f864f7de6ce6640bab6d962f00b956da75361 Mon Sep 17 00:00:00 2001
|
||||
From: Alexandre Detiste <alexandre.detiste@gmail.com>
|
||||
Date: Wed, 1 May 2024 13:43:53 +0200
|
||||
Subject: [PATCH] vendore reraise() from six
|
||||
|
||||
---
|
||||
ci/requirements.txt | 1 -
|
||||
setup.py | 2 +-
|
||||
src/tblib/decorators.py | 14 ++++++++++++--
|
||||
3 files changed, 13 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/ci/requirements.txt b/ci/requirements.txt
|
||||
index a1708f4..b4f1852 100644
|
||||
--- a/ci/requirements.txt
|
||||
+++ b/ci/requirements.txt
|
||||
@@ -1,6 +1,5 @@
|
||||
virtualenv>=16.6.0
|
||||
pip>=19.1.1
|
||||
setuptools>=18.0.1
|
||||
-six>=1.14.0
|
||||
tox
|
||||
twine
|
||||
diff --git a/setup.py b/setup.py
|
||||
index c5364a1..c09d4c3 100755
|
||||
--- a/setup.py
|
||||
+++ b/setup.py
|
||||
@@ -64,7 +64,7 @@ def read(*names, **kwargs):
|
||||
],
|
||||
python_requires='>=3.8',
|
||||
install_requires=[
|
||||
- # eg: "aspectlib==1.1.1", "six>=1.7",
|
||||
+ # eg: "aspectlib==1.1.1",
|
||||
],
|
||||
extras_require={
|
||||
# eg:
|
||||
diff --git a/src/tblib/decorators.py b/src/tblib/decorators.py
|
||||
index 38d0675..a1ace45 100644
|
||||
--- a/src/tblib/decorators.py
|
||||
+++ b/src/tblib/decorators.py
|
||||
@@ -1,11 +1,21 @@
|
||||
import sys
|
||||
from functools import wraps
|
||||
|
||||
-from six import reraise
|
||||
-
|
||||
from . import Traceback
|
||||
|
||||
|
||||
+def reraise(tp, value, tb=None):
|
||||
+ try:
|
||||
+ if value is None:
|
||||
+ value = tp()
|
||||
+ if value.__traceback__ is not tb:
|
||||
+ raise value.with_traceback(tb)
|
||||
+ raise value
|
||||
+ finally:
|
||||
+ value = None
|
||||
+ tb = None
|
||||
+
|
||||
+
|
||||
class Error:
|
||||
def __init__(self, exc_type, exc_value, traceback):
|
||||
self.exc_type = exc_type
|
Reference in New Issue
Block a user