diff --git a/DESCRIPTION b/DESCRIPTION index 2e608eb..72c7ea9 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,6 +1,6 @@ Package: pacs Title: Supplementary Tools for R Packages Developers -Version: 0.4.10 +Version: 0.4.10.9000 Authors@R: person(given = "Maciej", family = "Nasinski", @@ -24,7 +24,7 @@ BugReports: https://github.com/Polkas/pacs/issues Encoding: UTF-8 LazyData: true Roxygen: list(markdown = TRUE) -RoxygenNote: 7.2.1 +RoxygenNote: 7.2.2 Depends: R (>= 3.5.0) Imports: curl, diff --git a/NAMESPACE b/NAMESPACE index 4f3d1e6..57acb7c 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -15,6 +15,7 @@ export(match_flavors) export(pac_checkpage) export(pac_checkred) export(pac_compare_namespace) +export(pac_compare_news) export(pac_compare_versions) export(pac_deps) export(pac_deps_dev) @@ -28,6 +29,7 @@ export(pac_islast) export(pac_last) export(pac_lifeduration) export(pac_namespace) +export(pac_news) export(pac_size) export(pac_timemachine) export(pac_true_size) diff --git a/NEWS.md b/NEWS.md index 75ddb8e..33e726b 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,3 +1,8 @@ +# pacs 0.4.10.9000 + +* add NEWS file related functions, pac_news and pac_compare_news. +* improve code base. + # pacs 0.4.10 * remove the not needed testthat log file. diff --git a/R/comapre.R b/R/comapre.R index 77cbb73..6fd67f9 100644 --- a/R/comapre.R +++ b/R/comapre.R @@ -25,13 +25,10 @@ pac_compare_versions <- function(pac, lib.loc = .libPaths(), repos = "https://cran.rstudio.com/") { fields <- expand_dependency(fields) - stopifnot((length(pac) == 1) && is.character(pac)) - stopifnot(is.null(old) || (length(old) == 1) && is.character(old)) - stopifnot(is.null(new) || (length(new) == 1) && is.character(new)) - stopifnot(is.character(repos)) - stopifnot(is.null(lib.loc) || (all(lib.loc %in% .libPaths()) && (length(list.files(lib.loc)) > 0))) + validate_compare_input(pac, old, new, lib.loc, repos) stopifnot(is_online()) + if (isFALSE(pac_isin(pac, repos))) { return(NA) } @@ -94,13 +91,10 @@ pac_compare_namespace <- function(pac, new = NULL, lib.loc = .libPaths(), repos = "https://cran.rstudio.com/") { - stopifnot((length(pac) == 1) && is.character(pac)) - stopifnot(is.null(old) || (length(old) == 1) && is.character(old)) - stopifnot(is.null(new) || (length(new) == 1) && is.character(new)) - stopifnot(is.character(repos)) - stopifnot(is.null(lib.loc) || (all(lib.loc %in% .libPaths()) && (length(list.files(lib.loc)) > 0))) + validate_compare_input(pac, old, new, lib.loc, repos) stopifnot(is_online()) + if (isFALSE(pac_isin(pac, repos))) { return(NA) } @@ -148,3 +142,74 @@ pac_compare_namespace <- function(pac, structure(result, package = pac, old = old, new = new) } + +#' Compare NEWS files between specific CRAN packages versions +#' @description using the remote github CRAN mirror to compare NEWS files between specific packages versions. +#' @inheritParams standard_args +#' @param repos `character` vector repositories URLs to use. Used only for the validation. Default `https://cran.rstudio.com/` +#' @return `character` with NEWS content between specific versions. +#' @export +#' @examples +#' \dontrun{ +#' pacs::pac_compare_news("shiny", "1.0.0", "1.6.0") +#' # local version to newest one +#' pacs::pac_compare_news("shiny") +#' } +pac_compare_news <- function(pac, + old = NULL, + new = NULL, + lib.loc = .libPaths(), + repos = "https://cran.rstudio.com/") { + + + validate_compare_input(pac, old, new, lib.loc, repos) + stopifnot(is_online()) + + if (isFALSE(pac_isin(pac, repos))) { + return(NA) + } + + if (is.null(old)) { + stopifnot(pac %in% rownames(installed_packages(lib.loc = lib.loc))) + old <- pac_description(pac, local = TRUE)$Version + } + + if (is.null(new)) { + new <- pac_last(pac) + } + + stopifnot(utils::compareVersion(new, old) >= 0) + + version_pattern <- function(version) { + paste0("#.*", version) + } + + last_version <- pac_last(pac, repos = repos) + pac_news <- pac_news(pac, last_version, lib.loc = lib.loc, repos = repos) + + + old_version_reg <- regexpr(version_pattern(old), pac_news) + which_matched_old <- which(old_version_reg > 0)[1] + old_version_pos <- if (which_matched_old > 0) { + which_matched_old + } else { + NA + } + + new_version_reg <- regexpr(version_pattern(new), pac_news) + which_matched_new <- which(new_version_reg > 0)[1] + new_version_pos <- if (which_matched_new > 0) { + which_matched_new + } else { + NA + } + + if (is.na(old_version_pos) || is.na(new_version_pos)) { + return(NA) + } + + result <- pac_news[new_version_pos:(old_version_pos - 1)] + result +} + + diff --git a/R/description.R b/R/description.R index 63d2478..afd7364 100644 --- a/R/description.R +++ b/R/description.R @@ -17,13 +17,7 @@ pac_description <- function(pac, local = FALSE, lib.loc = .libPaths(), repos = "https://cran.rstudio.com/") { - stopifnot((isFALSE(local)) || - (isTRUE(local) && (is.null(version) || isTRUE(utils::packageDescription(pac, lib.loc = lib.loc)$Version == version)))) - stopifnot(all(c(is.null(version), is.null(at))) || xor(!is.null(version), !is.null(at))) - stopifnot(is.null(at) || inherits(at, "Date")) - stopifnot(length(pac) == 1 && is.character(pac)) - stopifnot(is.null(lib.loc) || (all(lib.loc %in% .libPaths()) && (length(list.files(lib.loc)) > 0))) - stopifnot(is.null(version) || (length(version) == 1 && is.character(version))) + validate_pac_input(pac, version, at, local, lib.loc, repos) is_installed <- isTRUE(pac %in% rownames(installed_packages(lib.loc = lib.loc))) if ((!is_installed && local) || (!local && !is_online())) { @@ -83,7 +77,7 @@ pac_description_dcf_raw <- function(pac, version, repos = "https://cran.rstudio. silent = TRUE ) if (inherits(tt, "try-error")) { - result <- cran_archive_file(pac, version, repos, "DESCRIPTION") + result <- cran_archive_file(pac, version, "DESCRIPTION", repos) } else { result <- as.list(read.dcf(ee)[1, ]) } diff --git a/R/namespace.R b/R/namespace.R index 727bc9f..e137888 100644 --- a/R/namespace.R +++ b/R/namespace.R @@ -14,13 +14,7 @@ #' pacs::pac_namespace("memoise", local = TRUE) #' } pac_namespace <- function(pac, version = NULL, at = NULL, local = FALSE, lib.loc = .libPaths(), repos = "https://cran.rstudio.com/") { - stopifnot((isFALSE(local)) || - (isTRUE(local) && (is.null(version) || isTRUE(utils::packageDescription(pac, lib.loc = lib.loc)$Version == version)))) - stopifnot(all(c(is.null(version), is.null(at))) || xor(!is.null(version), !is.null(at))) - stopifnot(is.null(at) || inherits(at, "Date")) - stopifnot(length(pac) == 1 && is.character(pac)) - stopifnot(is.null(lib.loc) || (all(lib.loc %in% .libPaths()) && (length(list.files(lib.loc)) > 0))) - stopifnot(is.null(version) || (length(version) == 1 && is.character(version))) + validate_pac_input(pac, version, at, local, lib.loc, repos) is_installed <- isTRUE(pac %in% rownames(installed_packages(lib.loc = lib.loc))) if ((!is_installed && local) || (!local && !is_online())) { @@ -85,7 +79,7 @@ pac_readnamespace_raw <- function(pac, version, repos = "https://cran.rstudio.co silent = TRUE ) if (inherits(tt, "try-error")) { - result <- cran_archive_file(pac, version, repos, "NAMESPACE") + result <- cran_archive_file(pac, version, "NAMESPACE", repos) } else { result <- readLines(ee, warn = FALSE) unlink(ee) diff --git a/R/news.R b/R/news.R new file mode 100644 index 0000000..e5efa92 --- /dev/null +++ b/R/news.R @@ -0,0 +1,93 @@ +#' Get NEWS for a package +#' @description Get NEWS for a package from CRAN or local +#' @inheritParams standard_args +#' @param repos `character` vector repositories URLs to use. Used only for the validation. Default `https://cran.rstudio.com/` +#' @return `character` with NEWS content. +#' @note Results are cached for 30 minutes with `memoise` package. +#' @export +#' @examples +#' \dontrun{ +#' pacs::pac_news("dplyr", version = "0.8.0") +#' pacs::pac_news("dplyr", at = as.Date("2019-02-01")) +#' } +pac_news <- function( + pac, + version = NULL, + at = NULL, + local = FALSE, + lib.loc = .libPaths(), + repos = "https://cran.rstudio.com/" +) { + + validate_pac_input(pac, version, at, local, lib.loc, repos) + + is_installed <- isTRUE(pac %in% rownames(installed_packages(lib.loc = lib.loc))) + if ((!is_installed && local) || (!local && !is_online())) { + return(NA) + } + + version_installed <- if (is_installed) { + utils::packageDescription(pac)$Version + } else { + NA + } + version_null <- is.null(version) + + if (local && is_installed && is.null(at) && (version_null || isTRUE(utils::compareVersion(version, version_installed) == 0))) { + news_name <- intersect(list.files(system.file(package = pac)), c("NEWS.md", "NEWS", "NEWS.Rmd")) + if (length(news_name) == 0) { + return(NA) + } + return(readLines(system.file(package = pac, news_name[1]), warn = FALSE)) + } else if (isTRUE(is_isin(pac, "https://cran.rstudio.com/"))) { + last_version <- pac_last(pac, repos = repos) + version <- if (!version_null) { + version + } else if (!is.null(at)) { + vv <- utils::tail(pac_timemachine(pac, at = at)$Version, 1) + if (isNA(vv) || is.null(vv)) { + return(NA) + } + vv + } else { + last_version + } + news_lines <- pac_readnews(pac, version, repos) + if (isTRUE(is.na(news_lines))) { + return(NA) + } else if (length(news_lines) == 0) { + return(NA) + } else { + return(news_lines) + } + } else { + return(NA) + } +} + + +pac_readnews_raw <- function(pac, version, repos = "https://cran.rstudio.com/") { + ee <- tempfile() + d_url <- sprintf( + "https://raw.githubusercontent.com/cran/%s/%s/NEWS", + pac, + version + ) + tt <- try( + { + suppressWarnings(utils::download.file(d_url, + destfile = ee, + quiet = TRUE + )) + }, + silent = TRUE + ) + if (inherits(tt, "try-error")) { + result <- cran_archive_file(pac, version, "NEWS", repos) + } else { + res <- readLines(ee) + unlink(ee) + } +} + +pac_readnews <- memoise::memoise(pac_readnews_raw, cache = cachem::cache_mem(max_age = 30 * 60)) diff --git a/R/read_file_cran.R b/R/read_file_cran.R new file mode 100644 index 0000000..f21a647 --- /dev/null +++ b/R/read_file_cran.R @@ -0,0 +1,59 @@ +#' Read a file from CRAN +#' @description Read a file from CRAN package source. +#' @param pac `character` package name. +#' @param version `character` package version. +#' @param repos `character` vector repositories URLs to use. Used only for the validation. Default `https://cran.rstudio.com/` +#' @param file `character` file name to read. Possible values are `DESCRIPTION` and `NAMESPACE`. +#' @keywords internal +cran_archive_file <- function(pac, version, file, repos = "https://cran.rstudio.com/") { + last_version <- pac_last(pac, repos) + + if (isTRUE(!is.null(version) && version != last_version)) { + base_url <- sprintf("https://cran.r-project.org/src/contrib/Archive/%s", pac) + } else { + base_url <- "https://cran.r-project.org/src/contrib" + version <- last_version + } + + d_url <- sprintf( + "%s/%s_%s.tar.gz", + base_url, + pac, + version + ) + + temp_tar <- tempfile(fileext = ".tar.gz") + + download <- try( + expr = { + suppressWarnings(utils::download.file(d_url, + destfile = temp_tar, + quiet = TRUE + )) + }, + silent = TRUE + ) + + if (inherits(download, "try-error")) { + result <- structure(list(), package = pac, version = version) + } else { + temp_dir <- tempdir() + utils::untar(temp_tar, exdir = temp_dir) + if (file == "DESCRIPTION") { + result <- as.list(read.dcf(file.path(temp_dir, pac, "DESCRIPTION"))[1, ]) + } else if (file == "NAMESPACE") { + result <- readLines(file.path(temp_dir, pac, "NAMESPACE"), warn = FALSE) + } else if (file == "NEWS") { + news_name <- intersect(list.files(file.path(temp_dir, pac)), c("NEWS.md", "NEWS", "NEWS.Rmd")) + if (length(news_name) == 0) { + warning("NEWS file not found") + return(NA) + } + result <- readLines(file.path(temp_dir, pac, news_name[1]), warn = FALSE) + } else { + stop("Invalid file name") + } + } + unlink(temp_tar) + result +} diff --git a/R/read_file_github.R b/R/read_file_github.R new file mode 100644 index 0000000..4eaba6c --- /dev/null +++ b/R/read_file_github.R @@ -0,0 +1,32 @@ +#' Read a file from a GitHub CRAN repository +#' @description Read a file from a GitHub CRAN repository. +#' @param pac `character` package name. +#' @param version `character` package version. +#' @param file `character` file name to read. Possible values are `DESCRIPTION` and `NAMESPACE`. +#' @param repos `character` vector repositories URLs to use. Used only for the validation. Default `https://cran.rstudio.com/` +#' @note if the file is not found in the GitHub repository, it will try to find it in the CRAN archive. +#' @keywords internal +read_github_file <- function(pac, version, file, repos = "https://cran.rstudio.com/") { + ee <- tempfile() + d_url <- sprintf( + "https://raw.githubusercontent.com/cran/%s/%s/%s", + pac, + version, + file + ) + tt <- try( + expr = { + suppressWarnings(utils::download.file(d_url, + destfile = ee, + quiet = TRUE + )) + }, + silent = TRUE + ) + if (inherits(tt, "try-error")) { + result <- cran_archive_file(pac, version, repos, file) + } else { + res <- readLines(ee) + unlink(ee) + } +} diff --git a/R/utils.R b/R/utils.R index 43e224a..813eb3d 100644 --- a/R/utils.R +++ b/R/utils.R @@ -256,50 +256,6 @@ expand_dependency <- function(fields) { } } -cran_archive_file <- function(pac, version, repos, file) { - last_version <- pac_last(pac, repos) - - if (isTRUE(!is.null(version) && version != last_version)) { - base_url <- sprintf("https://cran.r-project.org/src/contrib/Archive/%s", pac) - } else { - base_url <- "https://cran.r-project.org/src/contrib" - version <- last_version - } - - d_url <- sprintf( - "%s/%s_%s.tar.gz", - base_url, - pac, - version - ) - - temp_tar <- tempfile(fileext = ".tar.gz") - - download <- try( - { - suppressWarnings(utils::download.file(d_url, - destfile = temp_tar, - quiet = TRUE - )) - }, - silent = TRUE - ) - - if (inherits(download, "try-error")) { - result <- structure(list(), package = pac, version = version) - } else { - temp_dir <- tempdir() - utils::untar(temp_tar, exdir = temp_dir) - # tabs are not acceptable - result <- switch(file, - DESCRIPTION = as.list(read.dcf(file.path(temp_dir, pac, "DESCRIPTION"))[1, ]), - NAMESPACE = readLines(file.path(temp_dir, pac, "NAMESPACE"), warn = FALSE) - ) - } - unlink(temp_tar) - result -} - read_html_table <- function(table_lines) { rr_range <- grep("]*>", table_lines) if (length(rr_range) != 2) { diff --git a/R/utils_validate.R b/R/utils_validate.R new file mode 100644 index 0000000..25a597e --- /dev/null +++ b/R/utils_validate.R @@ -0,0 +1,23 @@ + +#' validate pac input +#' @keywords internal +validate_pac_input <- function(pac, version, at, local, lib.loc, repos) { + stopifnot(length(pac) == 1 && is.character(pac)) + stopifnot(is.null(at) || inherits(at, "Date")) + stopifnot(is.null(version) || (length(version) == 1 && is.character(version))) + stopifnot(all(c(is.null(version), is.null(at))) || xor(!is.null(version), !is.null(at))) + stopifnot(is.null(lib.loc) || (all(lib.loc %in% .libPaths()) && (length(list.files(lib.loc)) > 0))) + stopifnot(is.character(repos)) + stopifnot((isFALSE(local)) || + (isTRUE(local) && (is.null(version) || isTRUE(utils::packageDescription(pac, lib.loc = lib.loc)$Version == version)))) +} + +#' validate compare input +#' @keywords internal +validate_compare_input <- function(pac, old, new, lib.loc, repos) { + stopifnot((length(pac) == 1) && is.character(pac)) + stopifnot(is.null(old) || (length(old) == 1) && is.character(old)) + stopifnot(is.null(new) || (length(new) == 1) && is.character(new)) + stopifnot(is.character(repos)) + stopifnot(is.null(lib.loc) || (all(lib.loc %in% .libPaths()) && (length(list.files(lib.loc)) > 0))) +} diff --git a/man/cran_archive_file.Rd b/man/cran_archive_file.Rd new file mode 100644 index 0000000..85ecf44 --- /dev/null +++ b/man/cran_archive_file.Rd @@ -0,0 +1,21 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/read_file_cran.R +\name{cran_archive_file} +\alias{cran_archive_file} +\title{Read a file from CRAN} +\usage{ +cran_archive_file(pac, version, file, repos = "https://cran.rstudio.com/") +} +\arguments{ +\item{pac}{\code{character} package name.} + +\item{version}{\code{character} package version.} + +\item{file}{\code{character} file name to read. Possible values are \code{DESCRIPTION} and \code{NAMESPACE}.} + +\item{repos}{\code{character} vector repositories URLs to use. Used only for the validation. Default \verb{https://cran.rstudio.com/}} +} +\description{ +Read a file from CRAN package source. +} +\keyword{internal} diff --git a/man/pac_compare_news.Rd b/man/pac_compare_news.Rd new file mode 100644 index 0000000..f1e0c7c --- /dev/null +++ b/man/pac_compare_news.Rd @@ -0,0 +1,38 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/comapre.R +\name{pac_compare_news} +\alias{pac_compare_news} +\title{Compare NEWS files between specific CRAN packages versions} +\usage{ +pac_compare_news( + pac, + old = NULL, + new = NULL, + lib.loc = .libPaths(), + repos = "https://cran.rstudio.com/" +) +} +\arguments{ +\item{pac}{\code{character} a package name.} + +\item{old}{\code{character} an old version of package, default local version. Default: \code{NULL}} + +\item{new}{\code{character} a new version of package, default newest version. Default: \code{NULL}} + +\item{lib.loc}{\code{character} vector of search paths with local packages. Default: \code{.libPaths()}} + +\item{repos}{\code{character} vector repositories URLs to use. Used only for the validation. Default \verb{https://cran.rstudio.com/}} +} +\value{ +\code{character} with NEWS content between specific versions. +} +\description{ +using the remote github CRAN mirror to compare NEWS files between specific packages versions. +} +\examples{ +\dontrun{ +pacs::pac_compare_news("shiny", "1.0.0", "1.6.0") +# local version to newest one +pacs::pac_compare_news("shiny") +} +} diff --git a/man/pac_news.Rd b/man/pac_news.Rd new file mode 100644 index 0000000..407a684 --- /dev/null +++ b/man/pac_news.Rd @@ -0,0 +1,43 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/news.R +\name{pac_news} +\alias{pac_news} +\title{Get NEWS for a package} +\usage{ +pac_news( + pac, + version = NULL, + at = NULL, + local = FALSE, + lib.loc = .libPaths(), + repos = "https://cran.rstudio.com/" +) +} +\arguments{ +\item{pac}{\code{character} a package name.} + +\item{version}{\code{character} version of a package. Default: \code{NULL}} + +\item{at}{\code{Date} from which to take the version. Default: \code{NULL}} + +\item{local}{\code{logical} if to use local repository (or newest remote packages). Default: \code{FALSE}} + +\item{lib.loc}{\code{character} vector of search paths with local packages. Default: \code{.libPaths()}} + +\item{repos}{\code{character} vector repositories URLs to use. Used only for the validation. Default \verb{https://cran.rstudio.com/}} +} +\value{ +\code{character} with NEWS content. +} +\description{ +Get NEWS for a package from CRAN or local +} +\note{ +Results are cached for 30 minutes with \code{memoise} package. +} +\examples{ +\dontrun{ +pacs::pac_news("dplyr", version = "0.8.0") +pacs::pac_news("dplyr", at = as.Date("2019-02-01")) +} +} diff --git a/man/read_github_file.Rd b/man/read_github_file.Rd new file mode 100644 index 0000000..aa21dbd --- /dev/null +++ b/man/read_github_file.Rd @@ -0,0 +1,24 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/read_file_github.R +\name{read_github_file} +\alias{read_github_file} +\title{Read a file from a GitHub CRAN repository} +\usage{ +read_github_file(pac, version, file, repos = "https://cran.rstudio.com/") +} +\arguments{ +\item{pac}{\code{character} package name.} + +\item{version}{\code{character} package version.} + +\item{file}{\code{character} file name to read. Possible values are \code{DESCRIPTION} and \code{NAMESPACE}.} + +\item{repos}{\code{character} vector repositories URLs to use. Used only for the validation. Default \verb{https://cran.rstudio.com/}} +} +\description{ +Read a file from a GitHub CRAN repository. +} +\note{ +if the file is not found in the GitHub repository, it will try to find it in the CRAN archive. +} +\keyword{internal} diff --git a/man/validate_compare_input.Rd b/man/validate_compare_input.Rd new file mode 100644 index 0000000..f72794f --- /dev/null +++ b/man/validate_compare_input.Rd @@ -0,0 +1,12 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/utils_validate.R +\name{validate_compare_input} +\alias{validate_compare_input} +\title{validate compare input} +\usage{ +validate_compare_input(pac, old, new, lib.loc, repos) +} +\description{ +validate compare input +} +\keyword{internal} diff --git a/man/validate_pac_input.Rd b/man/validate_pac_input.Rd new file mode 100644 index 0000000..d6da3c6 --- /dev/null +++ b/man/validate_pac_input.Rd @@ -0,0 +1,12 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/utils_validate.R +\name{validate_pac_input} +\alias{validate_pac_input} +\title{validate pac input} +\usage{ +validate_pac_input(pac, version, at, local, lib.loc, repos) +} +\description{ +validate pac input +} +\keyword{internal} diff --git a/tests/testthat/test-description.R b/tests/testthat/test-description.R index 2b16723..08f0163 100644 --- a/tests/testthat/test-description.R +++ b/tests/testthat/test-description.R @@ -1,8 +1,8 @@ test_that("cran_archive_file", { skip_if_offline() - expect_true(length(cran_archive_file("dplyr", "1.0.0", "https://cran.rstudio.com/", "DESCRIPTION")) == 22) + expect_true(length(cran_archive_file("dplyr", "1.0.0", "DESCRIPTION", "https://cran.rstudio.com/")) == 22) expect_identical( - cran_archive_file("dplyr", "0.0.0.1", "https://cran.rstudio.com/", "DESCRIPTION"), + cran_archive_file("dplyr", "0.0.0.1", "DESCRIPTION", "https://cran.rstudio.com/"), structure(list(), package = "dplyr", version = "0.0.0.1") ) }) diff --git a/tests/testthat/test-news.R b/tests/testthat/test-news.R new file mode 100644 index 0000000..ed8b0eb --- /dev/null +++ b/tests/testthat/test-news.R @@ -0,0 +1,5 @@ +test_that("pacs::pac_news", { + skip_if_offline() + expect_true(is.character(pac_news("dplyr", version = "0.8.0"))) + expect_true(is.character(pac_news("dplyr", at = as.Date("2019-02-01")))) +}) \ No newline at end of file diff --git a/tests/testthat/test-validate_pac_input.R b/tests/testthat/test-validate_pac_input.R new file mode 100644 index 0000000..cc7b832 --- /dev/null +++ b/tests/testthat/test-validate_pac_input.R @@ -0,0 +1,9 @@ +test_that("test valid validate_pac_input input", { + expect_silent(validate_pac_input("memoise", version = NULL, at = NULL, local = TRUE, lib.loc = .libPaths(), repos = "https://cran.rstudio.com/")) + expect_silent(validate_pac_input("memoise", version = "1.1.0", at = NULL, local = FALSE, lib.loc = .libPaths(), repos = "https://cran.rstudio.com/")) +}) + +test_that("test invalid validate_pac_input input", { + expect_error(validate_pac_input("memoise", version = "1.1.0", at = NULL, local = TRUE, lib.loc = .libPaths(), repos = "https://cran.rstudio.com/")) + expect_error(validate_pac_input("memoise", version = "1.1.0", at = as.Date("2019-02-01"), local = FALSE, lib.loc = .libPaths(), repos = "https://cran.rstudio.com/")) +})