inst/unitTests/runit.exports.R

### --- Test setup ---
#
# regression tests
#

if(FALSE) {
  ## Not really needed, but can be handy when writing tests
  library(RUnit)
  library(GenABEL)
}

### do not run
#stop("SKIP THIS TEST")
###

### ---- common functions and data -----

#source(paste("../inst/unitTests/shared_functions.R"))
#source(paste(path,"/shared_functions.R",sep=""))

### --- Test functions ---

test.exports <- function()
{
  require(GenABEL.data)
  data(ge03d2.clean)
  nTestIds <- sample(c(10:min(100, nids(ge03d2.clean))), 1)
  nTestSnps <- sample(c(10:min(1000, nsnps(ge03d2.clean))), 1)
  dta <- ge03d2.clean[sort(sample(1:nids(ge03d2.clean), nTestIds)),
                      sort(sample(1:nsnps(ge03d2.clean), nTestSnps))]

  export.plink(dta, filebasename="tmpOld", dpieceFun="old", transpose=FALSE)
  export.plink(dta, filebasename="tmpNew", dpieceFun="new", transpose=FALSE)
  xO <- read.table(file="tmpOld.ped", head=FALSE, strings=FALSE)
  xN <- read.table(file="tmpNew.ped", head=FALSE, strings=FALSE)
  checkIdentical(xN, xO)
  xO <- read.table(file="tmpOld.map", head=FALSE, strings=FALSE)
  xN <- read.table(file="tmpNew.map", head=FALSE, strings=FALSE)
  checkIdentical(xN, xO)
  xO <- read.table(file="tmpOld.map.ext", head=FALSE, strings=FALSE)
  xN <- read.table(file="tmpNew.map.ext", head=FALSE, strings=FALSE)
  checkIdentical(xN, xO)

  unlink("tmpOld*")
  unlink("tmpNew*")

  export.merlin(dta, pedfile="tmpOld.ped", datafile="tmpOld.dat",
                mapfile="tmpOld.map", dpieceFun="old")
  export.merlin(dta, pedfile="tmpNew.ped", datafile="tmpNew.dat",
                mapfile="tmpNew.map", dpieceFun="new")
  xO <- read.table(file="tmpOld.ped", head=FALSE, strings=FALSE)
  xN <- read.table(file="tmpNew.ped", head=FALSE, strings=FALSE)
  checkIdentical(xN, xO)

  xO <- read.table(file="tmpOld.map", head=FALSE, strings=FALSE)
  xN <- read.table(file="tmpNew.map", head=FALSE, strings=FALSE)
  checkIdentical(xN, xO)

  xO <- read.table(file="tmpOld.map.ext", head=FALSE, strings=FALSE)
  xN <- read.table(file="tmpNew.map.ext", head=FALSE, strings=FALSE)
  checkIdentical(xN, xO)

  xO <- read.table(file="tmpOld.dat", head=FALSE, strings=FALSE)
  xN <- read.table(file="tmpNew.dat", head=FALSE, strings=FALSE)
  checkIdentical(xN, xO)

  ## Clean up the files we created
  unlink("tmpOld*")
  unlink("tmpNew*")

  export.plink(dta, filebasename="tmpTrans", transpose=TRUE)
  convert.snp.tped(tpedfile="tmpTrans.tped",
                   tfamfile="tmpTrans.tfam",
                   out="tmpTrans.raw")
  xBack <- load.gwaa.data(gen="tmpTrans.raw", phe="tmpTrans.phe", id="IID")
  strand(xBack) <- strand(dta)
  phdata(xBack) <- phdata(xBack)[, -1]
  sameCode <- which(coding(dta) == coding(xBack))
  checkIdentical(xBack[, sameCode], dta[, sameCode])

  swappedCode <- which(refallele(dta)==effallele(xBack) &
                       effallele(dta)==refallele(xBack))
  for (i in swappedCode) {
    gtDta <- c(2, 1, 0)[as.vector(as.numeric(dta[, i]))+1]
    gtBack <- as.vector(as.numeric(xBack[, i]))
    print(checkIdentical(gtBack, gtDta))
  }

  ## Clean up the files we created
  unlink("tmpTrans*")
}


test.export.merlin.bug2525 <- function()
{
  require(GenABEL.data)
	data(srdta)
  export.merlin(
    srdta[, 1:2], dpieceFun="new",
    mapfile="tmpNew.map", pedfile="tmpNew.ped", datafile="tmpNew.dat"
    )
  export.merlin(
    srdta[, 1:2], dpieceFun="old",
    mapfile="tmpOld.map", pedfile="tmpOld.ped", datafile="tmpOld.dat"
    )
  xO <- read.table(file="tmpOld.ped", head=FALSE, strings=FALSE)
  xN <- read.table(file="tmpNew.ped", head=FALSE, strings=FALSE)
  checkIdentical(xN, xO)

  ## Clean up the files we created
  unlink("tmpOld*")
  unlink("tmpNew*")
}


test.export.merlin.bug2664 <- function() {
  require(GenABEL.data)
	data(srdta)
  export.merlin(
    srdta[1:200, 1:10], dpieceFun="new",
    mapfile="tmp.s1.map", pedfile="tmp.s1.ped", datafile="tmp.s1.dat",
    stepids=1
    )
  export.merlin(
    srdta[1:200, 1:10], dpieceFun="new",
    mapfile="tmp.s10.map", pedfile="tmp.s10.ped", datafile="tmp.s10.dat",
    stepids=10
    )
  x1  <- read.table(file="tmp.s1.ped",  header=FALSE, stringsAsFactors=FALSE)
  x10 <- read.table(file="tmp.s10.ped", header=FALSE, stringsAsFactors=FALSE)
  checkIdentical(x1, x10)

  ## Clean up the files we created
  unlink("tmp.s1.*")
  unlink("tmp.s10.*")
}

Try the GenABEL package in your browser

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

GenABEL documentation built on May 30, 2017, 3:36 a.m.