-
-
Save mlr/6574be720a88800b7883 to your computer and use it in GitHub Desktop.
Rspec Rails cheatsheet with expect syntax (including capybara matchers)
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Model | |
expect(@user).to have(1).error_on(:username) # checks whether there is an error in username | |
expect(@user.errors[:username]).to include("can't be blank") # check for the error message | |
# Rendering | |
expect(response).to render_template(:index) | |
# Redirecting | |
expect(response).to redirect_to(movies_path) | |
# Capybara Matchers | |
expect(response.body).to have_content("Hello world") | |
expect(response.body).to_not have_content("Hello world") | |
expect(response.body).to have_css("input#movie_title") | |
expect(response.body).to have_css("input", count: 3) # true if there are 3 input tags in response | |
expect(response.body).to have_css("input", maximum: 3) # true if there or fewer or equal to 3 input tags | |
expect(response.body).to have_css("input", minimum: 3) # true if there are minimum of 3 input tags | |
expect(response.body).to have_css("input", between: 1..3) # true if there 1 to 3 input tags | |
expect(response.body).to have_css("p a", text: "hello") # true if there is a anchor tag with text hello | |
expect(response.body).to have_css("p a", text: /[hH]ello(.+)/i) # true if there is a anchor tag with text matching regex | |
expect(response.body).to have_xpath("//a") | |
expect(response.body).to have_xpath("//a", href: "google.com") | |
expect(response.body).to have_xpath("//a[@href='google.com']") | |
expect(response.body).to have_xpath("//a[contains(.,'some string')]") | |
expect(response.body).to have_xpath("//p//a", text: /re[dab]i/i, count: 1) | |
# Can take both xpath and css as input and can take arguments similar to both have_css and have_xpath | |
expect(response.body).to have_selector(:xpath, "//p/h1") | |
expect(response.body).to have_selector(:css, "p a#movie_edit_path") | |
# For making capybara to take css as default selector | |
Capybara.default_selector = :css | |
expect(response.body).to have_selector("input") # checks for the presence of the input tag | |
expect(response.body).to have_selector("input", value: "Twelve Angry Men") # checks for input tag with value | |
expect(response.body).to_not have_selector("input") | |
# For making capybara to take xpath as default selector | |
Capybara.default_selector = :xpath | |
expect(response.body).to have_selector("//input") # checks for the presence of the input tag | |
expect(response.body).to have_selector("//input", value: "Twelve Angry Men") # checks for input tag with value | |
# To access elements inside form | |
expect(response.body).to have_field("FirstName") # checks for presence of a input field named FirstName in a form | |
expect(response.body).to have_field("FirstName", value: "Rambo") | |
expect(response.body).to have_field("FirstName", with: "Rambo") | |
# Checking for a link | |
expect(response.body).to have_link("Foo") | |
expect(response.body).to have_link("Foo", href: "google.com") | |
expect(response.body).to_not have_link("Foo", href: "google.com") |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment