# 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")