How to use nose's assert_raises? How to use nose's assert_raises? python python

How to use nose's assert_raises?


While the accepted answer is correct, I think there is a better use to assert_raises method.

If you simply want to assert that an exception occurs, it's probably simpler and cleaner to use @raises syntax.

@raises(HTTPError)def test_exception_is_raised:    call_your_method(p1, p2)

However, assume you want to do bit more with the raised exception, for example: we need to assert that raised HTTPError is of type 401: Unauthorized, instead of 500: Server Error.

In such a situation above syntax is not that helpful, we should use the assert_raises but in a different way.If we do not pass it a callable as the second parameter assert_raises will return back a context which we can use to further test the exception details.

def test_exception_is_raised:    with assert_raises(HTTPError) as cm:         call_your_method(p1, p2)    ex = cm.exception # raised exception is available through exception property of context    ok_(ex.code == 401, 'HTTPError should be Unauthorized!')


The assert_raises() function tests to make sure a function call raises a specified exception when presented with certain parameters.

For example, if you had a function add that adds two numbers, it should probably raise a TypeError when you pass it, say, an integer and a string. So:

from nose.tools import assert_raisesdef add(x, y):    return x + yassert_raises(TypeError, add, 2, "0")

The first argument is the exception type you expect. The second is the function to call. The rest of the arguments will be passed to the function (in this case, they will become x and y inside the function).

If the expected exception is raised by the function, the assertion passes.