Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
gaoqiong
pybind11
Commits
67b54894
Commit
67b54894
authored
Sep 07, 2016
by
Ivan Smirnov
Browse files
Set error if it's not set in error_already_set()
parent
392f16cc
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
39 additions
and
4 deletions
+39
-4
include/pybind11/cast.h
include/pybind11/cast.h
+8
-3
tests/test_exceptions.cpp
tests/test_exceptions.cpp
+19
-1
tests/test_exceptions.py
tests/test_exceptions.py
+12
-0
No files found.
include/pybind11/cast.h
View file @
67b54894
...
...
@@ -106,10 +106,15 @@ PYBIND11_NOINLINE inline handle get_type_handle(const std::type_info &tp) {
}
PYBIND11_NOINLINE
inline
std
::
string
error_string
()
{
PyObject
*
type
,
*
value
,
*
traceback
;
PyErr_Fetch
(
&
type
,
&
value
,
&
traceback
);
if
(
!
PyErr_Occurred
())
{
PyErr_SetString
(
PyExc_RuntimeError
,
"Unknown internal error occurred"
);
return
"Unknown internal error occurred"
;
}
PyObject
*
type
,
*
value
,
*
traceback
;
PyErr_Fetch
(
&
type
,
&
value
,
&
traceback
);
std
::
string
errorString
;
std
::
string
errorString
;
if
(
type
)
{
errorString
+=
handle
(
type
).
attr
(
"__name__"
).
cast
<
std
::
string
>
();
errorString
+=
": "
;
...
...
tests/test_exceptions.cpp
View file @
67b54894
...
...
@@ -104,5 +104,23 @@ test_initializer custom_exceptions([](py::module &m) {
m
.
def
(
"throws3"
,
&
throws3
);
m
.
def
(
"throws4"
,
&
throws4
);
m
.
def
(
"throws_logic_error"
,
&
throws_logic_error
);
});
m
.
def
(
"throw_already_set"
,
[](
bool
err
)
{
if
(
err
)
PyErr_SetString
(
PyExc_ValueError
,
"foo"
);
try
{
throw
py
::
error_already_set
();
}
catch
(
const
std
::
runtime_error
&
e
)
{
if
((
err
&&
e
.
what
()
!=
std
::
string
(
"ValueError: foo"
))
||
(
!
err
&&
e
.
what
()
!=
std
::
string
(
"Unknown internal error occurred"
)))
{
PyErr_Clear
();
throw
std
::
runtime_error
(
"error message mismatch"
);
}
}
PyErr_Clear
();
if
(
err
)
PyErr_SetString
(
PyExc_ValueError
,
"foo"
);
throw
py
::
error_already_set
();
});
});
tests/test_exceptions.py
View file @
67b54894
import
pytest
def
test_error_already_set
(
msg
):
from
pybind11_tests
import
throw_already_set
with
pytest
.
raises
(
RuntimeError
)
as
excinfo
:
throw_already_set
(
False
)
assert
msg
(
excinfo
.
value
)
==
"Unknown internal error occurred"
with
pytest
.
raises
(
ValueError
)
as
excinfo
:
throw_already_set
(
True
)
assert
msg
(
excinfo
.
value
)
==
"foo"
def
test_custom
(
msg
):
from
pybind11_tests
import
(
MyException
,
throws1
,
throws2
,
throws3
,
throws4
,
throws_logic_error
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment