tests/testthat/test-aemet_forecast_hourly.R

test_that("Online", {
  skip_on_cran()
  skip_if_offline()
  skip_if_not(aemet_detect_api_key(), message = "No API KEY")

  meta <- aemet_forecast_hourly("a", extract_metadata = TRUE)
  # Same as
  meta2 <- aemet_forecast_hourly("NOEXIST",
    extract_metadata = TRUE,
    verbose = TRUE
  )
  expect_identical(meta, meta2)


  st <- aemet_munic$municipio[1:3]

  # Default
  expect_message(alll <- aemet_forecast_hourly(st, verbose = TRUE))
  expect_s3_class(alll, "tbl_df")
  expect_identical(unique(alll$municipio), st)

  # Same as
  stn <- as.numeric(st)

  allln <- aemet_forecast_hourly(stn)
  expect_identical(alll, allln)
  # NUll
  expect_snapshot(emp <- aemet_forecast_hourly("naha"))

  expect_s3_class(emp, "tbl_df")
  expect_equal(nrow(emp), 0)
  expect_snapshot(dput(emp))

  # Extract some vars
  expect_snapshot(vv <- aemet_forecast_vars_available(alll))

  expect_snapshot(aemet_forecast_tidy(alll, "hagaga"), error = TRUE)

  # Extract everythig
  for (v in vv) {
    tt <- aemet_forecast_tidy(alll, v)
    expect_s3_class(tt, "tbl_df")
  }
})

Try the climaemet package in your browser

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

climaemet documentation built on April 4, 2025, 4:13 a.m.