tests/testthat/test-search_scientific.R

context("search_scientific")

test_that("search_scientific basic functionality works", {
  vcr::use_cassette("search_scientific", {
    aa <- search_scientific("Tardigrada")

    expect_is(aa, "data.frame")
    expect_is(aa, "tbl_df")

    expect_is(aa$tsn, "character")
    expect_gt(NROW(aa), 0)
  })
})

test_that("search_scientific - xml works", {
  vcr::use_cassette("search_scientific-xml", {
    aa <- search_scientific("Tardigrada", wt = "xml")

    expect_is(aa, "character")
    expect_true(grepl("xmlns", aa))
  })
})

test_that("search_scientific - raw JSON works", {
  vcr::use_cassette("search_scientific-json", {
    aa <- search_scientific("Tardigrada", raw = TRUE)

    expect_is(aa, "character")
    expect_false(grepl("xmlns", aa))
  })
})

test_that("search_scientific fails well", {
  expect_error(search_scientific(), "\"x\" is missing")
  expect_error(search_scientific("asdfadf", wt = "ffa"), "'wt' must be one of")

  vcr::use_cassette("search_scientific-fail-well", {
    # query with no results lead to 0 row data.frame's
    tmp <- search_scientific(x = "asdfadf", wt = "json")
    expect_is(tmp, "tbl_df")
    expect_equal(NROW(tmp), 0)
  })
})
ropensci/ritis documentation built on Sept. 29, 2022, 8:52 p.m.