Simplify more tests by replacing capture with assert

This commit is contained in:
Dean Moldovan 2016-08-19 13:45:36 +02:00
parent 3b44daedf6
commit 99dbdc16e5
6 changed files with 53 additions and 98 deletions

View File

@ -111,7 +111,7 @@ void init_issues(py::module &m) {
}); });
// (no id): should not be able to pass 'None' to a reference argument // (no id): should not be able to pass 'None' to a reference argument
m2.def("print_element", [](ElementA &el) { std::cout << el.value() << std::endl; }); m2.def("get_element", [](ElementA &el) { return el.value(); });
// (no id): don't cast doubles to ints // (no id): don't cast doubles to ints
m2.def("expect_float", [](float f) { return f; }); m2.def("expect_float", [](float f) { return f; });
@ -160,10 +160,7 @@ void init_issues(py::module &m) {
py::class_<StrIssue> si(m2, "StrIssue"); py::class_<StrIssue> si(m2, "StrIssue");
si .def(py::init<int>()) si .def(py::init<int>())
.def(py::init<>()) .def(py::init<>())
.def("__str__", [](const StrIssue &si) { .def("__str__", [](const StrIssue &si) { return "StrIssue[" + std::to_string(si.value()) + "]"; })
std::cout << "StrIssue.__str__ called" << std::endl;
return "StrIssue[" + std::to_string(si.value()) + "]";
})
; ;
// Issue #328: first member in a class can't be used in operators // Issue #328: first member in a class can't be used in operators

View File

@ -60,13 +60,13 @@ def test_shared_ptr_gc():
def test_no_id(capture, msg): def test_no_id(capture, msg):
from pybind11_tests.issues import print_element, expect_float, expect_int from pybind11_tests.issues import get_element, expect_float, expect_int
with pytest.raises(TypeError) as excinfo: with pytest.raises(TypeError) as excinfo:
print_element(None) get_element(None)
assert msg(excinfo.value) == """ assert msg(excinfo.value) == """
Incompatible function arguments. The following argument types are supported: Incompatible function arguments. The following argument types are supported:
1. (arg0: m.issues.ElementA) -> None 1. (arg0: m.issues.ElementA) -> int
Invoked with: None Invoked with: None
""" """
@ -105,13 +105,11 @@ def test_no_id(capture, msg):
""" """
def test_str_issue(capture, msg): def test_str_issue(msg):
"""Issue #283: __str__ called on uninitialized instance when constructor arguments invalid""" """Issue #283: __str__ called on uninitialized instance when constructor arguments invalid"""
from pybind11_tests.issues import StrIssue from pybind11_tests.issues import StrIssue
with capture: assert str(StrIssue(3)) == "StrIssue[3]"
assert str(StrIssue(3)) == "StrIssue[3]"
assert capture == "StrIssue.__str__ called"
with pytest.raises(TypeError) as excinfo: with pytest.raises(TypeError) as excinfo:
str(StrIssue("no", "such", "constructor")) str(StrIssue("no", "such", "constructor"))

View File

@ -27,18 +27,12 @@ py::object call_kw_func(py::function f) {
return f(*args, **kwargs); return f(*args, **kwargs);
} }
void args_function(py::args args) { py::tuple args_function(py::args args) {
for (size_t it=0; it<args.size(); ++it) return args;
std::cout << "got argument: " << py::object(args[it]) << std::endl;
} }
void args_kwargs_function(py::args args, py::kwargs kwargs) { py::tuple args_kwargs_function(py::args args, py::kwargs kwargs) {
for (auto item : args) return py::make_tuple(args, kwargs);
std::cout << "got argument: " << item << std::endl;
if (kwargs) {
for (auto item : kwargs)
std::cout << "got keyword argument: " << item.first << " -> " << item.second << std::endl;
}
} }
struct KWClass { struct KWClass {

View File

@ -12,8 +12,8 @@ def test_function_signatures(doc):
assert doc(kw_func4) == "kw_func4(myList: List[int]=[13, 17]) -> str" assert doc(kw_func4) == "kw_func4(myList: List[int]=[13, 17]) -> str"
assert doc(kw_func_udl) == "kw_func_udl(x: int, y: int=300) -> str" assert doc(kw_func_udl) == "kw_func_udl(x: int, y: int=300) -> str"
assert doc(kw_func_udl_z) == "kw_func_udl_z(x: int, y: int=0) -> str" assert doc(kw_func_udl_z) == "kw_func_udl_z(x: int, y: int=0) -> str"
assert doc(args_function) == "args_function(*args) -> None" assert doc(args_function) == "args_function(*args) -> tuple"
assert doc(args_kwargs_function) == "args_kwargs_function(*args, **kwargs) -> None" assert doc(args_kwargs_function) == "args_kwargs_function(*args, **kwargs) -> tuple"
assert doc(KWClass.foo0) == "foo0(self: m.KWClass, arg0: int, arg1: float) -> None" assert doc(KWClass.foo0) == "foo0(self: m.KWClass, arg0: int, arg1: float) -> None"
assert doc(KWClass.foo1) == "foo1(self: m.KWClass, x: int, y: float) -> None" assert doc(KWClass.foo1) == "foo1(self: m.KWClass, x: int, y: float) -> None"
@ -48,20 +48,12 @@ def test_named_arguments(msg):
assert kw_func_udl_z(x=5) == "x=5, y=0" assert kw_func_udl_z(x=5) == "x=5, y=0"
def test_arg_and_kwargs(capture): def test_arg_and_kwargs():
assert call_kw_func(kw_func2) == "x=1234, y=5678" assert call_kw_func(kw_func2) == "x=1234, y=5678"
with capture:
args_function('arg1_value', 'arg2_value', 3) args = 'arg1_value', 'arg2_value', 3
assert capture.unordered == """ assert args_function(*args) == args
got argument: arg1_value
got argument: arg2_value args = 'a1', 'a2'
got argument: 3 kwargs = dict(arg3='a3', arg4=4)
""" assert args_kwargs_function(*args, **kwargs) == (args, kwargs)
with capture:
args_kwargs_function('arg1_value', 'arg2_value', arg3='arg3_value', arg4=4)
assert capture.unordered == """
got argument: arg1_value
got argument: arg2_value
got keyword argument: arg3 -> arg3_value
got keyword argument: arg4 -> 4
"""

View File

@ -91,7 +91,7 @@ public:
Movable(int a, int b) : value{a+b} { print_created(this, a, b); } Movable(int a, int b) : value{a+b} { print_created(this, a, b); }
Movable(const Movable &m) { value = m.value; print_copy_created(this); } Movable(const Movable &m) { value = m.value; print_copy_created(this); }
Movable(Movable &&m) { value = std::move(m.value); print_move_created(this); } Movable(Movable &&m) { value = std::move(m.value); print_move_created(this); }
int get_value() const { return value; } std::string get_value() const { return std::to_string(value); }
~Movable() { print_destroyed(this); } ~Movable() { print_destroyed(this); }
private: private:
int value; int value;
@ -102,8 +102,8 @@ public:
virtual NonCopyable get_noncopyable(int a, int b) { return NonCopyable(a, b); } virtual NonCopyable get_noncopyable(int a, int b) { return NonCopyable(a, b); }
virtual Movable get_movable(int a, int b) = 0; virtual Movable get_movable(int a, int b) = 0;
void print_nc(int a, int b) { std::cout << get_noncopyable(a, b).get_value() << std::endl; } std::string print_nc(int a, int b) { return get_noncopyable(a, b).get_value(); }
void print_movable(int a, int b) { std::cout << get_movable(a, b).get_value() << std::endl; } std::string print_movable(int a, int b) { return get_movable(a, b).get_value(); }
}; };
class NCVirtTrampoline : public NCVirt { class NCVirtTrampoline : public NCVirt {
virtual NonCopyable get_noncopyable(int a, int b) { virtual NonCopyable get_noncopyable(int a, int b) {
@ -138,9 +138,11 @@ class A_Repeat {
#define A_METHODS \ #define A_METHODS \
public: \ public: \
virtual int unlucky_number() = 0; \ virtual int unlucky_number() = 0; \
virtual void say_something(unsigned times) { \ virtual std::string say_something(unsigned times) { \
for (unsigned i = 0; i < times; i++) std::cout << "hi"; \ std::string s = ""; \
std::cout << std::endl; \ for (unsigned i = 0; i < times; ++i) \
s += "hi"; \
return s; \
} }
A_METHODS A_METHODS
}; };
@ -148,8 +150,8 @@ class B_Repeat : public A_Repeat {
#define B_METHODS \ #define B_METHODS \
public: \ public: \
int unlucky_number() override { return 13; } \ int unlucky_number() override { return 13; } \
void say_something(unsigned times) override { \ std::string say_something(unsigned times) override { \
std::cout << "B says hi " << times << " times" << std::endl; \ return "B says hi " + std::to_string(times) + " times"; \
} \ } \
virtual double lucky_number() { return 7.0; } virtual double lucky_number() { return 7.0; }
B_METHODS B_METHODS
@ -178,27 +180,27 @@ class PyA_Repeat : public A_Repeat {
public: public:
using A_Repeat::A_Repeat; using A_Repeat::A_Repeat;
int unlucky_number() override { PYBIND11_OVERLOAD_PURE(int, A_Repeat, unlucky_number, ); } int unlucky_number() override { PYBIND11_OVERLOAD_PURE(int, A_Repeat, unlucky_number, ); }
void say_something(unsigned times) override { PYBIND11_OVERLOAD(void, A_Repeat, say_something, times); } std::string say_something(unsigned times) override { PYBIND11_OVERLOAD(std::string, A_Repeat, say_something, times); }
}; };
class PyB_Repeat : public B_Repeat { class PyB_Repeat : public B_Repeat {
public: public:
using B_Repeat::B_Repeat; using B_Repeat::B_Repeat;
int unlucky_number() override { PYBIND11_OVERLOAD(int, B_Repeat, unlucky_number, ); } int unlucky_number() override { PYBIND11_OVERLOAD(int, B_Repeat, unlucky_number, ); }
void say_something(unsigned times) override { PYBIND11_OVERLOAD(void, B_Repeat, say_something, times); } std::string say_something(unsigned times) override { PYBIND11_OVERLOAD(std::string, B_Repeat, say_something, times); }
double lucky_number() override { PYBIND11_OVERLOAD(double, B_Repeat, lucky_number, ); } double lucky_number() override { PYBIND11_OVERLOAD(double, B_Repeat, lucky_number, ); }
}; };
class PyC_Repeat : public C_Repeat { class PyC_Repeat : public C_Repeat {
public: public:
using C_Repeat::C_Repeat; using C_Repeat::C_Repeat;
int unlucky_number() override { PYBIND11_OVERLOAD(int, C_Repeat, unlucky_number, ); } int unlucky_number() override { PYBIND11_OVERLOAD(int, C_Repeat, unlucky_number, ); }
void say_something(unsigned times) override { PYBIND11_OVERLOAD(void, C_Repeat, say_something, times); } std::string say_something(unsigned times) override { PYBIND11_OVERLOAD(std::string, C_Repeat, say_something, times); }
double lucky_number() override { PYBIND11_OVERLOAD(double, C_Repeat, lucky_number, ); } double lucky_number() override { PYBIND11_OVERLOAD(double, C_Repeat, lucky_number, ); }
}; };
class PyD_Repeat : public D_Repeat { class PyD_Repeat : public D_Repeat {
public: public:
using D_Repeat::D_Repeat; using D_Repeat::D_Repeat;
int unlucky_number() override { PYBIND11_OVERLOAD(int, D_Repeat, unlucky_number, ); } int unlucky_number() override { PYBIND11_OVERLOAD(int, D_Repeat, unlucky_number, ); }
void say_something(unsigned times) override { PYBIND11_OVERLOAD(void, D_Repeat, say_something, times); } std::string say_something(unsigned times) override { PYBIND11_OVERLOAD(std::string, D_Repeat, say_something, times); }
double lucky_number() override { PYBIND11_OVERLOAD(double, D_Repeat, lucky_number, ); } double lucky_number() override { PYBIND11_OVERLOAD(double, D_Repeat, lucky_number, ); }
}; };
@ -221,7 +223,7 @@ class PyA_Tpl : public Base {
public: public:
using Base::Base; // Inherit constructors using Base::Base; // Inherit constructors
int unlucky_number() override { PYBIND11_OVERLOAD_PURE(int, Base, unlucky_number, ); } int unlucky_number() override { PYBIND11_OVERLOAD_PURE(int, Base, unlucky_number, ); }
void say_something(unsigned times) override { PYBIND11_OVERLOAD(void, Base, say_something, times); } std::string say_something(unsigned times) override { PYBIND11_OVERLOAD(std::string, Base, say_something, times); }
}; };
template <class Base = B_Tpl> template <class Base = B_Tpl>
class PyB_Tpl : public PyA_Tpl<Base> { class PyB_Tpl : public PyA_Tpl<Base> {

View File

@ -54,7 +54,7 @@ def test_override(capture, msg):
assert cstats.move_constructions >= 0 assert cstats.move_constructions >= 0
def test_inheriting_repeat(capture): def test_inheriting_repeat():
from pybind11_tests import A_Repeat, B_Repeat, C_Repeat, D_Repeat, A_Tpl, B_Tpl, C_Tpl, D_Tpl from pybind11_tests import A_Repeat, B_Repeat, C_Repeat, D_Repeat, A_Tpl, B_Tpl, C_Tpl, D_Tpl
class VI_AR(A_Repeat): class VI_AR(A_Repeat):
@ -66,28 +66,20 @@ def test_inheriting_repeat(capture):
return 999 return 999
obj = VI_AR() obj = VI_AR()
with capture: assert obj.say_something(3) == "hihihi"
obj.say_something(3)
assert capture == "hihihi"
assert obj.unlucky_number() == 99 assert obj.unlucky_number() == 99
obj = VI_AT() obj = VI_AT()
with capture: assert obj.say_something(3) == "hihihi"
obj.say_something(3)
assert capture == "hihihi"
assert obj.unlucky_number() == 999 assert obj.unlucky_number() == 999
for obj in [B_Repeat(), B_Tpl()]: for obj in [B_Repeat(), B_Tpl()]:
with capture: assert obj.say_something(3) == "B says hi 3 times"
obj.say_something(3)
assert capture == "B says hi 3 times"
assert obj.unlucky_number() == 13 assert obj.unlucky_number() == 13
assert obj.lucky_number() == 7.0 assert obj.lucky_number() == 7.0
for obj in [C_Repeat(), C_Tpl()]: for obj in [C_Repeat(), C_Tpl()]:
with capture: assert obj.say_something(3) == "B says hi 3 times"
obj.say_something(3)
assert capture == "B says hi 3 times"
assert obj.unlucky_number() == 4444 assert obj.unlucky_number() == 4444
assert obj.lucky_number() == 888.0 assert obj.lucky_number() == 888.0
@ -96,9 +88,7 @@ def test_inheriting_repeat(capture):
return C_Repeat.lucky_number(self) + 1.25 return C_Repeat.lucky_number(self) + 1.25
obj = VI_CR() obj = VI_CR()
with capture: assert obj.say_something(3) == "B says hi 3 times"
obj.say_something(3)
assert capture == "B says hi 3 times"
assert obj.unlucky_number() == 4444 assert obj.unlucky_number() == 4444
assert obj.lucky_number() == 889.25 assert obj.lucky_number() == 889.25
@ -106,9 +96,7 @@ def test_inheriting_repeat(capture):
pass pass
obj = VI_CT() obj = VI_CT()
with capture: assert obj.say_something(3) == "B says hi 3 times"
obj.say_something(3)
assert capture == "B says hi 3 times"
assert obj.unlucky_number() == 4444 assert obj.unlucky_number() == 4444
assert obj.lucky_number() == 888.0 assert obj.lucky_number() == 888.0
@ -117,9 +105,7 @@ def test_inheriting_repeat(capture):
return VI_CR.lucky_number(self) * 10 return VI_CR.lucky_number(self) * 10
obj = VI_CCR() obj = VI_CCR()
with capture: assert obj.say_something(3) == "B says hi 3 times"
obj.say_something(3)
assert capture == "B says hi 3 times"
assert obj.unlucky_number() == 4444 assert obj.unlucky_number() == 4444
assert obj.lucky_number() == 8892.5 assert obj.lucky_number() == 8892.5
@ -128,9 +114,7 @@ def test_inheriting_repeat(capture):
return VI_CT.lucky_number(self) * 1000 return VI_CT.lucky_number(self) * 1000
obj = VI_CCT() obj = VI_CCT()
with capture: assert obj.say_something(3) == "B says hi 3 times"
obj.say_something(3)
assert capture == "B says hi 3 times"
assert obj.unlucky_number() == 4444 assert obj.unlucky_number() == 4444
assert obj.lucky_number() == 888000.0 assert obj.lucky_number() == 888000.0
@ -142,22 +126,18 @@ def test_inheriting_repeat(capture):
return 42.0 return 42.0
for obj in [D_Repeat(), D_Tpl()]: for obj in [D_Repeat(), D_Tpl()]:
with capture: assert obj.say_something(3) == "B says hi 3 times"
obj.say_something(3)
assert capture == "B says hi 3 times"
assert obj.unlucky_number() == 4444 assert obj.unlucky_number() == 4444
assert obj.lucky_number() == 888.0 assert obj.lucky_number() == 888.0
obj = VI_DR() obj = VI_DR()
with capture: assert obj.say_something(3) == "B says hi 3 times"
obj.say_something(3)
assert capture == "B says hi 3 times"
assert obj.unlucky_number() == 123 assert obj.unlucky_number() == 123
assert obj.lucky_number() == 42.0 assert obj.lucky_number() == 42.0
class VI_DT(D_Tpl): class VI_DT(D_Tpl):
def say_something(self, times): def say_something(self, times):
print("VI_DT says:" + (' quack' * times)) return "VI_DT says:" + (' quack' * times)
def unlucky_number(self): def unlucky_number(self):
return 1234 return 1234
@ -166,14 +146,12 @@ def test_inheriting_repeat(capture):
return -4.25 return -4.25
obj = VI_DT() obj = VI_DT()
with capture: assert obj.say_something(3) == "VI_DT says: quack quack quack"
obj.say_something(3)
assert capture == "VI_DT says: quack quack quack"
assert obj.unlucky_number() == 1234 assert obj.unlucky_number() == 1234
assert obj.lucky_number() == -4.25 assert obj.lucky_number() == -4.25
def test_move_support(capture): def test_move_support():
from pybind11_tests import NCVirt, NonCopyable, Movable from pybind11_tests import NCVirt, NonCopyable, Movable
class NCVirtExt(NCVirt): class NCVirtExt(NCVirt):
@ -198,16 +176,10 @@ def test_move_support(capture):
return Movable(a, b) return Movable(a, b)
ncv1 = NCVirtExt() ncv1 = NCVirtExt()
with capture: assert ncv1.print_nc(2, 3) == "36"
ncv1.print_nc(2, 3) assert ncv1.print_movable(4, 5) == "9"
assert capture == "36"
with capture:
ncv1.print_movable(4, 5)
assert capture == "9"
ncv2 = NCVirtExt2() ncv2 = NCVirtExt2()
with capture: assert ncv2.print_movable(7, 7) == "14"
ncv2.print_movable(7, 7)
assert capture == "14"
# Don't check the exception message here because it differs under debug/non-debug mode # Don't check the exception message here because it differs under debug/non-debug mode
with pytest.raises(RuntimeError): with pytest.raises(RuntimeError):
ncv2.print_nc(9, 9) ncv2.print_nc(9, 9)