inst/unitTests/runTests.R

pkg <- "sp23design"

if (require("RUnit", quietly = TRUE)) {
  library(package=pkg, character.only = TRUE)
  if (!(exists("path") && file.exists(path)))
    path <- system.file("unitTests", package = pkg)

  ## --- Testing ---

  ## Define tests
  testSuite <- defineTestSuite(name = paste(pkg, "unit tests"),
                               dirs = path,
                               testFileRegexp="^runitTests.R$",
                               testFuncRegexp = "^test.+",
                               rngKind = "Mersenne-Twister",
                               rngNormalKind = "Inversion")

  if (interactive()) {
    cat("Now have RUnit Test Suite 'testSuite' for package '",
        pkg, "' :\n", sep='')
    str(testSuite)
    cat('', "Consider doing",
        "\t  tests <- runTestSuite(testSuite)", "\nand later",
        "\t  printTextProtocol(tests)", '', sep = "\n")
  } else {
    ## run from shell / Rscript / R CMD Batch / ...
    ## Run
    tests <- runTestSuite(testSuite)
    if (file.access(path, 02) != 0) {
      ## cannot write to path -> use writable one
      tdir <- tempfile(paste(pkg, "unitTests", sep="_"))
      dir.create(tdir)
      pathReport <- file.path(tdir, "report")
      cat("RUnit reports are written into ", tdir, "/report.(txt|html)",
          sep = "")
    } else {
      pathReport <- file.path(path, "report")
    }
    ## Print Results:
    printTextProtocol(tests, showDetails = FALSE)
    printTextProtocol(tests, showDetails = FALSE,
                      fileName = paste(pathReport, "Summary.txt", sep = ""))
    printTextProtocol(tests, showDetails = TRUE,
                      fileName = paste(pathReport, ".txt", sep = ""))

    ## Print HTML Version to a File:
    ## printHTMLProtocol has problems on Mac OS X
    if (Sys.info()["sysname"] != "Darwin")
      printHTMLProtocol(tests,
                        fileName = paste(pathReport, ".html", sep = ""))

    ## stop() if there are any failures i.e. FALSE to unit test.
    ## This will cause R CMD check to return error and stop
    tmp <- getErrors(tests)
    if(tmp$nFail > 0 | tmp$nErr > 0) {
      stop(paste("\n\nunit testing failed (#test failures: ", tmp$nFail,
                 ", R errors: ",  tmp$nErr, ")\n\n", sep=""))
    }
  }
} else {
  cat("R package 'RUnit' cannot be loaded -- no unit tests run\n",
      "for package", pkg,"\n")
}

Try the sp23design package in your browser

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

sp23design documentation built on April 19, 2022, 5:08 p.m.