Commit 90ef404d authored by Ian Henriksen's avatar Ian Henriksen

Added tests to make sure the correct exception handling routines are

called when different c++ exception handling needs to take place for
different parts of a given expression.
parent f5537bb0
...@@ -202,15 +202,15 @@ public: ...@@ -202,15 +202,15 @@ public:
return this->val; return this->val;
} }
wrapped_int &operator=(const wrapped_int &other) { wrapped_int &operator=(const wrapped_int &other) {
if (other.val == 4) { if ((other.val == 4) && (this->val == 4)) {
throw std::overflow_error("4 is really too big!"); throw std::overflow_error("Can't assign 4 to 4!");
} }
this->val = other.val; this->val = other.val;
return *this; return *this;
} }
wrapped_int &operator=(const long long &v) { wrapped_int &operator=(const long long &v) {
if (v == 4) { if ((v == 4) && (this->val == 4)) {
throw std::overflow_error("4 is really too small!"); throw std::overflow_error("Can't assign 4 to 4!");
} }
this->val = v; this->val = v;
return *this; return *this;
...@@ -229,11 +229,11 @@ cdef extern from "wint.cpp" nogil: ...@@ -229,11 +229,11 @@ cdef extern from "wint.cpp" nogil:
wrapped_int() wrapped_int()
wrapped_int(long long val) wrapped_int(long long val)
wrapped_int(long long v1, long long v2) except + wrapped_int(long long v1, long long v2) except +
wrapped_int operator+(wrapped_int &other) except + wrapped_int operator+(wrapped_int &other) except +ValueError
wrapped_int operator+() except + wrapped_int operator+() except +RuntimeError
wrapped_int operator-(wrapped_int &other) except + wrapped_int operator-(wrapped_int &other) except +
wrapped_int operator-() except + wrapped_int operator-() except +
wrapped_int operator*(wrapped_int &other) except + wrapped_int operator*(wrapped_int &other) except +OverflowError
wrapped_int operator/(wrapped_int &other) except + wrapped_int operator/(wrapped_int &other) except +
wrapped_int operator%(wrapped_int &other) except + wrapped_int operator%(wrapped_int &other) except +
long long operator^(wrapped_int &other) except + long long operator^(wrapped_int &other) except +
...@@ -255,18 +255,26 @@ cdef extern from "wint.cpp" nogil: ...@@ -255,18 +255,26 @@ cdef extern from "wint.cpp" nogil:
wrapped_int operator--(int) except + wrapped_int operator--(int) except +
wrapped_int operator!() except + wrapped_int operator!() except +
bool operator bool() except + bool operator bool() except +
wrapped_int &operator[](long long &index) except + wrapped_int &operator[](long long &index) except +IndexError
long long &operator()() except + long long &operator()() except +
wrapped_int &operator=(const wrapped_int &other) except + wrapped_int &operator=(const wrapped_int &other) except +ArithmeticError
wrapped_int &operator=(const long long &vao) except + wrapped_int &operator=(const long long &vao) except +
def assert_raised(f, *args): def assert_raised(f, *args, **kwargs):
err = kwargs.get('err', None)
if err is None:
try: try:
f(*args) f(*args)
raised = False raised = False
except: except:
raised = True raised = True
else:
try:
f(*args)
raised = False
except err:
raised = True
assert raised assert raised
def initialization(long long a, long long b): def initialization(long long a, long long b):
...@@ -424,33 +432,45 @@ def cascaded_assign(long long a, long long b, long long c): ...@@ -424,33 +432,45 @@ def cascaded_assign(long long a, long long b, long long c):
a = b = c a = b = c
return a.val return a.val
def separate_exceptions(long long a, long long b, long long c, long long d, long long e):
cdef:
wrapped_int wa = wrapped_int(a)
wrapped_int wc = wrapped_int(c)
wrapped_int wd = wrapped_int(d)
wrapped_int we = wrapped_int(e)
wa[b] = (+wc) * wd + we
return a.val
def test(): def test():
a = 1 assert_raised(initialization, 1, 4)
b = 4 assert_raised(addition, 1, 4)
c = 4 assert_raised(subtraction, 1, 4)
assert_raised(initialization, a, b) assert_raised(multiplication, 1, 4)
assert_raised(addition, a, b) assert_raised(division, 1, 4)
assert_raised(subtraction, a, b) assert_raised(mod, 1, 4)
assert_raised(multiplication, a, b) assert_raised(minus, 4)
assert_raised(division, a, b) assert_raised(plus, 4)
assert_raised(mod, a, b) assert_raised(xor, 1, 4)
assert_raised(minus, b) assert_raised(address, 4)
assert_raised(plus, b) assert_raised(iseq, 1, 4)
assert_raised(xor, a, b) assert_raised(neq, 1, 4)
assert_raised(address, b) assert_raised(left_shift, 1, 4)
assert_raised(iseq, a, b) assert_raised(right_shift, 1, 4)
assert_raised(neq, a, b) assert_raised(cpp_preincrement, 4)
assert_raised(left_shift, a, b) assert_raised(cpp_predecrement, 4)
assert_raised(right_shift, a, b) assert_raised(cpp_postincrement, 4)
assert_raised(cpp_preincrement, b) assert_raised(cpp_postdecrement, 4)
assert_raised(cpp_predecrement, b) assert_raised(negate, 4)
assert_raised(cpp_postincrement, b) assert_raised(bool_cast, 4)
assert_raised(cpp_postdecrement, b) assert_raised(index, 1, 4)
assert_raised(negate, b) assert_raised(assign_index, 1, 4, 4)
assert_raised(bool_cast, b) assert_raised(call, 4)
assert_raised(index, a, b) assert_raised(assign_same, 4, 4)
assert_raised(assign_index, a, b, c) assert_raised(assign_different, 4, 4)
assert_raised(assign_same, a, b) assert_raised(cascaded_assign, 4, 4, 1)
assert_raised(assign_different, a, b) assert_raised(cascaded_assign, 4, 1, 4)
assert_raised(cascaded_assign, a, b, c) assert_raised(separate_exceptions, 1, 1, 1, 1, 4, err=ValueError)
assert_raised(cascaded_assign, b, a, c) assert_raised(separate_exceptions, 1, 1, 1, 4, 1, err=OverflowError)
assert_raised(separate_exceptions, 1, 1, 4, 1, 1, err=RuntimeError)
assert_raised(separate_exceptions, 1, 4, 1, 1, 1, err=IndexError)
assert_raised(separate_exceptions, 4, 1, 1, 1, 3, err=ArithmeticError)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment