Nothing
library(codelist)
source("helpers.R")
# In case user has set this
op <- options(CLLOCALE=NULL)
data(objectcodes)
codelist <- as.codelist(objectcodes)
# Default settings
x <- c("A", "X", "A01", NA)
res <- labels.code(x, codelist = codelist)
l <- codelist$label[codelist$code != "X" & codelist$locale == "EN"]
expect_equal(res, factor(c("Toys", NA, "Teddy Bear", NA), levels = l))
# add missing category
x <- c("A", "X", "A01", NA)
res <- labels.code(x, codelist = codelist, missing = FALSE)
l <- codelist$label[codelist$locale == "EN"]
expect_equal(res, factor(c("Toys", "Unknown object", "Teddy Bear", NA), levels = l))
# only levels present
x <- c("A", "X", "A01", NA)
res <- labels.code(x, codelist = codelist, droplevels = TRUE)
expect_equal(res, factor(c("Toys", NA, "Teddy Bear", NA),
levels = c("Toys", "Teddy Bear")))
# add missing category & only levels present
x <- c("A", "X", "A01", NA)
res <- labels.code(x, codelist = codelist, missing = FALSE, droplevels = TRUE)
l <- codelist$label[codelist$locale == "EN"]
expect_equal(res, factor(c("Toys", "Unknown object", "Teddy Bear", NA),
levels = c("Toys", "Teddy Bear", "Unknown object")))
# invalid values in x
x <- c("FOO", "X", "A01", NA)
expect_error(res <- labels.code(x, codelist = codelist))
# invalid codelist
x <- c("A", "X", "A01", NA)
expect_error(res <- labels.code(x, codelist = "FOO"))
# Pass codelist in attribute of x
x <- c("A", "X", "A01", NA)
attr(x, "codelist") <- codelist
res <- labels.code(x)
l <- codelist$label[codelist$code != "X" & codelist$locale == "EN"]
expect_equal(res, factor(c("Toys", NA, "Teddy Bear", NA), levels = l))
# Pass codelist in attribute of x; only levels present
x <- c("A", "X", "A01", NA)
attr(x, "codelist") <- codelist
res <- labels.code(x, missing = FALSE, droplevels = TRUE)
l <- codelist$label[codelist$locale == "EN"]
expect_equal(res, factor(c("Toys", "Unknown object", "Teddy Bear", NA),
levels = c("Toys", "Teddy Bear", "Unknown object")))
# set locale to NL
x <- c("A", "X", "A01", NA)
res <- labels.code(x, codelist = codelist, locale = "NL")
l <- codelist$label[codelist$code != "X" & codelist$locale == "NL"]
expect_equal(res, factor(c("Speelgoed", NA, "Teddybeer", NA), levels = l))
# set locale to EN; explicit
x <- c("A", "X", "A01", NA)
res <- labels.code(x, codelist = codelist, locale = "EN")
l <- codelist$label[codelist$code != "X" & codelist$locale == "EN"]
expect_equal(res, factor(c("Toys", NA, "Teddy Bear", NA), levels = l))
# invalid locale
x <- c("A", "X", "A01", NA)
expect_warning(res <- labels.code(x, codelist = codelist, locale = "FOO"))
l <- codelist$label[codelist$code != "X" & codelist$locale == "EN"]
expect_equal(res, factor(c("Toys", NA, "Teddy Bear", NA), levels = l))
# set locale to NL using option
options(CLLOCALE="NL")
x <- c("A", "X", "A01", NA)
res <- labels.code(x, codelist = codelist)
l <- codelist$label[codelist$code != "X" & codelist$locale == "NL"]
expect_equal(res, factor(c("Speelgoed", NA, "Teddybeer", NA), levels = l))
options(CLLOCALE=NULL)
# set locale to EN using option
options(CLLOCALE="EN")
x <- c("A", "X", "A01", NA)
res <- labels.code(x, codelist = codelist)
l <- codelist$label[codelist$code != "X" & codelist$locale == "EN"]
expect_equal(res, factor(c("Toys", NA, "Teddy Bear", NA), levels = l))
options(CLLOCALE=NULL)
# empty x
x <- character(0)
res <- labels.code(x, codelist = codelist)
l <- codelist$label[codelist$code != "X" & codelist$locale == "EN"]
expect_equal(res, factor(character(0), levels = l))
# all missing x
x <- c(NA, NA)
res <- labels.code(x, codelist = codelist)
l <- codelist$label[codelist$code != "X" & codelist$locale == "EN"]
expect_equal(res, factor(c(NA, NA), levels = l))
# x = factor
x <- factor(c("A", "X", "A01", NA))
res <- labels.code(x, codelist = codelist)
l <- codelist$label[codelist$code != "X" & codelist$locale == "EN"]
expect_equal(res, factor(c("Toys", NA, "Teddy Bear", NA), levels = l))
# labelm
x <- c("A", "X", "A01", NA)
res <- to_labels(x, missing = FALSE, codelist = codelist)
res2 <- labels.code(x, codelist = codelist, missing = FALSE)
expect_equal(res, res2)
# Do not convert to codelist
x <- c("A", "X", "A01", NA)
res <- labels.code(x, codelist = objectcodes)
l <- codelist$label[codelist$code != "X" & codelist$locale == "EN"]
expect_equal(res, factor(c("Toys", NA, "Teddy Bear", NA), levels = l))
# Locale missing in codelist
codelist2 <- codelist[codelist$locale == "EN", ]
codelist2$locale <- NULL
x <- c("A", "X", "A01", NA)
res <- labels.code(x, codelist = codelist2)
l <- codelist2$label[codelist2$code != "X"]
expect_equal(res, factor(c("Toys", NA, "Teddy Bear", NA), levels = l))
# reset options
options(op)
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.