tests/testthat/test-read.R

context("reading")

test_that("get kallisto path", {
  dir_name <- "small_test_data"

  # the standard case
  file_name <- file.path(dir_name, "abundance.h5")
  result <- get_kallisto_path(dir_name)
  expect_equal(result$ext, "h5")
  expect_equal(result$path, file_name)

  # user gives the full path
  result <- get_kallisto_path(file_name)
  expect_equal(result$ext, "h5")
  expect_equal(result$path, file_name)

  # user gives plain text file (full path)
  file_name <- file.path(dir_name, "abundance.tsv")
  result <- get_kallisto_path(file_name)
  expect_equal(result$ext, "tsv")
  expect_equal(result$path, file_name)

  missing_file_name <- file.path(dir_name, "missing.h5")
  expect_error(get_kallisto_path(missing_file_name))

  expect_error(get_kallisto_path("missing_directory"))

})

test_that("both read types", {
  dir_name <- "small_test_data"

  h5_file_name <- file.path(dir_name, "abundance.h5")
  kal_h5 <- read_kallisto_h5(h5_file_name, read_bootstrap = FALSE)
  kal_h5$abundance <- dplyr::arrange(kal_h5$abundance, target_id)

  tsv_file_name <- file.path(dir_name, "abundance.tsv")
  kal_tsv <- read_kallisto_tsv(tsv_file_name)

  expect_equal(kal_h5$abundance$target_id, kal_tsv$abundance$target_id)
  expect_equal(ncol(kal_h5$abundance), ncol(kal_tsv$abundance))
})

test_that("generalized read", {
  dir_name <- "small_test_data"

  kal_dir <- read_kallisto(dir_name, read_bootstrap = TRUE)
  h5_file_name <- file.path(dir_name, "abundance.h5")
  kal_h5 <- read_kallisto(h5_file_name, read_bootstrap = TRUE)

  expect_equal(kal_dir, kal_h5)

  kal_h5_manual <- read_kallisto_h5(h5_file_name, read_bootstrap = TRUE)
  expect_equal(kal_h5, kal_h5_manual)

  kal_h5 <- read_kallisto(dir_name, read_bootstrap = TRUE, max_bootstrap = 10)
  expect_equal(length(kal_h5$bootstrap), 10L)

  expect_error(read_kallisto(dir_name,
    read_bootstrap = TRUE,
    max_bootstrap = "junk"))

  tsv_file_name <- file.path(dir_name, "abundance.tsv")
  expect_warning(kal_tsv <- read_kallisto(tsv_file_name, read_bootstrap = TRUE))


})

test_that("reading bias and fragment length distribution", {
  # TODO: write me!
})
pachterlab/zika documentation built on May 24, 2019, 5:58 p.m.