mirror of
https://github.com/pybind/pybind11.git
synced 2024-11-26 07:02:11 +00:00
Simplify more tests by replacing capture with assert
This commit is contained in:
parent
3b44daedf6
commit
99dbdc16e5
@ -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
|
||||||
|
@ -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"))
|
||||||
|
@ -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 {
|
||||||
|
@ -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
|
|
||||||
"""
|
|
||||||
|
@ -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> {
|
||||||
|
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user