-
Notifications
You must be signed in to change notification settings - Fork 186
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
New meta-level test that roxygen2 has been run (#2460)
- Loading branch information
1 parent
c4b8e34
commit acbfd77
Showing
2 changed files
with
62 additions
and
3 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
acbfd77
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Html / CSS / JavaScript The Great Tutorials for learning.