I’m a big fan of RSpec, and I use it all the time. But I think Cucumber wins hands down in generating readable test outputs which can be important in many scenarios. Let me explain one such scenario which I faced in one of my projects.
I was working on a Rails API app which would serve as the backend for a JS/native client running on platforms unknown to me. The API client was developed by a remote team separately. The remote developers would write client code to consume the APIs looking at an API documentation which would ideally describe the requests and all the possible responses from the APIs along with examples. The documentation would reflect the latest changes and it should be possible to obtain the documentation for every commit. The documentation would also ideally show the health of the APIs, so the client developers would know, for any given commit, which of the APIs work as expected ( mainly because I didn’t want to answer questions like “Does the user listing API work, because I’m always getting a 403 status?” ) , If the API doc is green, it means it should work for a correct request. I used Cucumber to write integration tests and also for all the above requirements, and it worked well for me.
Here’s an example of the documentation cucumber would create for my user sign up API:
Feature: Sign Up
Background:
Given I send and accept JSON
Scenario: Passwords do not match
When I send a POST request to “/api/users” with the following:
“”"
{
“user” : {
“first_name”: “Kobe”,
“last_name”: “Bryant”,
“email”: “kobe@gmail.com”,
“password”: “kobe1234”,
“password_confirmation”: “kobe12345”
}
}
“”"
Then the response status should be “422”
And the JSON response should be:
“”"
{“errors” : [“Password confirmation doesn’t match Password”]}
“”"
RSpec can test this scenario alright, and it would be very much readable for any Ruby programmer. But I can’t imagine a way to produce such a readable output with RSpec which could be read by a non Ruby developer, in my case a client side dev who may not be too interested in opening a ruby file to understand the API. But with cucumber, you are forced to think of a scenario as a sequence of steps, which really helped me in my case. My only problem with cucumber was writing regexes. But that’s a small threshold to cross (I created some vim snippets to help me with the common regex templates) and it’s not going to be one of your 99 problems.
Cucumber worked amazingly well for me, but I may not use it all the time. I can’t think of a reason why I shouldn’t use it for every project, though. Laziness probably.