skip_if_not_installed("survival")

m1 <- survival::survfit(survival::Surv(time, status) ~ sex + age + ph.ecog, data = survival::lung)

test_that("model_info", {
  expect_true(model_info(m1)$is_logit)
  expect_false(model_info(m1)$is_linear)
})

test_that("find_predictors", {
  expect_identical(find_predictors(m1), list(conditional = c("sex", "age", "ph.ecog")))
  expect_null(find_predictors(m1, effects = "random"))
})

test_that("find_response", {
  expect_identical(find_response(m1), "survival::Surv(time, status)")
  expect_identical(find_response(m1, combine = FALSE), c("time", "status"))
})

test_that("link_inverse", {
  expect_equal(link_inverse(m1)(0.2), plogis(0.2), tolerance = 1e-5)
})

test_that("get_data", {
  expect_identical(nrow(get_data(m1)), 227L)
  expect_named(get_data(m1), c("time", "status", "sex", "age", "ph.ecog"))
})

test_that("find_formula", {
  expect_length(find_formula(m1), 1)
  expect_equal(
    find_formula(m1),
    list(conditional = as.formula(
      "survival::Surv(time, status) ~ sex + age + ph.ecog"
    )),
    ignore_attr = TRUE
  )
})

test_that("find_variables", {
  expect_identical(find_variables(m1), list(
    response = c("time", "status"),
    conditional = c("sex", "age", "ph.ecog")
  ))
  expect_identical(
    find_variables(m1, flatten = TRUE),
    c("time", "status", "sex", "age", "ph.ecog")
  )
})

test_that("n_obs", {
  expect_identical(n_obs(m1), 227L)
})

test_that("linkfun", {
  expect_false(is.null(link_function(m1)))
})

test_that("is_multivariate", {
  expect_false(is_multivariate(m1))
})

test_that("find_terms", {
  expect_identical(
    find_terms(m1),
    list(
      response = "Surv(time, status)",
      conditional = c("sex", "age", "ph.ecog")
    )
  )
})

test_that("find_statistic", {
  expect_null(find_statistic(m1))
})

skip_if_not_installed("withr")
withr::with_package(
  "survival",
  test_that("find_predictors works with strata", {
    data(mtcars)
    mod <- suppressWarnings(survival::clogit(
      am ~ mpg + cyl + mpg:cyl + survival::strata(carb, gear),
      data = mtcars
    ))
    out <- find_predictors(mod)
    expect_identical(out, list(conditional = c("mpg", "cyl"), strata = c("carb", "gear")))

    # works with reserved arguments inside "strata()"
    mod <- suppressWarnings(survival::clogit(
      am ~ mpg + cyl + mpg:cyl + survival::strata(carb, gear, shortlabel = TRUE),
      data = mtcars
    ))
    out <- find_predictors(mod)
    expect_identical(out, list(conditional = c("mpg", "cyl"), strata = c("carb", "gear")))
  })
)