inst/tinytest/count/count_tests.R

# count number of tests
library(broadcast)
library(tinytest)

# set working directory to source file location
SourceFileLocation <- function() {
  # BATCH way:
  path <- funr::get_script_path()
  if(!is.null(path)) return(path)
  
  # R-Studio way:
  if(Sys.getenv("RSTUDIO") == "1") {
    if(rstudioapi::isAvailable(version_needed = NULL,child_ok = FALSE)) {
      return(dirname(rstudioapi::getSourceEditorContext()$path))
    }
    if(is.null(knitr::current_input(dir = TRUE)) == FALSE) {
      return(knitr::current_input(dir = TRUE))
    }
    return(getwd())
  }
}

enumerate_total <- 0


# root folder tests ====

wd <- SourceFileLocation()
setwd(wd)
setwd("..")
getwd()
files <- list.files(normalizePath(getwd()), pattern = ".R", full.names = TRUE)
max.width <- max(stringi::stri_width(basename(files))) + 8
for(iFile in files) {
  capture.output(source(normalizePath(iFile)), file = nullfile()) |> suppressMessages()
  cat(stringi::stri_pad_right(basename(iFile), max.width), " -> ", enumerate,  "\n")
  enumerate_total <- enumerate_total + enumerate
}
rem <-  setdiff(ls(), c("SourceFileLocation", "enumerate", "enumerate_total"))
rm(list = rem)


# sub folder tests ====

subfolders <- list.dirs() |> basename() |> setdiff(c(".", "count"))
wd <- SourceFileLocation()
setwd(wd)
setwd("..")
path <- file.path(getwd(), subfolders) |> normalizePath()
files <- list.files(path, pattern = "*.R", full.names = TRUE)
max.width <- max(stringi::stri_width(basename(files))) + 8

for(iSubFolder in subfolders) {
  
  wd <- SourceFileLocation()
  setwd(wd)
  setwd("..")
  setwd(normalizePath(iSubFolder))
  getwd()
  files <- list.files(normalizePath(getwd()), pattern = ".R", full.names = TRUE)
  print(iSubFolder)
  for(iFile in files) {
    capture.output(source(normalizePath(iFile)), file = nullfile()) |> suppressMessages()
    cat(stringi::stri_pad_right(basename(iFile), max.width), " -> ", enumerate,  "\n")
    enumerate_total <- enumerate_total + enumerate
  }
  print(enumerate_total)
  rem <-  setdiff(ls(), c("SourceFileLocation", "enumerate", "enumerate_total", "max.width"))
  rm(list = rem)
  cat("\n")
  
}


print(enumerate_total)


# end ====

Try the broadcast package in your browser

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

broadcast documentation built on Sept. 15, 2025, 5:08 p.m.