tests/testthat/test-encode_geno.R

context("encode_geno")

test_that("encode_geno works", {

    geno <- rbind(c("C", "G", "C",  "GG", "CG"),
                  c("A", "A", "AT", "TA", "TT"),
                  c("T", "G", NA,   "GT", "TT"))
    codes <- rbind(c("C", "G"),
                   c("A", "T"),
                   c("T", "G"))

    expected <- rbind(c("A", "B", "A", "B", "H"),
                      c("A", "A", "H", "H", "B"),
                      c("A", "B", "-", "H", "A"))

    expect_equal(encode_geno(geno, codes), expected)

    expected2 <- gsub("Z", "A",
                      gsub("A", "B",
                           gsub("B", "Z", expected)))

    expect_equal(encode_geno(geno, cbind(codes[,2], codes[,1])), expected2)

    # errors: multiple characters, NAs
    expect_error(encode_geno(geno, cbind(paste0(codes[,1], codes[,1]), codes[,2])))
    expect_error(encode_geno(geno, cbind(codes[,1], paste0(codes[,2], codes[,2]))))
    codes[1,2] <- NA
    expect_error(encode_geno(geno, codes))

})


test_that("encode_geno works multi-core", {

    if(isnt_karl()) skip("this test only run locally")

    geno <- rbind(c("C", "G", "C",  "GG", "CG"),
                  c("A", "A", "AT", "TA", "TT"),
                  c("T", "G", NA,   "GT", "TT"))
    codes <- rbind(c("C", "G"),
                   c("A", "T"),
                   c("T", "G"))

    expected <- rbind(c("A", "B", "A", "B", "H"),
                      c("A", "A", "H", "H", "B"),
                      c("A", "B", "-", "H", "A"))

    expect_equal(encode_geno(geno, codes), expected)
    expect_equal(encode_geno(geno, codes, cores=2), expected)

    expected2 <- gsub("Z", "A",
                      gsub("A", "B",
                           gsub("B", "Z", expected)))

    expect_equal(encode_geno(geno, cbind(codes[,2], codes[,1])), expected2)
    expect_equal(encode_geno(geno, cbind(codes[,2], codes[,1]), cores=2), expected2)

})

Try the qtl2convert package in your browser

Any scripts or data that you put into this service are public.

qtl2convert documentation built on July 11, 2022, 5:08 p.m.