AMR/tests/testthat/test-eucast_rules.R

118 lines
5.3 KiB
R
Raw Normal View History

# ==================================================================== #
# TITLE #
# Antimicrobial Resistance (AMR) Analysis #
# #
2019-01-02 23:24:07 +01:00
# SOURCE #
2020-07-08 14:48:06 +02:00
# https://github.com/msberends/AMR #
# #
# LICENCE #
# (c) 2018-2020 Berends MS, Luz CF et al. #
# #
2019-01-02 23:24:07 +01:00
# This R package is free software; you can freely use and distribute #
# it for both personal and commercial purposes under the terms of the #
# GNU General Public License version 2.0 (GNU GPL-2), as published by #
# the Free Software Foundation. #
# #
# We created this package for both routine data analysis and academic #
# research and it was publicly released in the hope that it will be #
# useful, but it comes WITHOUT ANY WARRANTY OR LIABILITY. #
2020-07-08 14:48:06 +02:00
# Visit our website for more info: https://msberends.github.io/AMR. #
# ==================================================================== #
2018-11-16 20:50:50 +01:00
context("eucast_rules.R")
2018-03-27 17:43:42 +02:00
test_that("EUCAST rules work", {
2019-10-15 14:35:23 +02:00
skip_on_cran()
2020-05-16 13:05:47 +02:00
2019-04-05 18:47:39 +02:00
# thoroughly check input table
2019-06-01 20:54:56 +02:00
expect_equal(colnames(eucast_rules_file),
c("if_mo_property", "like.is.one_of", "this_value",
2019-04-05 18:47:39 +02:00
"and_these_antibiotics", "have_these_values",
"then_change_these_antibiotics", "to_value",
2020-09-19 15:15:57 +02:00
"reference.rule", "reference.rule_group",
2020-09-24 00:30:11 +02:00
"reference.version",
"note"))
MOs_mentioned <- unique(eucast_rules_file$this_value)
MOs_mentioned <- sort(trimws(unlist(strsplit(MOs_mentioned[!is_possibly_regex(MOs_mentioned)], ",", fixed = TRUE))))
MOs_test <- suppressWarnings(suppressMessages(mo_name(MOs_mentioned)))
expect_length(MOs_mentioned[MOs_test != MOs_mentioned], 0)
2020-05-16 13:05:47 +02:00
expect_error(suppressWarnings(eucast_rules(example_isolates, col_mo = "Non-existing")))
2019-05-13 12:21:57 +02:00
expect_error(eucast_rules(x = "text"))
expect_error(eucast_rules(data.frame(a = "test")))
expect_error(eucast_rules(data.frame(mo = "test"), rules = "invalid rules set"))
2019-08-07 15:37:39 +02:00
expect_warning(eucast_rules(data.frame(mo = "Escherichia coli", vancomycin = "S", stringsAsFactors = TRUE)))
2020-05-16 13:05:47 +02:00
expect_identical(colnames(example_isolates),
colnames(suppressWarnings(eucast_rules(example_isolates))))
2020-05-16 13:05:47 +02:00
2019-02-27 17:39:39 +01:00
a <- data.frame(mo = c("Klebsiella pneumoniae",
"Pseudomonas aeruginosa",
"Enterobacter aerogenes"),
2018-03-27 17:43:42 +02:00
amox = "-", # Amoxicillin
stringsAsFactors = FALSE)
2019-02-27 17:39:39 +01:00
b <- data.frame(mo = c("Klebsiella pneumoniae",
"Pseudomonas aeruginosa",
"Enterobacter aerogenes"),
2018-10-17 17:32:34 +02:00
amox = "R", # Amoxicillin
2018-03-27 17:43:42 +02:00
stringsAsFactors = FALSE)
2018-11-16 20:50:50 +01:00
expect_identical(suppressWarnings(eucast_rules(a, "mo", info = FALSE)), b)
expect_identical(suppressWarnings(eucast_rules(a, "mo", info = TRUE)), b)
2020-05-16 13:05:47 +02:00
2019-02-27 17:39:39 +01:00
a <- data.frame(mo = c("Staphylococcus aureus",
"Streptococcus group A"),
2019-05-10 16:44:59 +02:00
COL = "-", # Colistin
2018-03-27 17:43:42 +02:00
stringsAsFactors = FALSE)
2019-02-27 17:39:39 +01:00
b <- data.frame(mo = c("Staphylococcus aureus",
"Streptococcus group A"),
2019-05-10 16:44:59 +02:00
COL = "R", # Colistin
2018-03-27 17:43:42 +02:00
stringsAsFactors = FALSE)
2018-11-16 20:50:50 +01:00
expect_equal(suppressWarnings(eucast_rules(a, "mo", info = FALSE)), b)
2020-05-16 13:05:47 +02:00
2018-11-01 20:23:33 +01:00
# piperacillin must be R in Enterobacteriaceae when tica is R
library(dplyr)
expect_equal(suppressWarnings(
example_isolates %>%
2019-05-10 16:44:59 +02:00
mutate(TIC = as.rsi("R"),
PIP = as.rsi("S")) %>%
2020-09-24 00:30:11 +02:00
eucast_rules(col_mo = "mo", version_expertrules = 3.1) %>%
left_join_microorganisms() %>%
filter(family == "Enterobacteriaceae") %>%
2019-05-10 16:44:59 +02:00
pull(PIP) %>%
unique() %>%
as.character()),
"R")
2020-05-16 13:05:47 +02:00
2019-05-10 16:44:59 +02:00
# Azithromicin and Clarythromycin must be equal to Erythromycin
2020-05-16 13:05:47 +02:00
a <- eucast_rules(data.frame(mo = example_isolates$mo,
ERY = example_isolates$ERY,
AZM = as.rsi("R"),
CLR = as.rsi("R"),
2020-09-24 00:30:11 +02:00
stringsAsFactors = FALSE),
version_expertrules = 3.1)$CLR
2020-05-16 13:05:47 +02:00
b <- example_isolates$ERY
2018-10-17 17:32:34 +02:00
expect_identical(a[!is.na(b)],
b[!is.na(b)])
2020-05-16 13:05:47 +02:00
2018-10-17 17:32:34 +02:00
# amox is inferred by benzylpenicillin in Kingella kingae
expect_equal(
2019-01-03 23:56:19 +01:00
suppressWarnings(
as.list(eucast_rules(
data.frame(mo = as.mo("Kingella kingae"),
2019-05-10 16:44:59 +02:00
PEN = "S",
AMX = "-",
2019-01-03 23:56:19 +01:00
stringsAsFactors = FALSE)
2019-05-10 16:44:59 +02:00
, info = FALSE))$AMX
2019-01-03 23:56:19 +01:00
),
2018-10-17 17:32:34 +02:00
"S")
2020-05-16 13:05:47 +02:00
2018-11-30 12:05:59 +01:00
# also test norf
expect_output(suppressWarnings(eucast_rules(example_isolates %>% mutate(NOR = "S", NAL = "S"), info = TRUE)))
2020-05-16 13:05:47 +02:00
2018-11-30 12:05:59 +01:00
# check verbose output
expect_output(suppressWarnings(eucast_rules(example_isolates, verbose = TRUE, info = TRUE)))
2020-05-16 13:05:47 +02:00
2018-03-27 17:43:42 +02:00
})