tests/testthat/test-bold_identify.R

context("bold_identify")

test_that("bold_identify returns the correct object", {
  skip_on_cran()
  vcr::use_cassette("bold_identify", {
    test <- bold_identify(sequences = sequences$seq1)
  })
  expect_is(test, 'list')
  expect_is(test[[1]], 'data.frame')
  expect_is(test[[1]]$ID, 'character')
})

test_that("bold_identify returns the correct object (db)", {
  skip_on_cran()

  vcr::use_cassette("bold_identify", {
    test <- bold_identify(sequences = sequences$seq1, db = 'COX1_SPECIES')
  })
  expect_is(test, 'list')
  expect_is(test[[1]], 'data.frame')
  expect_is(test[[1]]$ID, 'character')
})

test_that("bold_identify returns the correct object (response)", {
  skip_on_cran()
  vcr::use_cassette("bold_identify", {
    test <- bold_identify(sequences = sequences$seq1, response = TRUE)
  })
  expect_is(test, "list")
  test <- test[[1]]
  expect_is(test$response, "HttpResponse")
  expect_equal(test$response$status_code, 200)
  expect_equal(test$response$response_headers$`content-type`, "text/xml")
  expect_is(test$warning, "character")
  expect_equal(test$warning, "")
})

test_that("bold_identify works for XML that contains &", {
  skip_on_cran()
  test_seq <- "AACCCTATACTTTTTATTTGGAATTTGAGCGGGTATAGTAGGTACTAGCTTAAGTATATTAATTCGTCTAGAGCTAGGACAACCCGGTGTATTTTTAGAAGATGACCAAACCTATAACGTTATTGTAACAGCCCACGCTTTTATTATAATTTTCTTCATAATTATACCAATCATAATTGGA"
  vcr::use_cassette("bold_identify", {
    test <- bold_identify(test_seq)
    expect_is(test, 'list')
    expect_is(test[[1]], 'data.frame')
    expect_is(test[[1]]$ID, 'character')
  })
})

test_that("bold_identify skips the identification when the sequences has invalid characters or when the sequence is too short", {
    test <- bold_identify(sequences = c(substr(sequences$seq1, 1, 50), gsub("N", "0", sequences$seq3)))
  expect_is(test, 'list')
  expect_true(all(is.na(test)))
  expect_length(attributes(test[[1]]), 2L)
  expect_equal(attr(test[[1]], "error"), "Sequence must be at least 80 bp")
  expect_equal(attr(test[[2]], "error"), "Sequence contains invalid characters")
})

test_that("bold_identify fails well", {
  expect_error(bold_identify(),
    "argument 'sequences' is missing, with no default")
  expect_error(bold_identify(sequences = 1),
    "'sequences' must be of class character")
  expect_error(bold_identify(sequences = "", db = "test"),
               "'test' is not a valid db")
  expect_error(bold_identify(sequences = "", db = c("COX1", "COX1_SPECIES")),
    "'db' must be length 1")
})
ropensci/bold documentation built on Sept. 10, 2023, 11:50 p.m.