tests/testthat/test-nulls-classes.R

describe("new_null_distribution", {
  it("errors for non-numeric observed", {
    nulls <- matrix(1:10, nrow = 5, ncol = 2)
    expect_error(
      new_null_distribution(nulls, "test", letters[1:5]),
      "numeric"
    )
  })

  it("creates a valid null_distribution object", {
    nulls <- matrix(rnorm(100), nrow = 10, ncol = 10)
    observed <- rnorm(10)
    nd <- new_null_distribution(nulls, "burt2020", observed, list(nh = 25))

    expect_s3_class(nd, "null_distribution")
    expect_equal(nd$method, "burt2020")
    expect_equal(nd$n_perm, 10)
    expect_equal(nd$n, 10)
    expect_identical(nd$nulls, nulls)
    expect_identical(nd$observed, observed)
    expect_equal(nd$params, list(nh = 25))
  })
})

describe("validate_null_distribution", {
  it("passes for valid objects", {
    nulls <- matrix(rnorm(50), nrow = 5, ncol = 10)
    nd <- new_null_distribution(nulls, "moran", rnorm(5))
    expect_invisible(validate_null_distribution(nd))
  })

  it("errors for non-null_distribution", {
    expect_error(validate_null_distribution(list()), "null_distribution")
  })

  it("errors when observed length mismatches nulls rows", {
    nulls <- matrix(rnorm(50), nrow = 5, ncol = 10)
    expect_error(
      new_null_distribution(nulls, "moran", rnorm(3)),
      "observed.*length"
    )
  })

  it("errors for non-numeric nulls", {
    expect_error(
      new_null_distribution("not a matrix", "test", 1),
      "numeric matrix"
    )
  })

  it("errors for non-character method", {
    expect_error(
      new_null_distribution(matrix(1:4, 2, 2), 42, 1:2),
      "character string"
    )
  })

  it("errors for corrupted nulls field", {
    nulls <- matrix(rnorm(50), nrow = 5, ncol = 10)
    nd <- new_null_distribution(nulls, "moran", rnorm(5))
    nd$nulls <- "broken"
    expect_error(validate_null_distribution(nd), "matrix")
  })

  it("errors for corrupted observed length", {
    nulls <- matrix(rnorm(50), nrow = 5, ncol = 10)
    nd <- new_null_distribution(nulls, "moran", rnorm(5))
    nd$observed <- rnorm(3)
    expect_error(validate_null_distribution(nd), "observed.*length")
  })
})

describe("print.null_distribution", {
  it("prints method, permutations, and observations", {
    nulls <- matrix(rnorm(50), nrow = 5, ncol = 10)
    nd <- new_null_distribution(nulls, "moran", rnorm(5))
    expect_snapshot(res <- print(nd))
    expect_identical(res, nd)
  })
})

describe("summary.null_distribution", {
  it("returns expected summary fields", {
    nulls <- matrix(rnorm(50), nrow = 5, ncol = 10)
    nd <- new_null_distribution(nulls, "burt2020", rnorm(5))
    s <- summary(nd)

    expect_equal(s$method, "burt2020")
    expect_equal(s$n_perm, 10)
    expect_equal(s$n, 5)
    expect_length(s$null_mean, 5)
    expect_length(s$null_sd, 5)
  })
})

describe("as.matrix.null_distribution", {
  it("returns the nulls matrix", {
    nulls <- matrix(1:20, nrow = 4, ncol = 5)
    nd <- new_null_distribution(nulls, "moran", 1:4)
    expect_identical(as.matrix(nd), nulls)
  })
})

describe("plot.null_distribution", {
  it("returns a ggplot object when ggplot2 available", {
    skip_if_not_installed("ggplot2")
    nulls <- matrix(rnorm(100), nrow = 10, ncol = 10)
    nd <- new_null_distribution(nulls, "burt2020", rnorm(10))
    p <- plot(nd, parcel = 1)
    expect_s3_class(p, "gg")
  })
})

Try the neuromapr package in your browser

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

neuromapr documentation built on Feb. 27, 2026, 5:08 p.m.