I'm using the Groovy RESTClient class to do write some (spock) Acceptance tests for Java WebServices I've been authoring.
One frustration I've had is in testing the responses...
200
Status's are easy:
when: def result = callServiceWithValidParams()
then: result.status == 200
But with 400+
I'm forced to either wrap in a try-catch
, or test for the HttpResponseException
that RESTClient
throws by default.
when:
callWithInvalidParams()
then:
def e = thrown(Exception)
e.message == 'Bad Request'
This is sort-of OK, if a little frustrating... but I want to do better.
Ideally, I want my tests to more resemble this (might be confusing if you don't use groovy/spock)
@Unroll
def "should return #statusCode '#status' Response"()
{
when:
def result = restClient.get(path: PATH, query: [param: parameter])
then:
result.status == statusCode
where:
status | statusCode | parameter
'OK' | 200 | validParam
'Bad Request' | 400 | invalidParam
}
In the above example, the 'Bad Request' case fails. Instead of returning a value, restClient.get()
throws HttpResponseException
@JonPeterson came up with what I think is a better solution, so I gave his answer the checkmark:
client.handler.failure = client.handler.success
More info here
The solution I (previously) landed on:
restClient.handler.failure = { it }
Which is shorthand for
restClient.handler.failure = { resp -> return resp }
@JimmyLuong noted in the comments that this approach drops the data from the response, and suggested the following enhancement:
restClient.handler.failure = { resp, data -> resp.setData(data); return resp }
As Tomasz already linked in a comment, here is my little one-liner answer from a similar question.
client.handler.failure = client.handler.success
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With