tests/testthat/test-export.R

for (engine in engines) {
    test_that(
        desc = paste("'append' argument", engine, sep = " : "),
        code = {
            con <- file.path(tempdir2(), "lines.txt")
            object1 <- c("aaa", "bbb")
            object2 <- c("ccc", "ddd")
            switch(
                EXPR = engine,
                "base" = {
                    expect_error(
                        object = export(
                            object = object1,
                            con = con,
                            append = TRUE,
                            engine = engine
                        ),
                        regexp = "base"
                    )
                },
                {
                    x <- export(
                        object = object1,
                        con = con,
                        append = FALSE,
                        engine = engine
                    )
                    expect_identical(x, realpath(con))
                    expect_true(file.exists(con))
                    expect_identical(
                        object = import(
                            con = con,
                            format = "lines",
                            engine = engine
                        ),
                        expected = object1
                    )
                    x <- export(
                        object = object2,
                        con = con,
                        append = TRUE,
                        engine = engine
                    )
                    expect_identical(x, realpath(con))
                    expect_true(file.exists(con))
                    expect_identical(
                        object = import(
                            con = con,
                            format = "lines",
                            engine = engine
                        ),
                        expected = c(object1, object2)
                    )
                    unlink2(con)
                }
            )
        }
    )
    for (format in .exportFormatChoices[["character"]]) {
        test_that(
            desc = paste(format, engine, sep = " : "),
            code = {
                testdir <- tempdir2()
                vec <- c("hello", "world")
                con <- file.path(testdir, paste0("character", ".", format))
                x <- export(
                    object = vec,
                    con = con,
                    engine = engine
                )
                expect_identical(x, realpath(con))
                expect_true(file.exists(con))
                expect_identical(
                    object = import(
                        con = con,
                        format = "lines",
                        engine = engine
                    ),
                    expected = vec
                )
                expect_error(
                    export(
                        object = vec,
                        con = con,
                        overwrite = FALSE,
                        engine = engine
                    ),
                    "File exists"
                )
                ## readr engine currently has locked file issues on Windows.
                if (identical(engine, "readr") && isWindows()) {
                    return()
                }
                expect_message(
                    export(
                        object = vec,
                        con = con,
                        overwrite = TRUE,
                        engine = engine
                    ),
                    "Overwriting"
                )
                unlink2(testdir)
            }
        )
    }
}

objects <- list(
    "DFrame" = df,
    "matrix" = mat
)

for (format in .exportFormatChoices[["delim"]]) {
    for (class in names(objects)) {
        for (engine in engines) {
            test_that(
                desc = paste(format, class, engine, sep = " : "),
                code = {
                    testdir <- tempdir2()
                    object <- objects[[class]]
                    con <- file.path(testdir, paste0(class, ".", format))
                    file <- export(
                        object = object,
                        con = con,
                        engine = engine
                    )
                    expect_true(file.exists(file))
                    expect_identical(
                        object = basename(file),
                        expected = paste0(class, ".", format)
                    )
                    reimport <- import(file, engine = engine)
                    expect_true(hasRownames(reimport))
                    ## Check the overwrite support.
                    expect_error(
                        export(
                            object = object,
                            con = con,
                            overwrite = FALSE,
                            engine = engine
                        ),
                        "File exists"
                    )
                    ## readr engine currently has locked file issues on Windows.
                    if (identical(engine, "readr") && isWindows()) {
                        return()
                    }
                    expect_message(
                        export(
                            object = object,
                            con = con,
                            overwrite = TRUE,
                            engine = engine
                        ),
                        "Overwriting"
                    )
                    unlink2(testdir)
                }
            )
        }
        test_that(
            desc = paste(
                "Invalid input",
                format, class,
                sep = " : "
            ),
            code = {
                object <- objects[[class]]
                expect_error(
                    export(object = as.data.frame(object)),
                    "symbol"
                )
            }
        )
    }
}

for (engine in engines) {
    test_that(
        desc = paste("Column names disabled", engine, sep = " : "),
        code = {
            object <- DataFrame(
                "txId" = c("tx0001", "tx0002", "tx0003", "tx0004"),
                "geneId" = c("gene0001", "gene0001", "gene0002", "gene0002")
            )
            con <- file.path(tempdir2(), "tx2gene.csv")
            x <- export(
                object = object,
                con = con,
                colnames = FALSE,
                engine = engine
            )
            header <- import(
                con = x,
                format = "lines",
                nMax = 1L,
                engine = engine
            )
            expect_identical(
                object = header,
                expected = "\"tx0001\",\"gene0001\""
            )
            unlink2(con)
        }
    )
}

for (format in .exportFormatChoices[["Matrix"]]) {
    test_that(
        desc = format,
        code = {
            object <- sparse
            expect_s4_class(object, "sparseMatrix")
            testdir <- tempdir2()
            con <- file.path(testdir, paste0("Matrix", ".", format))
            x <- export(
                object = object,
                con = con
            )
            expect_identical(
                object = x,
                expected = c(
                    "matrix" = realpath(file.path(
                        testdir,
                        paste0("Matrix", ".", format)
                    )),
                    "rownames" = realpath(file.path(
                        testdir,
                        paste0("Matrix", ".", format, ".", "rownames")
                    )),
                    "colnames" = realpath(file.path(
                        testdir,
                        paste0("Matrix", ".", format, ".", "colnames")
                    ))
                )
            )
            expect_true(all(file.exists(x)))
            ## Check accidental overwrite support.
            expect_error(
                object = export(
                    object = object,
                    con = con,
                    overwrite = FALSE
                ),
                regexp = "File exists"
            )
            expect_message(
                object = export(
                    object = object,
                    con = con,
                    overwrite = TRUE
                ),
                regexp = "Overwriting"
            )
            unlink2(testdir)
        }
    )
}

test_that("list : single level", {
    testdir <- tempdir2()
    object <- list("a" = c("a", "b", "c"), "b" = c("c", "d", "e"))
    out <- export(object, con = testdir)
    expect_identical(
        object = basename(unlist(out)),
        expected = c("a.txt", "b.txt")
    )
    expect_true(allAreFiles(unlist(out)))
    unlink2(testdir)
})

test_that("list : recursive", {
    testdir <- tempdir2()
    object <- list(
        "a" = list(
            "aa" = c("a", "b", "c"),
            "ab" = c("d", "e", "f")
        ),
        "b" = list(
            "ba" = c("g", "h", "i"),
            "bb" = c("j", "k", "l")
        )
    )
    out <- export(object, con = testdir)
    expect_identical(
        object = basename(unlist(out)),
        expected = c("aa.txt", "ab.txt", "ba.txt", "bb.txt")
    )
    expect_true(allAreFiles(unlist(out)))
    unlink2(testdir)
})

test_that("list : autopad zeros", {
    testdir <- tempdir2()
    object <- list("a", "b", "c", "d", "e", "f", "g", "h", "i", "j")
    out <- export(object, con = testdir)
    expect_identical(
        object = basename(unlist(out)),
        expected = c(
            "01.txt", "02.txt", "03.txt", "04.txt", "05.txt",
            "06.txt", "07.txt", "08.txt", "09.txt", "10.txt"
        )
    )
    unlink2(testdir)
})

test_that("List : single level", {
    testdir <- tempdir2()
    object <- List(
        "a" = c("a", "b", "c"),
        "b" = c("c", "d", "e")
    )
    out <- export(object, con = testdir)
    expect_identical(
        object = basename(unlist(out)),
        expected = c("a.txt", "b.txt")
    )
    expect_true(allAreFiles(unlist(out)))
    unlink2(testdir)
})

test_that("List : recursive", {
    testdir <- tempdir2()
    object <- List(
        "a" = List(
            "aa" = c("a", "b", "c"),
            "ab" = c("d", "e", "f")
        ),
        "b" = List(
            "ba" = c("g", "h", "i"),
            "bb" = c("j", "k", "l")
        )
    )
    out <- export(object, con = testdir)
    expect_identical(
        object = basename(unlist(out)),
        expected = c("aa.txt", "ab.txt", "ba.txt", "bb.txt")
    )
    expect_true(allAreFiles(unlist(out)))
    unlink2(testdir)
})

test_that("DFrameList", {
    testdir <- tempdir2()
    object <- DFrameList
    out <- export(object, con = testdir)
    expect_identical(
        object = basename(unlist(out)),
        expected = c("1.csv", "2.csv")
    )
    expect_true(allAreFiles(unlist(out)))
    unlink2(testdir)
})

test_that("SplitDFrameList", {
    testdir <- tempdir2()
    object <- SplitDFrameList
    out <- export(object, con = testdir)
    expect_identical(
        object = basename(unlist(out)),
        expected = c("1.csv", "2.csv")
    )
    expect_true(allAreFiles(unlist(out)))
    unlink2(testdir)
})

test_that("GRangesList", {
    testdir <- tempdir2()
    object <- GRangesList
    out <- export(object, con = testdir)
    expect_identical(
        object = basename(unlist(out)),
        expected = c("1.csv", "2.csv", "3.csv")
    )
    expect_true(allAreFiles(unlist(out)))
    unlink2(testdir)
})

test_that("Invalid input", {
    object <- sparse
    expect_error(
        object = export(object = unname(object)),
        regexp = "symbol"
    )
})
acidgenomics/brio documentation built on Feb. 1, 2024, 11:47 a.m.