tests/testthat/test-subsetToCodesInUse.R

test_that("tests with mock db", {
  skip_on_cran()
  # mock db
  cdm <- mockVocabRef("database")

  codes <- getCandidateCodes(
    cdm = cdm,
    keywords = "arthritis",
    domains = "Condition",
    includeDescendants = FALSE
  )
  expect_true(all(c("4", "5") %in%
                    subsetToCodesInUse(omopgenerics::newCodelist(list("cs" = codes$concept_id)),
                                       cdm = cdm)[[1]]))

  expect_warning(expect_true(length(subsetToCodesInUse(
    omopgenerics::newCodelist(list("cs1" = codes$concept_id,
                                   "cs2" = 999L)),
    cdm = cdm)) == 1)) # will just have cs1

  x <- subsetToCodesInUse(omopgenerics::newCodelist(list("cs" = codes$concept_id)),
                          cdm = cdm)
  expect_true(inherits(x, "codelist"))
  x <- subsetToCodesInUse(omopgenerics::newCodelist(list("cs" = codes$concept_id)),
                          cdm = cdm)
  expect_true(inherits(x, "codelist"))
  x <- list("concepts" = cdm$concept |>
              dplyr::filter(concept_id %in% c(4L,5L,6L)) |>
              dplyr::select("concept_id", "concept_name", "domain_id", "vocabulary_id") |>
              dplyr::mutate("ancestor_concept_id" = 999L) |>
              dplyr::collect()) |>
    omopgenerics::newCodelistWithDetails()
  x <- subsetToCodesInUse(x,
                          cdm = cdm)
  expect_true(inherits(x, "codelist_with_details"))
  expect_true(all(x$concepts$concept_id == c(4L, 5L)))

  # no codes in db
  codes <- getCandidateCodes(
    cdm = cdm,
    keywords = "Musculoskeletal",
    domains = "Condition",
    includeDescendants = FALSE
  )
  expect_warning(subsetToCodesInUse(omopgenerics::newCodelist(list("cs" = codes$concept_id)),
                                    cdm = cdm))

  CDMConnector::cdmDisconnect(cdm)

  cdm <- omock::mockCdmReference()
  expect_error(codesInUse(cdm))
  expect_error(subsetToCodesInUse(x = list("a" = 1), cdm = cdm))
})

test_that("sql server with achilles", {

  testthat::skip_if(Sys.getenv("CDM5_SQL_SERVER_SERVER") == "")
  testthat::skip_if(Sys.getenv("SQL_SERVER_DRIVER") == "")
  testthat::skip_if(packageVersion("CDMConnector") <= "1.2.0")

  db <- DBI::dbConnect(odbc::odbc(),
                       Driver   = Sys.getenv("SQL_SERVER_DRIVER"),
                       Server   = Sys.getenv("CDM5_SQL_SERVER_SERVER"),
                       Database = Sys.getenv("CDM5_SQL_SERVER_CDM_DATABASE"),
                       UID      = Sys.getenv("CDM5_SQL_SERVER_USER"),
                       PWD      = Sys.getenv("CDM5_SQL_SERVER_PASSWORD"),
                       TrustServerCertificate="yes",
                       Port     = Sys.getenv("CDM5_SQL_SERVER_PORT"))
  cdm <- CDMConnector::cdmFromCon(db,
                                  cdmSchema = c("CDMV54", "dbo"),
                                  achillesSchema = c("CDMV54", "dbo"),
                                  writeSchema = c("ohdsi", "dbo"))

  asthma_codes <- getCandidateCodes(
    cdm = cdm,
    keywords = "asthma",
    domains = c("Condition"),
    includeDescendants = TRUE
  )
  asthma_cl <- omopgenerics::newCodelist(list("cs" = asthma_codes$concept_id))

  asthma_codes_present <- subsetToCodesInUse(x = asthma_cl,
                                             cdm = cdm)

  expect_equal(sort(asthma_codes_present[[1]]),
               sort(cdm$condition_occurrence |>
                      dplyr::filter(.data$condition_concept_id %in%
                                      !!asthma_codes$concept_id) |>
                      dplyr::select("condition_concept_id") |>
                      dplyr::distinct() |>
                      dplyr::pull()))


  CDMConnector::cdmDisconnect(cdm)
})

Try the CodelistGenerator package in your browser

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

CodelistGenerator documentation built on Dec. 17, 2025, 5:06 p.m.