diff --git a/NEWS.md b/NEWS.md index 553ac178..bcad5362 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,5 +1,9 @@ # rsconnect (development version) +* Fixed analysis of directories that were smaller than the + `rsconnect.max.bundle.files=10000` limit but larger than the + `renv.config.dependencies.limit=1000` limit. (#968) + # rsconnect 1.0.2 * Fixed redeployments to shinyapps.io where `appName` is provided, but no local diff --git a/R/bundlePackageRenv.R b/R/bundlePackageRenv.R index 2ae9484d..140049dd 100644 --- a/R/bundlePackageRenv.R +++ b/R/bundlePackageRenv.R @@ -9,9 +9,18 @@ snapshotRenvDependencies <- function(bundleDir, ) defer(options(old)) + dependenciesLimit <- getOption("renv.config.dependencies.limit") + if (is.null(dependenciesLimit)) { + maxFiles <- getOption("rsconnect.max.bundle.files", 10000) + oldlim <- options( + renv.config.dependencies.limit = maxFiles + ) + defer(options(oldlim)) + } + # analyze code dependencies ourselves rather than relying on the scan during renv::snapshot, as # that will add renv to renv.lock as a dependency. - deps <- renv::dependencies(bundleDir) + deps <- renv::dependencies(bundleDir, root = bundleDir, progress = FALSE) renv::snapshot(bundleDir, packages = deps$Package, prompt = FALSE) defer(removeRenv(bundleDir)) diff --git a/tests/testthat/_snaps/bundlePackageRenv.md b/tests/testthat/_snaps/bundlePackageRenv.md index 240a8d82..29b9b130 100644 --- a/tests/testthat/_snaps/bundlePackageRenv.md +++ b/tests/testthat/_snaps/bundlePackageRenv.md @@ -1,3 +1,8 @@ +# large directories are analyzed + + Code + deps <- snapshotRenvDependencies(app_dir) + # errors if library and project are inconsistent Code diff --git a/tests/testthat/test-bundlePackageRenv.R b/tests/testthat/test-bundlePackageRenv.R index 7e9d9d28..f2b7f642 100644 --- a/tests/testthat/test-bundlePackageRenv.R +++ b/tests/testthat/test-bundlePackageRenv.R @@ -56,6 +56,20 @@ test_that("works with BioC packages", { expect_equal(Biobase$Repository, biocRepos(".")[[1]]) }) +# https://github.com/rstudio/rsconnect/issues/968 +test_that("large directories are analyzed", { + app_dir <- local_temp_app(list("foo.R" = "library(foreign)")) + data_dir <- file.path(app_dir, "data") + dir.create(data_dir) + for (each in seq_len(1001)) { + writeLines(character(0), file.path(data_dir, paste0(each, ".txt"))) + } + expect_snapshot( + deps <- snapshotRenvDependencies(app_dir) + ) + expect_contains(deps$Package, "foreign") +}) + # parseRenvDependencies --------------------------------------------------- test_that("gets DESCRIPTION from renv & system libraries", {