-
Notifications
You must be signed in to change notification settings - Fork 10
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #40 from rOpenGov/24-FV22TOTA
Fix #24
- Loading branch information
Showing
13 changed files
with
97 additions
and
49 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,5 @@ | ||
linters: linters_with_defaults() # see vignette("lintr") | ||
linters: linters_with_defaults( | ||
cyclocomp_linter(complexity_limit = 17L)) | ||
encoding: "UTF-8" | ||
exclusions: list( | ||
"tests") |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
#' Helper function to determine wether or not to include the id in a variable | ||
#' option | ||
#' | ||
#' @param meta_data Meta data object for the table of inquiry | ||
#' @noRd | ||
dst_determine_overlaps <- function(meta_data) { | ||
# Get variable names | ||
var_names <- get_vars(meta_data) | ||
|
||
# Get options for all variable names | ||
options <- get_var_options(meta_data, var_names) | ||
|
||
# Index over all vars to determine if there is duplicates | ||
dup <- list() | ||
|
||
for (i in seq_along(var_names)) { | ||
dup[i] <- length( | ||
options[[var_names[i]]] | ||
) == length( | ||
unique(options[[var_names[i]]]) | ||
) | ||
} | ||
|
||
# If any of the option/vars include duplicates, we should include the id | ||
return(any(unlist(dup))) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,3 @@ | ||
tables <- dst_get_tables(lang = "en") | ||
|
||
usethis::use_data(tables, overwrite = TRUE) | ||
|
||
# tables_da <- dst_get_tables(lang = "da") | ||
# | ||
# usethis::use_data(tables_da, overwrite = TRUE) |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,51 +1,49 @@ | ||
context("dst_date_parse") | ||
|
||
test_that("dst_date_parse gives the correct class.", { | ||
|
||
exp_dates <- c("POSIXct", "POSIXt") | ||
|
||
# Daily | ||
expect_equal(class(dst_date_parse(dst_date = "2000M01D01")), exp_dates) | ||
expect_equal(class(dst_date_parse(dst_date = c("2000M01D20", "2000M02D21", "2000M03D23", "2000M04D24"))), exp_dates) | ||
|
||
# Monthly | ||
expect_equal(class(dst_date_parse(dst_date = "2000M01")), exp_dates) | ||
expect_equal(class(dst_date_parse(dst_date = c("2000M01", "2000M02", "2000M03", "2000M04", "2000M10", "2000M11"))), exp_dates) | ||
|
||
# Quarterly | ||
expect_equal(class(dst_date_parse(dst_date = "2000Q1")), exp_dates) | ||
expect_equal(class(dst_date_parse(dst_date = "2000Q2")), exp_dates) | ||
expect_equal(class(dst_date_parse(dst_date = "2000Q3")), exp_dates) | ||
expect_equal(class(dst_date_parse(dst_date = "2000Q4")), exp_dates) | ||
expect_equal(class(dst_date_parse(dst_date = c("2000Q1", "2000Q2", "2000Q3", "2000Q4"))), exp_dates) | ||
|
||
# Yearly | ||
expect_equal(class(dst_date_parse(dst_date = "2000")), exp_dates) | ||
expect_equal(class(dst_date_parse(dst_date = c("2000", "2000", "2000", "2000"))), exp_dates) | ||
|
||
expect_equal(class(dst_date_parse(dst_date = c("2015H1", "2015H2"))), exp_dates) | ||
expect_equal(as.character(dst_date_parse(dst_date = c("2015H1", "2015H2"))), c("2015-01-01", "2015-07-01")) | ||
|
||
}) | ||
|
||
|
||
test_that("Test that dst_date_parse stops when the input is bad.", { | ||
|
||
# Daily | ||
expect_error(dst_date_parse(dst_date = "2000M01D35")) | ||
expect_error(dst_date_parse(dst_date = "2000M10D40")) | ||
|
||
# Monthly | ||
expect_error(dst_date_parse(dst_date = "20000M01")) | ||
expect_error(dst_date_parse(dst_date = "2000M101")) | ||
expect_error(dst_date_parse(dst_date = "2000M13")) | ||
|
||
# Quarterly | ||
expect_error(dst_date_parse(dst_date = "2000Q0")) | ||
expect_error(dst_date_parse(dst_date = "2000Q5")) | ||
|
||
# Yearly | ||
expect_error(dst_date_parse(dst_date = "20000")) | ||
expect_error(dst_date_parse(dst_date = "200")) | ||
|
||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
test_that("Overlap detection works", { | ||
expect_true(dst_determine_overlaps(dst_meta("FV22TOTA"))) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,28 +1,25 @@ | ||
|
||
context("dst_get_data") | ||
|
||
test_that("dst_get_data returns an error when the limit is reached.", { | ||
|
||
expect_error(dst_get_data(table = "folk1", | ||
query = list(CIVILSTAND = "*", | ||
STATSB = "*", | ||
query = list(CIVILSTAND = "*", | ||
STATSB = "*", | ||
HERKOMST = c("Personer med dansk oprindelse", "Efterkommere"), | ||
TID = "*", | ||
ALDER = "*"), lang = "da")) | ||
|
||
}) | ||
|
||
|
||
test_that("dst_get_data is parsing the data correctly when 'en' and 'da' are selected as language. The API returns decimal numbers with both , and .", { | ||
|
||
expect_equal(class(dst_get_data("AUP01", ALDER = "*", TID = "*", lang = "da", format = "CSV")$value), "numeric") | ||
|
||
}) | ||
|
||
test_that("dst_get_data fails with the BULK format when not all parameters have values.", { | ||
|
||
expect_error(dst_get_data("AUP01", ALDER = "*", TID = "*", lang = "da", format = "BULK")) | ||
|
||
}) | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,4 @@ | ||
|
||
|
||
context("dst_query_match") | ||
|
||
test_that("The function fails when mandatory values are not supplied.",{ | ||
|
||
expect_error(dst_query_match(table = "NRHP", meta_data = NULL, lang = "en", query = list(TRANSAKT = "P.1 Output", Tid = "1993"))) | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
test_that("Tables with identifyers with the same name but different ids are parsed properly", { | ||
# This tests that the issue in https://github.com/rOpenGov/dkstat/issues/24 | ||
# does not occur | ||
|
||
table <- dst_get_data( | ||
table = "FV22TOTA", | ||
VALRES = "*", | ||
OMRÅDE = "*", | ||
Tid = "*", | ||
lang = "da", | ||
format = "BULK" | ||
) | ||
|
||
expect_equal(nrow(unique(table)), nrow(table)) | ||
expect_equal(nrow(table) - nrow(unique(table)), 0) | ||
|
||
}) |