tests/testthat/test-expect-match.R

test_that("extra arguments to matches passed onto grepl", {
  expect_success(expect_match("te*st", "e*", fixed = TRUE))
  expect_success(expect_match("test", "TEST", ignore.case = TRUE))
})

test_that("special regex characters are escaped in output", {
  error <- tryCatch(expect_match("f() test", "f() test"), expectation = function(e) e$message)
  expect_equal(error, "\"f\\(\\) test\" does not match \"f() test\".\nActual value: \"f\\(\\) test\"")
})

test_that("correct reporting of expected label", {
  expect_failure(expect_match("[a]", "[b]"), escape_regex("[a]"), fixed = TRUE)
  expect_failure(expect_match("[a]", "[b]", fixed = TRUE), "[a]", fixed = TRUE)
})

test_that("errors if obj is empty str", {
  x <- character(0)
  err <- expect_error(
    expect_match(x, 'asdf'),
    class = "expectation_failure"
  )
  expect_match(err$message, 'is empty')
})

test_that("prints multiple unmatched values", {
  err <- expect_error(
    expect_match(letters[1:10], 'asdf'),
    class = "expectation_failure"
  )
  expect_match(err$message, "does not match")
})
r-lib/testthat documentation built on April 6, 2019, 2:15 a.m.