inst/tinytest/test-outbreak-active-cases.R

# Test just this file: tinytest::run_test_file("inst/tinytest/test-outbreak-active-cases.R")

# Test get_outbreak_size and get_active_cases functions
# These tests verify that:
# 1. get_active_cases() returns the number of infected individuals
# 2. get_outbreak_size() returns the number of infected + recovered individuals

# Create a SIRCONN model -------------------------------------------------------
model <- ModelSIRCONN(
  name = "test virus",
  n = 100,
  prevalence = 0.1,
  contact_rate = 2,
  transmission_rate = 0.5,
  recovery_rate = 0.3
)

verbose_off(model)
run(model, ndays = 15, seed = 123)

# Get model history data (for comparison)
hist_total <- get_hist_total(model)

# Get active cases and outbreak size
active_cases <- get_active_cases(model)
outbreak_size <- get_outbreak_size(model)

# Checking active cases
hist_total_infected <- aggregate(
  counts ~ date,
  data = hist_total[hist_total$state == "Infected", ],
  sum
)

expect_equal(
  hist_total_infected$counts,
  active_cases$active_cases
)

# Checking outbreak size
hist_total_outbreak_size <- aggregate(
  counts ~ date,
  data = hist_total[hist_total$state %in% c("Infected", "Recovered"), ],
  sum
)

expect_equal(
  hist_total_outbreak_size$counts,
  outbreak_size$outbreak_size
)

Try the epiworldR package in your browser

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

epiworldR documentation built on Feb. 21, 2026, 9:07 a.m.