tests/testthat/test-read_metro_area.R

context("read_metro_area")

# skip tests because they take too much time
skip_if(Sys.getenv("TEST_ONE") != "")
testthat::skip_on_cran()

# Reading the data -----------------------

test_that("read_metro_area", {

  # read data and check sf object
  expect_true(is(read_metro_area(year=1970), "sf"))
  test_sf <- read_metro_area(year=2001)
  expect_true(is(test_sf, "sf"))

  # filter state code
  test_sf <- read_metro_area(code_state = 33)
  expect_true(is(test_sf, "sf"))
  expect_true(33 %in% unique(test_sf$code_state))

  test_sf <- read_metro_area(code_state = c(33, 35))
  expect_true(is(test_sf, "sf"))
  expect_true(all(c(33, 35) %in% unique(test_sf$code_state)))

  # filter state abbrev
  test_sf <- read_metro_area(code_state = 'RJ')
  expect_true(is(test_sf, "sf"))
  expect_true('RJ' %in% unique(test_sf$abbrev_state))

  test_sf <- read_metro_area(code_state = c('RJ', 'SP'))
  expect_true(is(test_sf, "sf"))
  expect_true(all(c('RJ', 'SP') %in% unique(test_sf$abbrev_state)))

})



# ERRORS and messagens  -----------------------
test_that("read_metro_area", {

  # Wrong year
  expect_error(read_metro_area(year=9999999))
  expect_error(read_metro_area(year="xxx"))
  expect_error(read_metro_area(year=NULL))

  # filter state
  expect_error(read_metro_area(code_state = c('RJ', 33)))
  expect_error(read_metro_area(code_state = 'banana'))
  expect_error(read_metro_area(code_state = 999999999))

})

Try the geobr package in your browser

Any scripts or data that you put into this service are public.

geobr documentation built on May 29, 2024, 10:27 a.m.