Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add support for renv lockfiles (#55) #80

Merged
merged 9 commits into from
Feb 26, 2023
3 changes: 3 additions & 0 deletions .Rbuildignore
Original file line number Diff line number Diff line change
Expand Up @@ -7,3 +7,6 @@
^CRAN-SUBMISSION$
^.editorconfig$
^.codecov.yml$
^.*\.Rproj$
^\.Rproj\.user$
tests/.renvignore
43 changes: 43 additions & 0 deletions R/as_pkgrefs.R
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,9 @@ as_pkgrefs.default <- function(x, ...) {
#' @rdname as_pkgrefs
#' @export
as_pkgrefs.character <- function(x, bioc_version = NULL, ...) {
if(.detect_renv_lockfile(x)){
return(.extract_pkgrefs_renv_lockfile(path = x))
}
return(.normalize_pkgs(pkgs = x, bioc_version = bioc_version))
}

Expand All @@ -44,6 +47,26 @@ as_pkgrefs.sessionInfo <- function(x, ...) {
vapply(X = x$otherPkgs, FUN = .extract_pkgref_packageDescription, FUN.VALUE = character(1), USE.NAMES = FALSE)
}

.extract_pkgrefs_renv_lockfile <- function(path){
lockfile <- .parse_renv_lockfile(path)
sources <- vapply(lockfile[["Packages"]],`[[`,character(1),"Source",USE.NAMES = FALSE)
pkgs <- c()
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

a bit better to name this pkgrefs

if("Repository"%in%sources){
pkgs <- c(pkgs, paste0("cran::",vapply(lockfile[["Packages"]][sources=="Repository"],`[[`,character(1),"Package",USE.NAMES = FALSE)))
}
if("Bioconductor"%in%sources){
pkgs <- c(pkgs,paste0("bioc::",vapply(lockfile[["Packages"]][sources=="Bioconductor"],`[[`,character(1),"Package",USE.NAMES = FALSE)))
}
if("GitHub"%in%sources){
pkgs <- c(pkgs,
paste0("github::",
vapply(lockfile[["Packages"]][sources=="GitHub"],`[[`,character(1), "RemoteUsername", USE.NAMES = FALSE),"/",
vapply(lockfile[["Packages"]][sources=="GitHub"],`[[`,character(1), "Package", USE.NAMES = FALSE))
)
}
return(pkgs)
}

.extract_pkgref_packageDescription <- function(packageDescription) {
handle <- packageDescription[['Package']]
if ("GithubRepo" %in% names(packageDescription)) {
Expand All @@ -62,3 +85,23 @@ as_pkgrefs.sessionInfo <- function(x, ...) {
return(paste0("cran::", handle))
## }
}

.detect_renv_lockfile <- function(path){
# assuming all renv lockfiles are called renv.lock and path is only length 1
if(length(path)!=1){
return(FALSE)
}
if(isFALSE(file.exists(path))){
return(FALSE)
}
if (isFALSE(basename(path) == "renv.lock")) {
return(FALSE)
}
TRUE
}

.parse_renv_lockfile <- function(path){
lockfile <- jsonlite::fromJSON(path, simplifyVector = FALSE)
# class(lockfile) <- "renv_lockfile"
lockfile
}
2 changes: 1 addition & 1 deletion R/resolve.R
Original file line number Diff line number Diff line change
Expand Up @@ -212,7 +212,7 @@
#'
#' This function recursively queries dependencies of R packages at a specific snapshot time. The dependency graph can then be used to recreate the computational environment. The data on dependencies are provided by R-hub.
#'
#' @param pkgs `pkgs` can be 1) a character vector of R packages to resolve, or 2) a data structure that [as_pkgrefs()] can convert to a character vector of package references. For 1) `pkgs` can be either in shorthands, e.g. "rtoot", "ropensci/readODS", or in package references, e.g. "cran::rtoot", "github::ropensci/readODS". Please refer to the [Package References documentation](https://r-lib.github.io/pkgdepends/reference/pkg_refs.html) of `pak` for details. Currently, this package supports only cran and github packages. For 2) [as_pkgrefs()] support the output of [sessionInfo()].
#' @param pkgs `pkgs` can be 1) a character vector of R packages to resolve, 2) a path to a [`renv` lockfile](https://rstudio.github.io/renv/articles/lockfile.html), or 3) a data structure that [as_pkgrefs()] can convert to a character vector of package references. For 1) `pkgs` can be either in shorthands, e.g. "rtoot", "ropensci/readODS", or in package references, e.g. "cran::rtoot", "github::ropensci/readODS". Please refer to the [Package References documentation](https://r-lib.github.io/pkgdepends/reference/pkg_refs.html) of `pak` for details. Currently, this package supports only cran and github packages. For 2) [as_pkgrefs()] support the output of [sessionInfo()].
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It would be better to add an integration test to test_resolve.R

testthat("integration of renv to resolve", {
    expect_error(X <- resolve("../testdata/renv.lock", snapshot_date = "2023-01-01"), NA)
    ### more things
})

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@chainsawriot should I move all tests there or do a new set of tests?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just this test. In general, the last part of test_resolve.R is for all tests that require internet.

#' @param snapshot_date Snapshot date, if not specified, assume to be a month ago
#' @param no_enhances logical, whether to ignore packages in the "Enhances" field
#' @param no_suggests logical, whether to ignore packages in the "Suggests" field
Expand Down
2 changes: 1 addition & 1 deletion man/resolve.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions tests/.renvignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
testdata
Binary file added tests/testdata/bioc_renv.RDS
Binary file not shown.
Empty file added tests/testdata/fake_renv.lock
Empty file.
Loading