-
Notifications
You must be signed in to change notification settings - Fork 190
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
8129567
commit dd38646
Showing
2 changed files
with
85 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
# Test to ensure roxygenize() has been run on the current PR | ||
library(tools) | ||
library(roxygen2) | ||
|
||
old_dir <- file.path(tempdir(), "man") | ||
if (dir.exists(old_dir)) unlink(old_dir, recursive = TRUE) | ||
file.copy("man", tempdir(), recursive = TRUE) | ||
old_files <- list.files(old_dir, pattern = "\\.Rd$") | ||
new_dir <- "man" | ||
.Last <- function() unlink(old_dir, recursive = TRUE) | ||
|
||
# Rd2txt() prints to its out= argument, so we'd have to compare file contents; | ||
# plain parse_Rd() keeps srcref info that encodes the file path, which as.character() strips. | ||
normalize_rd <- function(rd_file) as.character(parse_Rd(rd_file)) | ||
|
||
rd_equal <- function(f1, f2) isTRUE(all.equal(normalize_rd(f1), normalize_rd(f2))) | ||
|
||
check_roxygenize_idempotent <- function(LOCALE) { | ||
Sys.setlocale("LC_COLLATE", LOCALE) | ||
roxygenize() | ||
|
||
new_files <- list.files(new_dir, pattern = "\\.Rd$") | ||
|
||
old_not_new <- setdiff(old_files, new_files) | ||
if (length(old_not_new) > 0L) { | ||
stop("Found saved .Rd files gone from a fresh run of roxygenize(): ", toString(old_not_new)) | ||
} | ||
|
||
new_not_old <- setdiff(new_files, old_files) | ||
if (length(new_not_old) > 0L) { | ||
stop("Found new .Rd files from a fresh run of roxygenize(): ", toString(new_not_old)) | ||
} | ||
|
||
for (file in new_files) { | ||
old_file <- file.path(old_dir, file) | ||
new_file <- file.path(new_dir, file) | ||
if (rd_equal(old_file, new_file)) { | ||
next | ||
} | ||
cat(sprintf("roxygenize() output differs from saved output for %s.\n", file)) | ||
cat("Here's the 'diff' comparison of the two files:\n") | ||
cat(" [---]: saved output in man/ directory\n") | ||
cat(" [+++]: roxygenize() output of R/ sources\n") | ||
system2("diff", c("--unified", old_file, new_file)) | ||
stop("Failed in LOCALE=", LOCALE, ".", call. = FALSE) | ||
} | ||
} | ||
|
||
# Run the check in a few locales to ensure there's no idempotency issues w.r.t. sorting, too | ||
for (LOCALE in c("C", "en_US", "hu_HU", "ja_JP")) { | ||
check_roxygenize_idempotent(LOCALE) | ||
} | ||
|
||
unlink(old_dir, recursive = TRUE) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
on: | ||
push: | ||
branches: [main, master] | ||
pull_request: | ||
branches: [main, master] | ||
|
||
name: repo-roxy-tests | ||
|
||
jobs: | ||
repo-roxy-tests: | ||
runs-on: ubuntu-latest | ||
env: | ||
GITHUB_PAT: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- uses: r-lib/actions/setup-r@v2 | ||
with: | ||
r-version: "release" | ||
use-public-rspm: true | ||
|
||
- uses: r-lib/actions/setup-r-dependencies@v2 | ||
with: | ||
extra-packages: | | ||
any::roxygen2 | ||
- name: Ensure roxygen content matches manual directory | ||
run: | | ||
callr::rscript(".dev/roxygen_test.R") | ||
shell: Rscript {0} |