Nothing
testthat::skip_if_not_installed("xml2")
# Find path to configuration file in package.
config <- system.file("config.xml", package = "familiar")
# Load the configuration file
config <- familiar:::.load_configuration_file(config)
# Check whether the main branches have the correct names.
# Find names of parent nodes.
config_node_names <- names(config)
expected_node_names <- familiar:::.get_all_configuration_parent_node_names()
testthat::test_that("1. All parent nodes are present in the configuration file.", {
testthat::expect_equal(all(config_node_names %in% expected_node_names), TRUE)
testthat::expect_equal(all(expected_node_names %in% config_node_names), TRUE)
})
testthat::test_that("2. All parameters are specified.", {
config_args <- unique(unlist(sapply(config, names)))
testthat::expect_equal(all(config_args %in% familiar:::.get_all_parameter_names()), TRUE)
testthat::expect_equal(all(familiar:::.get_all_parameter_names() %in% config_args), TRUE)
if (!all(familiar:::.get_all_parameter_names() %in% config_args)) {
warning(paste0(
"The following parameters are not specified in the configuration file: ",
paste0(setdiff(familiar:::.get_all_parameter_names(), config_args), collapse = ", ")))
}
if (!all(config_args %in% familiar:::.get_all_parameter_names())) {
warning(paste0(
"The following parameters are specified in the configuration file, but not familiar: ",
paste0(setdiff(config_args, familiar:::.get_all_parameter_names()), collapse = ", ")))
}
})
for (parent_node in expected_node_names) {
# Identify the parsing function for the node.
parse_fun <- switch(parent_node,
paths = familiar:::.parse_file_paths,
data = familiar:::.parse_experiment_settings,
run = familiar:::.parse_setup_settings,
preprocessing = familiar:::.parse_preprocessing_settings,
feature_selection = familiar:::.parse_feature_selection_settings,
model_development = familiar:::.parse_model_development_settings,
hyperparameter_optimisation = familiar:::.parse_hyperparameter_optimisation_settings,
evaluation = familiar:::.parse_evaluation_settings
)
# Find the expected arguments.
expected_config_args <- names(as.list(args(parse_fun)))
# Remove "" and "..." and other arguments that are not parameters that can be
# specified using ... .
expected_config_args <- intersect(expected_config_args, familiar:::.get_all_parameter_names())
# Remove specific arguments unless they are shared by a specific function.
if (parent_node != "data") {
expected_config_args <- setdiff(
expected_config_args, c("outcome_type", "development_batch_id")
)
}
if (parent_node != "run") {
expected_config_args <- setdiff(
expected_config_args, "parallel"
)
}
if (parent_node != "feature_selection") {
expected_config_args <- setdiff(
expected_config_args,
c("vimp_aggregation_rank_threshold", "vimp_aggregation_method")
)
}
# Find the argument names.
config_args <- names(config[[parent_node]])
testthat::test_that(paste0("3. All parameters are specified for the \"", parent_node, "\" node."), {
testthat::expect_equal(all(config_args %in% expected_config_args), TRUE)
testthat::expect_equal(all(expected_config_args %in% config_args), TRUE)
if (!all(expected_config_args %in% config_args)) {
warning(paste0(
"The following parameters are not specified in the configuration file under node \"",
parent_node, "\": ",
paste0(setdiff(expected_config_args, config_args), collapse = ", ")))
}
if (!all(config_args %in% expected_config_args)) {
warning(paste0(
"The following parameters are specified in the configuration file under node \"",
parent_node, "\" but not familiar: ",
paste0(setdiff(config_args, expected_config_args), collapse = ", ")))
}
})
}
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.