tests/testthat/test-codemeta_reader.R

context("codemeta_reader")

z <- system.file('extdata/codemeta.json', package = "handlr")

test_that("codemeta_reader: works", {
  skip_on_cran()

  x <- codemeta_reader(z)

  expect_is(codemeta_reader, "function")
  expect_is(x, "handl")
  expect_is(x$id, "character")
  expect_match(x$id, "doi.org")
  expect_match(attr(x, "from"), "codemeta")
  expect_match(attr(x, "source_type"), "file")
  expect_match(attr(x, "file"), ".json")
  expect_false(attr(x, "many"))
})

test_that("codemeta_reader: read from string", {
  skip_on_cran()
  
  str <- paste0(readLines(z), collapse = "")
  x <- codemeta_reader(str)
  
  expect_is(x, "handl")
  expect_is(x$id, "character")
  expect_match(x$id, "doi.org")
  expect_match(attr(x, "from"), "codemeta")
  expect_match(attr(x, "source_type"), "string")
  expect_equal(attr(x, "file"), "")
  expect_false(attr(x, "many"))
})

test_that("codemeta_reader fails well", {
  expect_error(codemeta_reader(), "\"x\" is missing")
  expect_error(codemeta_reader(5), "x must be of class character, json")
})
ropensci/handlr documentation built on April 26, 2022, 7:37 a.m.