From f1094bf636f95f5dfcb05408d2ca0960fa792c8e Mon Sep 17 00:00:00 2001 From: chainsawriot Date: Tue, 17 Dec 2024 20:45:14 +0100 Subject: [PATCH] Fix #458 (#461) * Fix #458 The S3 method can be dispatched. But the problem is that it can't be tested with testthat. Why? * Make test work * Reduce line count * Simplify .standardize_format --- DESCRIPTION | 2 +- NEWS.md | 6 ++++++ R/extensions.R | 6 +++--- R/utils.R | 8 ++------ tests/testthat/test_extensions.R | 21 +++++++++++++-------- 5 files changed, 25 insertions(+), 18 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 9da0a0b..0aa8209 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,7 +1,7 @@ Package: rio Type: Package Title: A Swiss-Army Knife for Data I/O -Version: 1.2.3 +Version: 1.2.4 Authors@R: c(person("Jason", "Becker", role = "aut", email = "jason@jbecker.co"), person("Chung-hong", "Chan", role = c("aut", "cre"), email = "chainsawtiney@gmail.com", comment = c(ORCID = "0000-0002-6232-7530")), diff --git a/NEWS.md b/NEWS.md index 01a73dd..522e279 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,3 +1,9 @@ +# rio 1.2.4 + +Bug fixes + +* Fix #458, custom S3 import and export functions work again + # rio 1.2.3 * Fix #453, don't nudge the user to install all suggested packages diff --git a/R/extensions.R b/R/extensions.R index 45a91ca..d9198e3 100644 --- a/R/extensions.R +++ b/R/extensions.R @@ -3,8 +3,8 @@ } .import.default <- function(file, ...) { - fileinfo <- get_info(file) - if (is.na(fileinfo$type) || is.na(fileinfo$import_function) || fileinfo$import_function == "") { + fileinfo <- get_info(file) ## S3 can't be dispatched + if (fileinfo$type == "unknown" || is.na(fileinfo$import_function) || fileinfo$import_function == "") { stop("Format not supported", call. = FALSE) } if (fileinfo$type == "known") { @@ -24,7 +24,7 @@ .export.default <- function(file, x, ...) { fileinfo <- get_info(file) - if (is.na(fileinfo$type) || is.na(fileinfo$export_function) || fileinfo$export_function == "") { + if (fileinfo$type == "unknown" || is.na(fileinfo$export_function) || fileinfo$export_function == "") { stop("Format not supported", call. = FALSE) } if (fileinfo$type == "known") { diff --git a/R/utils.R b/R/utils.R index feaf6c1..81d38c8 100644 --- a/R/utils.R +++ b/R/utils.R @@ -54,7 +54,7 @@ get_ext <- function(file) { ## TODO google sheets matched_formats <- unique_rio_formats[unique_rio_formats$input == input, ] if (nrow(matched_formats) == 0) { - return(list(input = input, format = NA, type = NA, format_name = NA, import_function = NA, export_function = NA, file = file)) + return(list(input = input, format = input, type = "unknown", format_name = NA, import_function = NA, export_function = NA, file = file)) } output <- as.list(matched_formats) output$file <- file @@ -62,11 +62,7 @@ get_ext <- function(file) { } .standardize_format <- function(input) { - info <- .query_format(input, "") - if (is.na(info$format)) { - return(input) - } - info$format + .query_format(input, "")$format } twrap <- function(value, tag) { diff --git a/tests/testthat/test_extensions.R b/tests/testthat/test_extensions.R index b04f832..540d58c 100644 --- a/tests/testthat/test_extensions.R +++ b/tests/testthat/test_extensions.R @@ -1,25 +1,30 @@ library("datasets") +skip_on_cran() test_that("S3 extension mechanism works for imports", { withr::with_tempdir({ write.csv(iris, "iris.custom") - expect_error(import("iris.custom")) + expect_error(import("iris.custom"), "Format not supported") .import.rio_custom <- function(file, ...) { read.csv(file, ...) } - ##expect_true(is.data.frame(import('iris.custom'))) - rm(.import.rio_custom) + expect_error(.import.rio_custom("iris.custom"), NA) + assign(".import.rio_custom", .import.rio_custom, envir = .GlobalEnv) + expect_true(is.data.frame(import("iris.custom"))) + rm(list = ".import.rio_custom", envir = .GlobalEnv) }) }) test_that("S3 extension mechanism works for exports", { withr::with_tempdir({ - expect_error(export("iris.custom")) - .export.rio_custom <- function(file, data, ...) { - write.csv(data, file, ...) + expect_error(export(iris, "iris.custom")) + .export.rio_custom <- function(file, x, ...) { + write.csv(x, file, ...) invisible(file) } - expect_error(is.character(export(iris, "iris.custom"))) - rm(.export.rio_custom) + expect_error(.export.rio_custom("iris.custom", iris), NA) + assign(".export.rio_custom", .export.rio_custom, envir = .GlobalEnv) + expect_true(is.character(export(iris, "iris.custom"))) + rm(list = ".export.rio_custom", envir = .GlobalEnv) }) })