Title: | Internal Infrastructure for R-multiverse |
---|---|
Description: | R-multiverse requires this internal infrastructure package to automate contribution reviews and populate universes. |
Authors: | William Michael Landau [aut, cre] , Charlie Gao [aut] , Eli Lilly and Company [cph] |
Maintainer: | William Michael Landau <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.3.4 |
Built: | 2025-01-06 06:19:20 UTC |
Source: | https://github.com/r-multiverse/multiverse.internals |
Summarize the issues of a package in human-readable text.
interpret_status(package, issues)
interpret_status(package, issues)
package |
Character string, name of the package. |
issues |
A list with one issue per package. Obtained by
reading the results of |
A character string summarizing the issues of a package in prose.
Other status:
update_status()
Check R-universe package check results.
issues_checks(meta = meta_checks())
issues_checks(meta = meta_checks())
meta |
A data frame with R-universe package check results
returned by |
issues_checks()
reads output from
the R-universe check API
to scan all R-multiverse packages for issues that may have
happened during building and testing.
A named list of information about packages which do not comply
with DESCRPTION
checks. Each name is a package name,
and each element contains specific information about
non-compliance.
Functions like issues_versions()
and issues_descriptions()
perform health checks for all packages in R-multiverse.
For a complete list of checks, see
the issues_*()
functions listed at
https://r-multiverse.org/multiverse.internals/reference/index.html.
record_versions()
updates the version number history
of releases in R-multiverse, and record_issues()
gathers
together all the issues about R-multiverse packages.
Other issues:
issues_dependencies()
,
issues_descriptions()
,
issues_versions()
meta <- meta_checks(repo = "https://wlandau.r-universe.dev") issues <- issues_checks(meta = meta) str(issues)
meta <- meta_checks(repo = "https://wlandau.r-universe.dev") issues <- issues_checks(meta = meta) str(issues)
Flag packages which have issues in their strong dependencies
(Imports:
, Depends:
, and LinkingTo:
in the DESCRIPTION
.)
These include indirect/upstream dependencies, as well, not just
the explicit mentions in the DESCRIPTION
file.
issues_dependencies(packages, meta = meta_packages(), verbose = FALSE)
issues_dependencies(packages, meta = meta_packages(), verbose = FALSE)
packages |
Character vector of names of packages with other issues. |
meta |
A data frame with R-universe package check results
returned by |
verbose |
|
A nested list of problems triggered by dependencies. The names of top-level elements are packages affected downstream. The value of each top-level element is a list whose names are Each element of this inner list is a character vector of relevant dependencies of the downstream package.
For example, consider a linear dependency graph where crew.cluster
depends on crew
, crew
depends on mirai
, and
mirai
depends on nanonext
. We represent the graph like this:
nanonext -> mirai -> crew -> crew.cluster
.
If nanonext
has an issue, then issues_dependencies()
returns
list(crew.cluster = list(nanonext = "crew"), ...)
, where ...
stands for additional named list entries. From this list, we deduce
that nanonext
is causing an issue affecting crew.cluster
through
the direct dependency on crew
.
The choice in output format from issues_dependencies()
allows package
maintainers to more easily figure out which direct dependencies
are contributing issues and drop those direct dependencies if necessary.
Functions like issues_versions()
and issues_descriptions()
perform health checks for all packages in R-multiverse.
For a complete list of checks, see
the issues_*()
functions listed at
https://r-multiverse.org/multiverse.internals/reference/index.html.
record_versions()
updates the version number history
of releases in R-multiverse, and record_issues()
gathers
together all the issues about R-multiverse packages.
Other issues:
issues_checks()
,
issues_descriptions()
,
issues_versions()
meta <- meta_packages(repo = "https://wlandau.r-universe.dev") issues_dependencies(packages = character(0L), meta = meta) issues_dependencies(packages = "crew.aws.batch", meta = meta) issues_dependencies(packages = "nanonext", meta = meta) issues_dependencies(packages = "crew", meta = meta) issues_dependencies(packages = c("crew", "mirai"), meta = meta)
meta <- meta_packages(repo = "https://wlandau.r-universe.dev") issues_dependencies(packages = character(0L), meta = meta) issues_dependencies(packages = "crew.aws.batch", meta = meta) issues_dependencies(packages = "nanonext", meta = meta) issues_dependencies(packages = "crew", meta = meta) issues_dependencies(packages = c("crew", "mirai"), meta = meta)
DESCRIPTION
-level issues.Report issues with DESCRIPTION
-level metadata of packages.
issues_descriptions(meta = meta_packages())
issues_descriptions(meta = meta_packages())
meta |
A data frame with R-universe package check results
returned by |
issues_descriptions()
reports specific issues in the
DESCRIPTION
-level metadata of packages:
Security advisories at https://github.com/RConsortium/r-advisory-database.
Licenses that cannot be verified as free and open-source.
The presence of a "Remotes"
field.
A named list of information about packages which do not comply
with DESCRPTION
checks. Each name is a package name,
and each element contains specific information about
non-compliance.
Functions like issues_versions()
and issues_descriptions()
perform health checks for all packages in R-multiverse.
For a complete list of checks, see
the issues_*()
functions listed at
https://r-multiverse.org/multiverse.internals/reference/index.html.
record_versions()
updates the version number history
of releases in R-multiverse, and record_issues()
gathers
together all the issues about R-multiverse packages.
Other issues:
issues_checks()
,
issues_dependencies()
,
issues_versions()
meta <- meta_packages(repo = "https://wlandau.r-universe.dev") issues <- issues_descriptions(meta = meta) str(issues)
meta <- meta_packages(repo = "https://wlandau.r-universe.dev") issues <- issues_descriptions(meta = meta) str(issues)
Check package version number history for compliance.
issues_versions(versions)
issues_versions(versions)
versions |
Character of length 1, file path to a JSON manifest tracking the history of released versions of packages. |
This function checks the version number history of packages in R-multiverse and reports any packages with issues. The current released version of a given package must be unique, and it must be greater than all the versions of all the previous package releases.
A named list of information about packages which do not comply with version number history checks. Each name is a package name, and each element contains specific information about version non-compliance: the current version number, the current version hash, and the analogous versions and hashes of the highest-versioned release recorded.
Functions like issues_versions()
and issues_descriptions()
perform health checks for all packages in R-multiverse.
For a complete list of checks, see
the issues_*()
functions listed at
https://r-multiverse.org/multiverse.internals/reference/index.html.
record_versions()
updates the version number history
of releases in R-multiverse, and record_issues()
gathers
together all the issues about R-multiverse packages.
Other issues:
issues_checks()
,
issues_dependencies()
,
issues_descriptions()
lines <- c( "[", " {", " \"package\": \"package_unmodified\",", " \"version_current\": \"1.0.0\",", " \"hash_current\": \"hash_1.0.0\",", " \"version_highest\": \"1.0.0\",", " \"hash_highest\": \"hash_1.0.0\"", " },", " {", " \"package\": \"version_decremented\",", " \"version_current\": \"0.0.1\",", " \"hash_current\": \"hash_0.0.1\",", " \"version_highest\": \"1.0.0\",", " \"hash_highest\": \"hash_1.0.0\"", " },", " {", " \"package\": \"version_incremented\",", " \"version_current\": \"2.0.0\",", " \"hash_current\": \"hash_2.0.0\",", " \"version_highest\": \"2.0.0\",", " \"hash_highest\": \"hash_2.0.0\"", " },", " {", " \"package\": \"version_unmodified\",", " \"version_current\": \"1.0.0\",", " \"hash_current\": \"hash_1.0.0-modified\",", " \"version_highest\": \"1.0.0\",", " \"hash_highest\": \"hash_1.0.0\"", " }", "]" ) versions <- tempfile() writeLines(lines, versions) out <- issues_versions(versions) str(out)
lines <- c( "[", " {", " \"package\": \"package_unmodified\",", " \"version_current\": \"1.0.0\",", " \"hash_current\": \"hash_1.0.0\",", " \"version_highest\": \"1.0.0\",", " \"hash_highest\": \"hash_1.0.0\"", " },", " {", " \"package\": \"version_decremented\",", " \"version_current\": \"0.0.1\",", " \"hash_current\": \"hash_0.0.1\",", " \"version_highest\": \"1.0.0\",", " \"hash_highest\": \"hash_1.0.0\"", " },", " {", " \"package\": \"version_incremented\",", " \"version_current\": \"2.0.0\",", " \"hash_current\": \"hash_2.0.0\",", " \"version_highest\": \"2.0.0\",", " \"hash_highest\": \"hash_2.0.0\"", " },", " {", " \"package\": \"version_unmodified\",", " \"version_current\": \"1.0.0\",", " \"hash_current\": \"hash_1.0.0-modified\",", " \"version_highest\": \"1.0.0\",", " \"hash_highest\": \"hash_1.0.0\"", " }", "]" ) versions <- tempfile() writeLines(lines, versions) out <- issues_versions(versions) str(out)
List package checks results reported by the R-universe package API.
meta_checks(repo = "https://community.r-multiverse.org")
meta_checks(repo = "https://community.r-multiverse.org")
repo |
Character of length 1, URL of the package repository.
R-multiverse uses |
A data frame with one row per package and columns with package check details.
Other meta:
meta_packages()
meta_checks(repo = "https://wlandau.r-universe.dev")
meta_checks(repo = "https://wlandau.r-universe.dev")
List package metadata in an R universe.
meta_packages( repo = "https://community.r-multiverse.org", fields = c("Version", "License", "Remotes", "RemoteSha") )
meta_packages( repo = "https://community.r-multiverse.org", fields = c("Version", "License", "Remotes", "RemoteSha") )
repo |
Character of length 1, URL of the package repository.
R-multiverse uses |
fields |
Character string of fields to query. |
A data frame with one row per package and columns with package metadata.
Other meta:
meta_checks()
meta_packages(repo = "https://wlandau.r-universe.dev")
meta_packages(repo = "https://wlandau.r-universe.dev")
Propose a Production snapshot of Staging.
propose_snapshot( path_staging, repo_staging = "https://staging.r-multiverse.org", types = c("src", "win", "mac"), r_versions = NULL, mock = NULL )
propose_snapshot( path_staging, repo_staging = "https://staging.r-multiverse.org", types = c("src", "win", "mac"), r_versions = NULL, mock = NULL )
path_staging |
Character string, directory path to the source files of the staging universe. |
repo_staging |
Character string, URL of the staging universe. |
types |
Character vector, what to pass to the |
r_versions |
Character vector of |
mock |
For testing purposes only, a named list of data frames for inputs to various intermediate functions. |
propose_snapshot()
proposes a snapshot of Staging
to migrate to Production. The recommended snapshot is the list of
packages for which (1) the build and check results of the current
release are in Staging, and (2) there are no issues.
Writes snapshot.json
with an R-universe-like manifest
of the packages recommended for the snapshot, and a
snapshot.url
file containing an R-universe snapshot API URL
to download those packages. Both these files are written to the
directory given by the path_staging
argument.
NULL
(invisibly). Called for its side effects.
propose_snapshot()
writes snapshot.json
with an R-universe-like
manifest of the packages recommended for the snapshot, and a
snapshot.url
file containing an R-universe snapshot API URL
to download those packages. Both these files are written to the
directory given by the path_staging
argument.
Other staging:
update_staging()
## Not run: url_staging = "https://github.com/r-multiverse/staging" path_staging <- tempfile() gert::git_clone(url = url_staging, path = path_staging) propose_snapshot( path_staging = path_staging, repo_staging = "https://staging.r-multiverse.org" ) ## End(Not run)
## Not run: url_staging = "https://github.com/r-multiverse/staging" path_staging <- tempfile() gert::git_clone(url = url_staging, path = path_staging) propose_snapshot( path_staging = path_staging, repo_staging = "https://staging.r-multiverse.org" ) ## End(Not run)
Record R-multiverse package issues in package-specific JSON files.
record_issues( repo = "https://community.r-multiverse.org", versions = "versions.json", output = "issues.json", mock = NULL, verbose = FALSE )
record_issues( repo = "https://community.r-multiverse.org", versions = "versions.json", output = "issues.json", mock = NULL, verbose = FALSE )
repo |
Character of length 1, URL of the package repository.
R-multiverse uses |
versions |
Character of length 1, file path to a JSON manifest tracking the history of released versions of packages. |
output |
Character of length 1, file path to the JSON file to record
new package issues. Each call to |
mock |
For testing purposes only, a named list of data frames for inputs to various intermediate functions. |
verbose |
|
NULL
(invisibly).
Functions like issues_versions()
and issues_descriptions()
perform health checks for all packages in R-multiverse.
For a complete list of checks, see
the issues_*()
functions listed at
https://r-multiverse.org/multiverse.internals/reference/index.html.
record_versions()
updates the version number history
of releases in R-multiverse, and record_issues()
gathers
together all the issues about R-multiverse packages.
For each package with observed problems, record_issues()
writes
a JSON list entry in the output JSON file
with one element for each type of failing check.
Each check-specific element has an informative name
(for example, checks
, descriptions
, or versions
)
and a list of diagnostic information. In addition, there is a date
field to indicate when an issue was first detected. The date
automatically resets the next time all the issues in the package
are resolved.
repo <- "https://wlandau.r-universe.dev" output <- tempfile() versions <- tempfile() record_versions( versions = versions, repo = repo ) record_issues( repo = repo, versions = versions, output = output ) writeLines(readLines(output))
repo <- "https://wlandau.r-universe.dev" output <- tempfile() versions <- tempfile() record_versions( versions = versions, repo = repo ) record_issues( repo = repo, versions = versions, output = output ) writeLines(readLines(output))
R-multiverse packages must have valid free and
open-source (FOSS) licenses to protect the intellectual
property rights of the package owners
(c.f. https://en.wikipedia.org/wiki/Free_and_open-source_software).
record_nonstandard_licenses()
records packages with nonstandard
licenses.
record_nonstandard_licenses( repo = "https://community.r-multiverse.org", path = "nonstandard_licenses.json" )
record_nonstandard_licenses( repo = "https://community.r-multiverse.org", path = "nonstandard_licenses.json" )
repo |
Character string, URL of the repository. |
path |
Character string, output path to write JSON data with the names and licenses of packages with non-standard licenses. |
NULL
(invisibly). Called for its side effects.
Record the manifest of versions of packages and their hashes.
record_versions( versions = "versions.json", repo = "https://community.r-multiverse.org", current = multiverse.internals::get_current_versions(repo = repo) )
record_versions( versions = "versions.json", repo = "https://community.r-multiverse.org", current = multiverse.internals::get_current_versions(repo = repo) )
versions |
Character of length 1, file path to a JSON manifest tracking the history of released versions of packages. |
repo |
Character of length 1, URL of the package repository.
R-multiverse uses |
current |
A data frame of current versions and hashes of packages
in |
This function tracks a manifest containing the current version,
the current hash, the highest version ever released, and
the hash of the highest version ever released.
issues_versions()
uses this information
to determine whether the package complies with best
practices for version numbers.
NULL
(invisibly). Writes a package version manifest
and a manifest of version issues as JSON files.
Functions like issues_versions()
and issues_descriptions()
perform health checks for all packages in R-multiverse.
For a complete list of checks, see
the issues_*()
functions listed at
https://r-multiverse.org/multiverse.internals/reference/index.html.
record_versions()
updates the version number history
of releases in R-multiverse, and record_issues()
gathers
together all the issues about R-multiverse packages.
# R-multiverse uses https://community.r-multiverse.org as the repo. repo <- "https://wlandau.r-universe.dev" # just for testing and examples output <- tempfile() versions <- tempfile() # First snapshot: record_versions( versions = versions, repo = repo ) readLines(versions) # In subsequent snapshots, we have historical information about versions. record_versions( versions = versions, repo = repo ) readLines(versions)
# R-multiverse uses https://community.r-multiverse.org as the repo. repo <- "https://wlandau.r-universe.dev" # just for testing and examples output <- tempfile() versions <- tempfile() # First snapshot: record_versions( versions = versions, repo = repo ) readLines(versions) # In subsequent snapshots, we have historical information about versions. record_versions( versions = versions, repo = repo ) readLines(versions)
Review a pull request to add packages to R-multiverse.
review_pull_request( owner = "r-multiverse", repo = "contributions", number, advisories = character(0L), organizations = character(0L) )
review_pull_request( owner = "r-multiverse", repo = "contributions", number, advisories = character(0L), organizations = character(0L) )
owner |
Character of length 1, name of the package repository owner. |
repo |
Character of length 1, URL of the package repository.
R-multiverse uses |
number |
Positive integer of length 1, index of the pull request in the repo. |
advisories |
Character vector of names of packages with advisories in the R Consortium Advisory Database. |
organizations |
Character vector of names of GitHub organizations. Pull requests from authors who are not members of at least one of these organizations will be flagged for manual review. |
NULL
(invisibly).
Other pull request reviews:
review_pull_requests()
Review pull requests which add packages to packages.json
.
review_pull_requests(owner = "r-multiverse", repo = "contributions")
review_pull_requests(owner = "r-multiverse", repo = "contributions")
owner |
Character of length 1, name of the package repository owner. |
repo |
Character of length 1, URL of the package repository.
R-multiverse uses |
NULL
(invisibly).
Other pull request reviews:
review_pull_request()
Update the staging universe.
update_staging( path_staging, path_community, repo_community = "https://community.r-multiverse.org", mock = NULL )
update_staging( path_staging, path_community, repo_community = "https://community.r-multiverse.org", mock = NULL )
path_staging |
Character string, directory path to the source files of the staging universe. |
path_community |
Character string, directory path to the source files of the community universe. |
repo_community |
Character string, URL of the community universe. |
mock |
For testing purposes only, a named list of data frames for inputs to various intermediate functions. |
update_staging()
controls how packages enter and leave
the staging universe. It updates the staging packages.json
manifest depending on the contents of the community
universe and issues with package checks.
NULL
(invisibly)
Other staging:
propose_snapshot()
## Not run: url_staging = "https://github.com/r-multiverse/staging" url_community = "https://github.com/r-multiverse/community" path_staging <- tempfile() path_community <- tempfile() gert::git_clone(url = url_staging, path = path_staging) gert::git_clone(url = url_community, path = path_community) update_staging( path_staging = path_staging, path_community = path_community, repo_community = "https://community.r-multiverse.org" ) ## End(Not run)
## Not run: url_staging = "https://github.com/r-multiverse/staging" url_community = "https://github.com/r-multiverse/community" path_staging <- tempfile() path_community <- tempfile() gert::git_clone(url = url_staging, path = path_staging) gert::git_clone(url = url_community, path = path_community) update_staging( path_staging = path_staging, path_community = path_community, repo_community = "https://community.r-multiverse.org" ) ## End(Not run)
Update the repository which reports the status on individual packages.
update_status( path_status, path_staging, path_community, repo_staging = "https://staging.r-multiverse.org", repo_community = "https://community.r-multiverse.org", mock = NULL )
update_status( path_status, path_staging, path_community, repo_staging = "https://staging.r-multiverse.org", repo_community = "https://community.r-multiverse.org", mock = NULL )
path_status |
Character string, directory path to the source files of the package status repository. |
path_staging |
Character string, directory path to the source files of the staging universe. |
path_community |
Character string, directory path to the source files of the community universe. |
repo_staging |
Character string, URL of the staging universe. |
repo_community |
Character string, URL of the community universe. |
mock |
For testing purposes only, a named list of data frames for inputs to various intermediate functions. |
Other status:
interpret_status()
## Not run: url_staging = "https://github.com/r-multiverse/staging" url_community = "https://github.com/r-multiverse/community" path_status <- tempfile() path_staging <- tempfile() path_community <- tempfile() gert::git_clone(url = url_staging, path = path_staging) gert::git_clone(url = url_community, path = path_community) update_status( path_status = path_status, path_staging = path_staging, path_community = path_community, repo_staging = "https://staging.r-multiverse.org", repo_community = "https://community.r-multiverse.org" ) writeLines( readLines( file.path(path_status, "community", "multiverse.internals.html") ) ) writeLines( readLines( file.path(path_status, "community", "multiverse.internals.xml") ) ) ## End(Not run)
## Not run: url_staging = "https://github.com/r-multiverse/staging" url_community = "https://github.com/r-multiverse/community" path_status <- tempfile() path_staging <- tempfile() path_community <- tempfile() gert::git_clone(url = url_staging, path = path_staging) gert::git_clone(url = url_community, path = path_community) update_status( path_status = path_status, path_staging = path_staging, path_community = path_community, repo_staging = "https://staging.r-multiverse.org", repo_community = "https://community.r-multiverse.org" ) writeLines( readLines( file.path(path_status, "community", "multiverse.internals.html") ) ) writeLines( readLines( file.path(path_status, "community", "multiverse.internals.xml") ) ) ## End(Not run)
Update the list of packages for each R-multiverse topic.
update_topics(path, repo = "https://community.r-multiverse.org", mock = NULL)
update_topics(path, repo = "https://community.r-multiverse.org", mock = NULL)
path |
Character string, local file path to the topics repository source code. |
repo |
Character string, URL of the Community universe. |
mock |
For testing purposes only, a named list of data frames for inputs to various intermediate functions. |
NULL
(invisibly). Called for its side effects.