tests/testthat/testthat_lencat.R

## Data (simulated) for testing ----
## simulate first data set
df1 <- data.frame(len=round(runif(50,0.1,9.9),1),
                  fish=sample(c("A","B","C"),50,replace=TRUE))

## simulate second data set
vals <- 1:5
freq <- 11:15
tmp <- rep(vals,freq)
tmp <- tmp+round(runif(length(tmp),0,0.9),1)
df2 <- data.frame(len1=tmp,
                  len0.1=tmp/10,
                  len0.01=tmp/100,
                  len10=tmp*10,
                  fish=rep(c("A","B","C"),c(30,20,15)))


## Test Messages ----
test_that("lencat() messages",{
  # wrong type of variable
  expect_error(lencat(~fish,data=df1),
               "must be numeric")
  # too many variables
  expect_error(lencat(~len+fish,data=df1),
               "only one variable")
  # bad width values
  expect_error(lencat(~len,data=df1,w=-1),
               "must be positive")
  expect_error(lencat(~len,data=df1,w=c(0.5,1)),
               "of length 1")
  # bad startcats
  expect_error(lencat(~len,data=df1,startcat=c(0.5,1)),
               "of length 1")
  # all NA values in the vector
  expect_warning(lencat(as.numeric(rep(NA,3))),
                 "were missing")
  # use.names but no names given in breaks
  expect_warning(lencat(~len,data=df1,breaks=seq(0,10,1),use.names=TRUE),
                 "Used default labels")
  # data.frame with more than one variable
  expect_error(lencat(df1),
               "data.frame with one column")
})


## Test Output Types ----
test_that("lencat() results",{
  ## Simple examples (same width as that created)
  tmp <- lencat(~len1,data=df2,w=1)
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"numeric")
  tmp <- lencat(~len0.1,data=df2,w=0.1)
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"numeric")
  tmp <- lencat(~len0.01,data=df2,w=0.01)
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"numeric")
  tmp <- lencat(~len10,data=df2,w=10)
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"numeric")
  ## Does it handle 1-column data.frame
  tmp <- lencat(data.frame(df2$len1),w=1)
  expect_is(tmp,"numeric")
  ## Different widths (don't control startcat)
  tmp <- lencat(~len1,data=df2,w=2)
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"numeric")
  tmp <- lencat(~len0.1,data=df2,w=0.2)
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"numeric")
  tmp <- lencat(~len10,data=df2,w=20)
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"numeric")
  ## Different widths (control startcat)
  tmp <- lencat(~len1,data=df2,w=2,startcat=1)
  expect_is(tmp$LCat,"numeric")
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  tmp <- lencat(~len0.1,data=df2,w=0.2,startcat=0.1)
  expect_is(tmp$LCat,"numeric")
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  tmp <- lencat(~len10,data=df2,w=20,startcat=10)
  expect_is(tmp$LCat,"numeric")
  ## Using breaks
  tmp <- lencat(~len1,data=df2,breaks=c(1,2,4))
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"numeric")
  tmp <- lencat(~len0.1,data=df2,breaks=c(1,2,4)/10)
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"numeric")
  ## using named breaks
  # but don't use names
  tmp <- lencat(~len1,data=df2,breaks=c(one=1,two=2,four=4))
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"numeric")
  # but do use names
  tmp <- lencat(~len1,data=df2,breaks=c(one=1,two=2,four=4),use.names=TRUE)
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"factor")
  # use names but don't return as a factor
  tmp <- lencat(~len1,data=df2,breaks=c(one=1,two=2,four=4),
                use.names=TRUE,as.fact=FALSE)
  expect_is(tmp,"data.frame")
  expect_equal(colnames(tmp),c(colnames(df2),"LCat"))
  expect_is(tmp$LCat,"character")
})

## Validate Results ----
test_that("lencat() results",{
  ## Simple examples (same width as that created)
  tmp <- lencat(~len1,data=df2,w=1)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freq)
  tmp <- lencat(~len0.1,data=df2,w=0.1)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freq)
  tmp <- lencat(~len0.01,data=df2,w=0.01)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freq)
  tmp <- lencat(~len10,data=df2,w=10)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freq)
  ## Does it handle 1-column data.frame
  tmp <- lencat(data.frame(df2$len1),w=1)
  expect_is(tmp,"numeric")
  expect_equal(as.numeric(xtabs(~tmp)),freq)
  ## Different widths (don't control startcat)
  freqtmp <- c(0,freq[c(2,4)])+freq[c(1,3,5)]
  tmp <- lencat(~len1,data=df2,w=2)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp)
  tmp <- lencat(~len0.1,data=df2,w=0.2)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp)
  tmp <- lencat(~len10,data=df2,w=20)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp)
  ## Different widths (control startcat)
  freqtmp <- freq[c(1,3,5)]+c(freq[c(2,4)],0)
  tmp <- lencat(~len1,data=df2,w=2,startcat=1)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp)
  tmp <- lencat(~len0.1,data=df2,w=0.2,startcat=0.1)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp)
  tmp <- lencat(~len10,data=df2,w=20,startcat=10)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp)
  ## Using breaks
  freqtmp <- freq[c(1,2,4)]+c(0,freq[c(3,5)])
  tmp <- lencat(~len1,data=df2,breaks=c(1,2,4))
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp)
  tmp <- lencat(~len0.1,data=df2,breaks=c(1,2,4)/10)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp)
  ## using named breaks
  # but don't use names
  tmp <- lencat(~len1,data=df2,breaks=c(one=1,two=2,four=4))
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp)
  # but do use names
  tmp <- lencat(~len1,data=df2,breaks=c(one=1,two=2,four=4),use.names=TRUE)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp)
  # use names but don't return as a factor
  tmp <- lencat(~len1,data=df2,breaks=c(one=1,two=2,four=4),
                use.names=TRUE,as.fact=FALSE)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),freqtmp[c(3,1,2)])
  # Don't need an automatic larger break
  tmp <- lencat(~len1,data=df2,breaks=c(one=1,two=2,four=4,six=6),use.names=TRUE)
  expect_equal(as.numeric(xtabs(~LCat,data=tmp)),c(freqtmp,0))
})

Try the FSA package in your browser

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

FSA documentation built on Aug. 27, 2023, 1:06 a.m.