-
Notifications
You must be signed in to change notification settings - Fork 260
What is RSpec? How do I create unit tests for Ruby code?
Each RSpec file contains one or more tests. Each test ensures a particular feature of our website is working properly.
The output of an RSpec run will tell you exactly what features aren't working. The benefit is that tested code is unlikely to break unnoticed.
The tests are run every time someone makes, or updates, a Pull Request.
Example: See our RSpec pass or fail status: Pull Request #316, Fix-Heroku, March 27th 2017
Every do
corresponds with an end
somewhere later in the file.
You can think of do
as a left bracket "{" and think of end
as a right bracket "}" that encloses some line(s) of code. This keeps code logically separated, so one test doesn't leak into the other.
-
RSpec.describe
usually gives the test a name, such as: #rating_percentage. -
RSpec.context
adds a line of text that helps explain (and give context to) the test that follows. (This line is optional, but can make the tests easier to understand.) Example: 'it returns the rating percentage'. -
RSpec.it
lays out an actual test, in Ruby code that should evaluate toTRUE
. Often uses ado
command to start a block of lines of test code. The block is finished with anend
command. If none of the code in the test errors out, and it all returnsTRUE
, the test passes.
Reading the tests requires some understanding of how programming languages determine true
and false
values. (Ruby is written in an English-like way, though, so some tests may be intuitive even to folks who have never coded.)
- The
RSpec.it
line can start with a line of text that describes how the test result should be, if the test passes. Descriptive text is usually a good idea, to help keep the tests easy to read for the next person who comes around. This text is optional, so some tests do not include it. Example RSpec.it line:
Example test:
describe '#rating_percentage' do
context 'it returns the rating percentage' do
it 'should return 0 when there are no votes' do
expect(restroom.rating_percentage).to eq 0
end
Alright, here you go: https://github.com/RefugeRestrooms/refugerestrooms/blob/develop/spec/
Behavior Driven Development, aka Test Driven Development, is a philosophy of coding that started with the notion that all code should be covered with small tests for each feature ("unit tests"). And if every feature must have tests, why not write the tests first, to define your features, then code the features until the tests work?
BDD/TDD suggests we ought to begin with a test file, and grow out our app from there. It's a radical idea. But, thankfully, we can still use their test-writing programs (in this case RSpec) the traditional way, which is writing the code first, tests later.
- Official RSpec Documentation: http://rspec.info/