tests/testthat/test-01-bPEESE.R

context("Model fitting for bPEESE")

# Load common test helpers
source(testthat::test_path("common-functions.R"))
skip_on_cran()
skip_if_not_installed("metadat")
skip_if_not_installed("metafor")
skip_refit_if_cached("bPEESE")

### Uses examples from the metafor package
test_that("bPEESE fits PEESE metafor-reference model", {
  ### fit PEESE model
  data(dat.lehmann2018, package = "metadat")
  fit_PEESE.metafor <- metafor::rma(yi, vi, mods = ~ vi, data = dat.lehmann2018)

  # using RoBMA package
  fit.bPEESE <- bPEESE(yi, vi, data = dat.lehmann2018, measure = "SMD", seed = 1, silent = TRUE)
  fit.bPEESE <- add_marglik(fit.bPEESE)
  fit.bPEESE <- suppressWarnings(add_loo(fit.bPEESE))
  save_fit("dat.lehmann2018-PEESE", fit.bPEESE, info = list(metafor = fit_PEESE.metafor))

  expect_s3_class(fit.bPEESE, "bPEESE")
})

test_that("bPEESE fits negative-direction PEESE metafor-reference model", {
  ### fit PEESE model
  data(dat.lehmann2018, package = "metadat")
  dat.lehmann2018$yi <- -dat.lehmann2018$yi
  fit_PEESE.metafor <- metafor::rma(yi, vi, mods = ~ vi, data = dat.lehmann2018)

  # using RoBMA package
  fit.bPEESE <- bPEESE(yi, vi, data = dat.lehmann2018, measure = "SMD", seed = 1, silent = TRUE)
  fit.bPEESE <- add_marglik(fit.bPEESE)
  fit.bPEESE <- suppressWarnings(add_loo(fit.bPEESE))
  save_fit("dat.lehmann2018-PEESE_neg", fit.bPEESE, info = list(metafor = fit_PEESE.metafor))

  expect_s3_class(fit.bPEESE, "bPEESE")
})

test_that("bPEESE fits PEESE meta-regression model", {
  ### fit PEESE model
  data(dat.lehmann2018, package = "metadat")
  fit_PEESE.metafor <- metafor::rma(yi, vi, mods = ~ vi + Preregistered, data = dat.lehmann2018)

  # using RoBMA package
  fit.bPEESE <- bPEESE(yi, vi, mods = ~ Preregistered, data = dat.lehmann2018, measure = "SMD", seed = 1, silent = TRUE)
  fit.bPEESE <- add_marglik(fit.bPEESE)
  fit.bPEESE <- suppressWarnings(add_loo(fit.bPEESE))
  save_fit("dat.lehmann2018-PEESEreg", fit.bPEESE, info = list(metafor = fit_PEESE.metafor, mods = "Preregistered"))

  expect_s3_class(fit.bPEESE, "bPEESE")
})

Try the RoBMA package in your browser

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

RoBMA documentation built on May 7, 2026, 5:08 p.m.