inst/tinytest/test_serialize_pb.R

## Jeroen Ooms and Dirk Eddelbuettel

library(RProtoBuf)

#test.serialize_pb <- function() {
##verify that rexp.proto is loaded
RProtoBuf:::pb(rexp.REXP)

##serialize a nested list
x <- list(foo=cars, bar=Titanic)
expect_equal(unserialize_pb(serialize_pb(x, NULL)), x)

##a bit of everything, copied from jsonlite package
set.seed('123')
myobject <- list(
    mynull = NULL,
    mycomplex = lapply(eigen(matrix(-rnorm(9),3)), round, 3),
    mymatrix = round(matrix(rnorm(9), 3),3),
    myint = as.integer(c(1,2,3)),
    mydf = cars,
    mylist = list(foo='bar', 123, NA, NULL, list('test')),
    mylogical = c(TRUE,FALSE,NA),
    mychar = c('foo', NA, 'bar'),
    myemptychar = character(0),
    somemissings = c(1,2,NA,NaN,5, Inf, 7 -Inf, 9, NA),
    myrawvec = charToRaw('This is a test'),
    myS4 = asS4("test")
)

expect_equal(unserialize_pb(serialize_pb(myobject, NULL)), myobject)
#}

#test.serialize_pb.alldatasets <- function() {
datasets <- as.data.frame(data(package="datasets")$results)
datasets$name <- sub("\\s+.*$", "", datasets$Item)

encoded.datasets <- sapply(datasets$name,
                           function(x) serialize_pb(get(x), NULL))

unserialized.datasets <- sapply(encoded.datasets, unserialize_pb)

expect_true(all(sapply(names(unserialized.datasets),
                     function(name) identical(get(name),
                                              unserialized.datasets[[name]]))))
#}


## this was issue #37 reported and fixed by Jeffrey Shen
#test.serialize.sublist <- function() {
x <- packageVersion("RProtoBuf")
expect_identical(x, unserialize_pb(serialize_pb(x, NULL)), info="checking sublists")
#}

t#est.serialize.posixlt <- function() {
x <- as.POSIXlt("1970-01-01T00:00:00Z")
expect_identical(x, unserialize_pb(serialize_pb(x, NULL)), info="checking posixlt")
#}

Try the RProtoBuf package in your browser

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

RProtoBuf documentation built on Nov. 3, 2022, 9:06 a.m.