Title: | Automate Validated Package Creation |
---|---|
Description: | Automate the steps necessary to create a validation ready package to make the process of validation simple. This includes setting up the specifications, test cases, test code, and validation report. Also provides tools to be able to execute the validation report from a variety of situations to provide documentation for validation. |
Authors: | Ellis Hughes [aut, cre] , Eli Miller [aut] , Marie Vendettuoli [aut] , Peyman Eshghi [aut] , Maya Gans [ctb] , PHUSE [cph] |
Maintainer: | Ellis Hughes <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.4.1 |
Built: | 2025-01-04 02:40:01 UTC |
Source: | https://github.com/phuse-org/valtools |
enable dynamic referencing by reading file and converting any dynamic references into their values for rendering in the validation report.
dynamic_reference_rendering(input, reference = NULL)
dynamic_reference_rendering(input, reference = NULL)
input |
R object or path to the file to convert dynamic referencing to values |
reference |
which dynamic referencer to use. When NULL, uses internal dynamic referencer. |
text with dynamic referencing evaluated
valtools uses roxygen across multiple file types to provide documentation. this function provides the tooling necessary to scrape from the major file types that we use ( R, R test code, markdown, Rmarkdown) and provides a consistent output type to capture the information necessary to help high level functions make assumptions.
scrape_roxygen(file, ..., type = tools::file_ext(file))
scrape_roxygen(file, ..., type = tools::file_ext(file))
file |
file to scrape roxygen block from |
... |
These dots are for future extensions and must be empty. |
type |
method of parse_roxygen to use if other that file extension |
a list of roxygen blocks found in the file.
Impose ordering of validation child files
Remove validation file orderingfrom the projects validation config file
Add user information to the projects validation config file to make for easier documentation
Remove user information from the projects validation config file
Get recorded user information from the validation config file to make for easier documentation
Use a Validation Config File Validation configuration for working/output directories, validation report naming conventions, and tracking user information(username,name,title, role). Provides a single location for setting behaviors.
Capture the information on a user that is going to be involved with validation
vt_add_file_to_config(filename, before = NULL, after = NULL) vt_drop_file_from_config(filename) vt_add_user_to_config(username = whoami::username(), name, title, role) vt_drop_user_from_config(username) vt_get_user_info(username, type = c("name", "title", "role")) vt_use_config( pkg = ".", package, working_dir, output_dir, report_rmd_name = "validation.Rmd", report_naming_format = "Validation_Report_{package}_v{version}_{date}", username_list = list(), validation_files = list(), ..., overwrite = FALSE ) vt_user(username, name, title, role, ...)
vt_add_file_to_config(filename, before = NULL, after = NULL) vt_drop_file_from_config(filename) vt_add_user_to_config(username = whoami::username(), name, title, role) vt_drop_user_from_config(username) vt_get_user_info(username, type = c("name", "title", "role")) vt_use_config( pkg = ".", package, working_dir, output_dir, report_rmd_name = "validation.Rmd", report_naming_format = "Validation_Report_{package}_v{version}_{date}", username_list = list(), validation_files = list(), ..., overwrite = FALSE ) vt_user(username, name, title, role, ...)
filename |
character vector containing filenames in order |
before , after
|
Optional destination of new filenames, default is end of
existing list. Supports < |
username |
username of the user. |
name |
full name of the user. |
title |
title of the user. |
role |
role of the user. Can be more than one. |
type |
type of information to pull. select at least one: name, title, role |
pkg |
where to write config file |
package |
character name of package or set validation is being performed for. |
working_dir |
character which directory to be have working validation contents that are used interactively |
output_dir |
character which folder should the contents for validation output to. |
report_rmd_name |
character name of rmarkdown document that is to be used for validation. |
report_naming_format |
character a glue friendly string
of the naming structure of the output validation report. use |
username_list |
list of user objects created by make_user. Each user contains entries for username, name, title, and role to be used for documentation. |
validation_files |
list of validation files: requirements, test cases and test code. Validation report content will be populated using this list in order. |
... |
additional information about the user to be passed into a list. |
overwrite |
|
Used for side effect of adding validation file ordering to validation config file. Invisibly returns TRUE on success.
Used for side effect of removing file ordering information from validation config file. Invisibly returns TRUE on success.
Used for side effect of adding user information to validation config file. Invisibly returns TRUE on success.
Used for side effect of removing user information to validation config file. Invisibly returns TRUE on success.
a character vector length of types requested containing the user information from the validation config file.
Used for side effect to create validation config file. Invisibly returns TRUE on success.
a "user" object
## Not run: vt_use_validation() vt_add_file_to_config(filename = "myReqFile.Rmd") ## End(Not run) ## Not run: vt_use_validation() vt_add_file_to_config(filename = "myReqFile.Rmd") vt_drop_file_from_config(filename = "myReqFile.Rmd") ## End(Not run) ## Not run: vt_use_validation() vt_add_user_to_config( username = "ellis", name = "Ellis Hughes", title = "Statistical Programmer", role = "Programmer") ## End(Not run) ## Not run: vt_use_validation() vt_add_user_to_config( username = "ellis", name = "Ellis Hughes", title = "Statistical Programmer", role = "Programmer") vt_drop_user_from_config(username = "ellis") ## End(Not run) ## Not run: vt_use_validation() vt_add_user_to_config( username = "ellis", name = "Ellis Hughes", title = "Statistical Programmer", role = "Programmer") vt_get_user_info(username = "ellis", type = c("name","title")) ## End(Not run) withr::with_tempdir({ vt_use_validation( package = "test.package", working_dir = ".", output_dir = ".", report_naming_format = "Validation_Report_{package}_v{version}_{date}", username_list = list( vt_user( name = "test", title = "test", role = "tester", username = "test" ))) }) vt_user( username = "ellis", name = "Ellis Hughes", title = "Statistical Programmer", role = "Programmer")
## Not run: vt_use_validation() vt_add_file_to_config(filename = "myReqFile.Rmd") ## End(Not run) ## Not run: vt_use_validation() vt_add_file_to_config(filename = "myReqFile.Rmd") vt_drop_file_from_config(filename = "myReqFile.Rmd") ## End(Not run) ## Not run: vt_use_validation() vt_add_user_to_config( username = "ellis", name = "Ellis Hughes", title = "Statistical Programmer", role = "Programmer") ## End(Not run) ## Not run: vt_use_validation() vt_add_user_to_config( username = "ellis", name = "Ellis Hughes", title = "Statistical Programmer", role = "Programmer") vt_drop_user_from_config(username = "ellis") ## End(Not run) ## Not run: vt_use_validation() vt_add_user_to_config( username = "ellis", name = "Ellis Hughes", title = "Statistical Programmer", role = "Programmer") vt_get_user_info(username = "ellis", type = c("name","title")) ## End(Not run) withr::with_tempdir({ vt_use_validation( package = "test.package", working_dir = ".", output_dir = ".", report_naming_format = "Validation_Report_{package}_v{version}_{date}", username_list = list( vt_user( name = "test", title = "test", role = "tester", username = "test" ))) }) vt_user( username = "ellis", name = "Ellis Hughes", title = "Statistical Programmer", role = "Programmer")
valtools assists the user in generating the validation report by allowing the user to define the order in which
vt_file(file, ..., dynamic_referencing = FALSE)
vt_file(file, ..., dynamic_referencing = FALSE)
file |
file to evaluate |
... |
These dots are for future extensions and must be empty. |
dynamic_referencing |
Whether to employ dynamic referencing or not. defaults to FALSE. |
a list of roxygen blocks found in the file.
Get all users from validation config file without knowing usernames
vt_get_all_users()
vt_get_all_users()
list of all users in config file
Identify ordering of validation or user-designated child files
vt_get_child_files( loc = c("folder", "yml"), validation_order = c("requirements", "test_cases", "test_code") )
vt_get_child_files( loc = c("folder", "yml"), validation_order = c("requirements", "test_cases", "test_code") )
loc |
location to explore. Either "folder" for naive inclusion of validation folder contents, or "yml" to use validation_folder field of validation.yml |
validation_order |
optional ordering of validation folders to search |
vector of child file names to include in validation report
withr::with_tempdir({ vt_use_validation() vt_use_test_case("testcase1", username = "a user", open = FALSE) vt_use_req("req1", username = "a user", open = FALSE) vt_use_test_code("testcode1", username = "another user", open = FALSE) # as listed in validation.yml validation_files vt_get_child_files(loc = "yml") # as ordered in validation subfolders vt_get_child_files(loc = "folder", validation_order = c("requirements", "test_cases", "test_code")) })
withr::with_tempdir({ vt_use_validation() vt_use_test_case("testcase1", username = "a user", open = FALSE) vt_use_req("req1", username = "a user", open = FALSE) vt_use_test_code("testcode1", username = "another user", open = FALSE) # as listed in validation.yml validation_files vt_get_child_files(loc = "yml") # as ordered in validation subfolders vt_get_child_files(loc = "folder", validation_order = c("requirements", "test_cases", "test_code")) })
vt_scrape_coverage_matrix
Kable handler for output of vt_scrape_coverage_matrix
vt_kable_coverage_matrix(x, format = vt_render_to())
vt_kable_coverage_matrix(x, format = vt_render_to())
x |
data.frame as output from |
format |
passed to |
knitr_kable object
Kable defaults for rendering validation report
vt_kable_sig_table(people, format = vt_render_to())
vt_kable_sig_table(people, format = vt_render_to())
people |
A dataframe with the columns role, Name and Title, Signature, and "Date" |
format |
passed to knitr::kable |
knitr_kable object
Generates kable code for validation environment details
vt_kable_val_env(val_env, format = vt_render_to())
vt_kable_val_env(val_env, format = vt_render_to())
val_env |
data.frame as output from |
format |
passed to |
knitr_kable object
vt_path() allows access of files relative to the working directory,which is identified by the config file. It is also required to be used in the validation report for cases where validation of installed packages is intended as it will shift access to the correct location for the installed package for access.
vt_path(...) vt_find_config()
vt_path(...) vt_find_config()
... |
|
vt_find_config() locates the config file in the working directory, and returns the full path to it.
withr::with_tempdir({callr::r(function(){ valtools::vt_use_validation() valtools::vt_path() valtools::vt_path("some", "reqs", "req01.md") valtools::vt_path("some/reqs/req01.md") valtools::vt_find_config() })})
withr::with_tempdir({callr::r(function(){ valtools::vt_use_validation() valtools::vt_path() valtools::vt_path("some", "reqs", "req01.md") valtools::vt_path("some/reqs/req01.md") valtools::vt_find_config() })})
reads the knitr and rmarkdown options to determine which output type is being rendered
vt_render_to()
vt_render_to()
This package is not intended for use by the end users. This is to be used within valtools packages.
vt_render_validation_report( report_path, output_dir = dirname(report_path), output_file = NULL, ..., render_time = c("build", "installed"), package = "" )
vt_render_validation_report( report_path, output_dir = dirname(report_path), output_file = NULL, ..., render_time = c("build", "installed"), package = "" )
report_path |
path to the validation report rmarkdown |
output_dir |
path to directory to output rendered report. defaults to same folder |
output_file |
expected output filename sans extension |
... |
arguments passed to render |
render_time |
type of rendering of validation to run, "build" or "installed". |
package |
the report type of rendering of validation to run, "build" or "installed". |
Evaluate the test code file
Turn test code results data.frame into kable output
vt_run_test_code_file(file, test_env = new.env(), ..., ref = vt_path()) vt_kable_test_code_results(results, format = vt_render_to())
vt_run_test_code_file(file, test_env = new.env(), ..., ref = vt_path()) vt_kable_test_code_results(results, format = vt_render_to())
file |
full path to test code file. |
test_env |
environment to perform tests in |
... |
argument passed to |
ref |
reference path to use. Defaults to vt_path() |
results |
results data.frame from |
format |
passed to |
a kable with variables: Test
, Expected
, Results
,
Pass/Fail
. Suitable for including in validation report
kableExtra object with formatting
Scrape change log from a validation project
Format change log info table for validation report
Initiate a change_log file
vt_scrape_change_log() vt_kable_change_log(change_log_info, format = vt_render_to()) vt_use_change_log(date = NULL, version = NULL, open = interactive())
vt_scrape_change_log() vt_kable_change_log(change_log_info, format = vt_render_to()) vt_use_change_log(date = NULL, version = NULL, open = interactive())
change_log_info |
data.frame as exported from |
format |
passed to |
date |
passed to template |
version |
version to set in news file |
open |
whether to open the file after |
data.frame with variables version
, effective_date
, description
a knitr_kable object
path to change log file, used for side effect of creating change_log
Extracts validation version, date, and description from change log items
that start with [validation]
.
withr::with_tempdir({ file.create(".here") vt_use_validation() vt_use_change_log() log_data <- vt_scrape_change_log() print(log_data) vt_kable_change_log(log_data) })
withr::with_tempdir({ file.create(".here") vt_use_validation() vt_use_change_log() log_data <- vt_scrape_change_log() print(log_data) vt_kable_change_log(log_data) })
Scrape "coverage" tag in test code to generate mapping
vt_scrape_coverage_matrix( type = c("long", "wide"), reference = NULL, src = ".", ref = vt_path() )
vt_scrape_coverage_matrix( type = c("long", "wide"), reference = NULL, src = ".", ref = vt_path() )
type |
one of "long" or "wide" which determines shape of output table |
reference |
dynamic reference holder if it already exists |
src , ref
|
passed to |
a data.frame mapping requirement ids to test case ids.
These functions provide utitilies to scrape the editor and editDate roxygen tags and put them into a nice data.frame for use in the validation reports. In addition, opinionated kable formatting functions are provided as well to facilitate nice printing in the reports.
vt_scrape_requirement_editors( tags = c("editor", "editDate"), src = ".", ref = vt_path(), dynamic_ref = NULL ) vt_scrape_test_case_editors( tags = c("editor", "editDate"), src = ".", ref = vt_path(), dynamic_ref = NULL ) vt_scrape_test_code_editors( tags = c("editor", "editDate", "deprecate"), src = ".", ref = vt_path(), dynamic_ref = NULL ) vt_scrape_function_editors( tags = c("editor", "editDate", "export"), src = ".", ref = vt_path() ) vt_kable_requirement_editors(x, format = vt_render_to()) vt_kable_function_editors(x, format = vt_render_to()) vt_kable_test_case_editors(x, format = vt_render_to()) vt_kable_test_code_editors(x, format = vt_render_to())
vt_scrape_requirement_editors( tags = c("editor", "editDate"), src = ".", ref = vt_path(), dynamic_ref = NULL ) vt_scrape_test_case_editors( tags = c("editor", "editDate"), src = ".", ref = vt_path(), dynamic_ref = NULL ) vt_scrape_test_code_editors( tags = c("editor", "editDate", "deprecate"), src = ".", ref = vt_path(), dynamic_ref = NULL ) vt_scrape_function_editors( tags = c("editor", "editDate", "export"), src = ".", ref = vt_path() ) vt_kable_requirement_editors(x, format = vt_render_to()) vt_kable_function_editors(x, format = vt_render_to()) vt_kable_test_case_editors(x, format = vt_render_to()) vt_kable_test_code_editors(x, format = vt_render_to())
tags |
which tags to keep. defaults to editor and editDate |
src |
path to package sources. defaults to current directory and passed to |
ref |
reference path to whre validation documentation lives. defaults
to |
dynamic_ref |
dynamic referencer object |
x |
data.frame as exported from vt_scrape_* |
format |
passed to |
data.frame containing the results of the scraped roxygen tags for each section
knitr_kable object
vt_scrape_functions Requires access to raw R/ or function documentation parsed via valtools into validation/ folder. Cannot pull information from installed R/ location.
withr::with_tempdir({ captured_output <- capture.output({vt_create_package(open = FALSE)}) vt_use_req( name = "req1", username = "B user", title = "Requirement 1", open = FALSE) writeLines(c( "#' @title Say Hello", "#' @editor B User", "#' @editDate 2021-04-27", "#' @export", "hello <- function(){print(\"Hello\")}" ), con = "R/hello.R") vt_use_test_case( name = "testcase1", username = "B user", title = "TesT Case 1", open = FALSE) vt_use_test_code( name = "testcode1", username = "C user", open = FALSE) req_editors <- vt_scrape_requirement_editors() vt_kable_requirement_editors(req_editors) fun_editors <- vt_scrape_function_editors() vt_kable_function_editors(fun_editors) t_case_editors <- vt_scrape_test_case_editors() vt_kable_test_case_editors(t_case_editors) t_code_editors <- vt_scrape_test_code_editors() vt_kable_test_code_editors(t_code_editors) })
withr::with_tempdir({ captured_output <- capture.output({vt_create_package(open = FALSE)}) vt_use_req( name = "req1", username = "B user", title = "Requirement 1", open = FALSE) writeLines(c( "#' @title Say Hello", "#' @editor B User", "#' @editDate 2021-04-27", "#' @export", "hello <- function(){print(\"Hello\")}" ), con = "R/hello.R") vt_use_test_case( name = "testcase1", username = "B user", title = "TesT Case 1", open = FALSE) vt_use_test_code( name = "testcode1", username = "C user", open = FALSE) req_editors <- vt_scrape_requirement_editors() vt_kable_requirement_editors(req_editors) fun_editors <- vt_scrape_function_editors() vt_kable_function_editors(fun_editors) t_case_editors <- vt_scrape_test_case_editors() vt_kable_test_case_editors(t_case_editors) t_code_editors <- vt_scrape_test_code_editors() vt_kable_test_code_editors(t_code_editors) })
Scrape "riskAssessment" tag in requirements to generate table
Kable handler for output of vt_scrape_risk_assessment
vt_scrape_risk_assessment(reference = NULL, src = ".", ref = vt_path()) vt_kable_risk_assessment(x, format = vt_render_to())
vt_scrape_risk_assessment(reference = NULL, src = ".", ref = vt_path()) vt_kable_risk_assessment(x, format = vt_render_to())
reference |
dynamic reference holder if it already exists |
src , ref
|
passed to |
x |
data.frame as output from |
format |
passed to |
a data.frame documenting requirements to risk assessments
knitr_kable object
Looks for the value in a custom roxygen sections. Custom
sections are named using @section <NAME>:
, where colon is use to indicate
end of the name, and value starts on next line.
vt_scrape_section(tag, block)
vt_scrape_section(tag, block)
tag |
name of the section, case insensitive. |
block |
character vector that holds the documentation block. |
section value
Marie Vendettuoli
2021-02-18
roxy_block1 <- c("@title Title1", "@param param1 definition", "@section Last updated date:", "2021-01-01", "@importFrom utils sessionInfo", "@export" ) vt_scrape_section("Last updated date:", roxy_block1) roxy_block2 <- paste0("#' ", roxy_block1) vt_scrape_section("Last updated date:", roxy_block2)
roxy_block1 <- c("@title Title1", "@param param1 definition", "@section Last updated date:", "2021-01-01", "@importFrom utils sessionInfo", "@export" ) vt_scrape_section("Last updated date:", roxy_block1) roxy_block2 <- paste0("#' ", roxy_block1) vt_scrape_section("Last updated date:", roxy_block2)
Generate a signature table for a validation report
vt_scrape_sig_table(usernames = NULL)
vt_scrape_sig_table(usernames = NULL)
usernames |
list of vt_names to use when validation.yml does not exist |
A dataframe created from the validation config containing a row for each user with the columns: role, name_and_title, signature, and date.
Looks for roxygen2 function documentation in /R for author details.
Assumes that author and date are tagged via custom sections @section Last updated by:
and @section Last updated date:
, respectively. To exclude a roxygen
block from this scraping, omit these section names.
If using a dummy documentation file, looks for @name
to capture
function name, otherwise uses the actual function call.
Exported or internal status does not affect scraping.
vt_scrape_tags_from( type, tags = c("editor", "editDate"), src = ".", ref = vt_path() )
vt_scrape_tags_from( type, tags = c("editor", "editDate"), src = ".", ref = vt_path() )
type |
type of scraping to be done. one of "requirements","test_cases","test_code","functions". to call functions. working directory must be an R package, or path identified in src must be an R package. |
tags |
which tags to keep. defaults to editor and editDate |
src |
path to package source. defaults to the current directory. |
ref |
reference path to where validation documentation lives. defaults to vt_path() |
Ellis Hughes
2021-03-05
At this time, this function does not retrieve documentation captured for functions dispatched within an R6 class. Tags at the class level documentation are retrieved.
Retrieves dependencies used in validation report. Includes: OS, R version, packages listed in the validation package DESCRIPTION (Depends/Imports/Suggests), packages present in current session.
vt_scrape_val_env(pkg = ".")
vt_scrape_val_env(pkg = ".")
pkg |
path to package |
data.frame with columns:
resource
"OS", "R" or package name
type
identifier of requirement type:
system - OS or R resource
package_req - from DESCRIPTION Depends/Imports of the package being validated
extended_req - from DESCRIPTION Suggests of the package being validated
session - packages in current workspace not captured via package_req/extended_req
detail
OS or version details
Marie Vendettuoli
2021-02-03
Create validation report from template
vt_use_report( pkg_name = NULL, template = "validation", dynamic_referencing = FALSE, open = is_interactive() )
vt_use_report( pkg_name = NULL, template = "validation", dynamic_referencing = FALSE, open = is_interactive() )
pkg_name |
name of package |
template |
what validation report template from valtools to use, one of "validation" (default) or "requirements" |
dynamic_referencing |
Should dynamic referencing be enabled by default. Boolean defaults to FALSE. |
open |
boolean to open the validation report for further editing |
Create a validation requirement, test case, or test code file
vt_use_test_case( name, username = vt_username(), title = NULL, open = interactive(), add_before = NULL, add_after = NULL ) vt_use_test_code( name, username = vt_username(), open = interactive(), add_before = NULL, add_after = NULL ) vt_use_req( name, username = vt_username(), title = NULL, open = interactive(), add_before = NULL, add_after = NULL )
vt_use_test_case( name, username = vt_username(), title = NULL, open = interactive(), add_before = NULL, add_after = NULL ) vt_use_test_code( name, username = vt_username(), open = interactive(), add_before = NULL, add_after = NULL ) vt_use_req( name, username = vt_username(), title = NULL, open = interactive(), add_before = NULL, add_after = NULL )
name |
The name/path of the validation item. These can be named with your
file system separator and will be organized as a directory structure. Items
are located at |
username |
The username to insert into the validation item as the author. |
title |
Title for the requirement defaults to be the base name passed sans file paths or extensions. |
open |
Should the newly made file be opened for editing. |
add_before , add_after
|
If either parameters is supplied, the location to add the validation item to the validation configuration. If no parameter is passed the item is added at the end. |
Path to the newly created validation item file, invisibly.
withr::with_tempdir({ vt_create_package("example.package") setwd("example.package") vt_add_user_to_config( username = whoami::username(), name = "Sample Name", title = "Sample", role = "example" ) # Create req at the cases top level `inst/validation/cases/case1` vt_use_test_case("case1", open = FALSE) # Create req at `inst/validation/cases/regTests/Update2/case2` vt_use_test_case("regTests/Update2/case2", open = FALSE, add_before = "case1.md") # Create a test case using tidy select vt_use_test_case("case1a", open = FALSE, add_after = tidyselect::starts_with("case1")) })
withr::with_tempdir({ vt_create_package("example.package") setwd("example.package") vt_add_user_to_config( username = whoami::username(), name = "Sample Name", title = "Sample", role = "example" ) # Create req at the cases top level `inst/validation/cases/case1` vt_use_test_case("case1", open = FALSE) # Create req at `inst/validation/cases/regTests/Update2/case2` vt_use_test_case("regTests/Update2/case2", open = FALSE, add_before = "case1.md") # Create a test case using tidy select vt_use_test_case("case1a", open = FALSE, add_after = tidyselect::starts_with("case1")) })
Creates a structure for validation artifacts. Validation items are stored in
inst/validation
Create the validation packet infrastructure. Intended to create validation infrastructure external to an R package.
vt_use_validation(pkg = ".", working_dir, ...) vt_create_package( pkg = ".", ..., fields = list(), rstudio = rstudioapi::isAvailable(), roxygen = TRUE, check_name = TRUE, open = rlang::is_interactive() ) vt_create_packet( path = ".", target, ..., rstudio = rstudioapi::isAvailable(), open = rlang::is_interactive() )
vt_use_validation(pkg = ".", working_dir, ...) vt_create_package( pkg = ".", ..., fields = list(), rstudio = rstudioapi::isAvailable(), roxygen = TRUE, check_name = TRUE, open = rlang::is_interactive() ) vt_create_packet( path = ".", target, ..., rstudio = rstudioapi::isAvailable(), open = rlang::is_interactive() )
pkg |
Top level directory of a package |
working_dir |
validation working directory of the project. Defaults to |
... |
Additional argument passed to |
fields |
A named list of fields to add to |
rstudio |
If |
roxygen |
Do you plan to use roxygen2 to document your package? |
check_name |
Whether to check if the name is valid for CRAN and throw an error if not. |
open |
If
|
path |
A path. If it exists, it is used. If it does not exist, it is created, provided that the parent path exists. |
target |
target of validation. Character name of package or scope validation packet is being performed for. |
Wrapper for whoami::username
vt_username()
vt_username()
@returns [character]
Username of the person that called the function
withr::with_tempdir({ vt_use_validation( username_list = list(vt_user( username = whoami::username(), name = "test", title = "title", role = "role"))) vt_username() })
withr::with_tempdir({ vt_use_validation( username_list = list(vt_user( username = whoami::username(), name = "test", title = "title", role = "role"))) vt_username() })
vt_validate_source
runs the validation on the current source, temporarily
installing the source to properly evaluate the report. vt_validate_build()
runs the same step, then compiles a bundle that includes th the validation
report and any other contents that are required for validation. Finally,
vt_validate_installed_package
run rerun the validation report for packages
that were built and then installed using thevt_validate_build()
.
vt_validate_source(src = ".", open = interactive()) vt_validate_build(src = ".", ...) vt_validate_install( src = ".", ..., install_verbose = TRUE, install_tests = TRUE, reload = TRUE ) vt_validate_installed_package( package, output_directory = ".", open = interactive() ) vt_validate_report(version, open = interactive())
vt_validate_source(src = ".", open = interactive()) vt_validate_build(src = ".", ...) vt_validate_install( src = ".", ..., install_verbose = TRUE, install_tests = TRUE, reload = TRUE ) vt_validate_installed_package( package, output_directory = ".", open = interactive() ) vt_validate_report(version, open = interactive())
src |
location of the source code. Assumed to be the same location as "pkg" |
open |
should the validation report be opened after it is built? |
... |
Additional argument passed to |
install_verbose |
should the installation be verbose? |
install_tests |
should the installation include installation of package-specific tests (if any)? |
reload |
Should package be reloaded after install? defaults to TRUE |
package |
installed package name |
output_directory |
Location of directory to output validation report |
version |
version of validation report to output. If missing, it tries to use the change_log.md, if that is missing then looks at the package version if the validation package is of an R package. |
path to either the validation report or the bundled package