99 lines
2.1 KiB
Factor
99 lines
2.1 KiB
Factor
|
! Copyright (C) 2006 Chris Double.
|
||
|
! See http://factorcode.org/license.txt for BSD license.
|
||
|
!
|
||
|
USING: tools.test kernel serialize io io.streams.byte-array math
|
||
|
alien arrays byte-arrays bit-arrays float-arrays sequences math
|
||
|
prettyprint parser classes math.constants io.encodings.binary
|
||
|
random assocs ;
|
||
|
IN: serialize.tests
|
||
|
|
||
|
: test-serialize-cell
|
||
|
2^ random dup
|
||
|
binary [ serialize-cell ] with-byte-writer
|
||
|
binary [ deserialize-cell ] with-byte-reader = ;
|
||
|
|
||
|
[ t ] [
|
||
|
100 [
|
||
|
drop
|
||
|
40 [ test-serialize-cell ] all?
|
||
|
4 [ 40 * test-serialize-cell ] all?
|
||
|
4 [ 400 * test-serialize-cell ] all?
|
||
|
4 [ 4000 * test-serialize-cell ] all?
|
||
|
and and and
|
||
|
] all?
|
||
|
] unit-test
|
||
|
|
||
|
TUPLE: serialize-test a b ;
|
||
|
|
||
|
C: <serialize-test> serialize-test
|
||
|
|
||
|
: objects
|
||
|
{
|
||
|
f
|
||
|
t
|
||
|
0
|
||
|
-50
|
||
|
20
|
||
|
5.25
|
||
|
-5.25
|
||
|
C{ 1 2 }
|
||
|
1/2
|
||
|
"test"
|
||
|
{ 1 2 "three" }
|
||
|
V{ 1 2 "three" }
|
||
|
SBUF" hello world"
|
||
|
"hello \u123456 unicode"
|
||
|
\ dup
|
||
|
[ \ dup dup ]
|
||
|
T{ serialize-test f "a" 2 }
|
||
|
B{ 50 13 55 64 1 }
|
||
|
?{ t f t f f t f }
|
||
|
F{ 1.0 3.0 4.0 1.0 2.35 0.33 }
|
||
|
<< 1 [ 2 ] curry parsed >>
|
||
|
{ { "a" "bc" } { "de" "fg" } }
|
||
|
H{ { "a" "bc" } { "de" "fg" } }
|
||
|
} ;
|
||
|
|
||
|
: check-serialize-1 ( obj -- ? )
|
||
|
"=====" print
|
||
|
dup class .
|
||
|
dup .
|
||
|
dup
|
||
|
object>bytes
|
||
|
bytes>object
|
||
|
dup . = ;
|
||
|
|
||
|
: check-serialize-2 ( obj -- ? )
|
||
|
dup number? over wrapper? or [
|
||
|
drop t ! we don't care if numbers aren't interned
|
||
|
] [
|
||
|
"=====" print
|
||
|
dup class .
|
||
|
dup 2array dup .
|
||
|
object>bytes
|
||
|
bytes>object dup .
|
||
|
first2 eq?
|
||
|
] if ;
|
||
|
|
||
|
[ t ] [ objects [ check-serialize-1 ] all? ] unit-test
|
||
|
|
||
|
[ t ] [ objects [ check-serialize-2 ] all? ] unit-test
|
||
|
|
||
|
[ t ] [ pi check-serialize-1 ] unit-test
|
||
|
[ serialize ] must-infer
|
||
|
[ deserialize ] must-infer
|
||
|
|
||
|
[ t ] [
|
||
|
V{ } dup dup push
|
||
|
object>bytes
|
||
|
bytes>object
|
||
|
dup first eq?
|
||
|
] unit-test
|
||
|
|
||
|
[ t ] [
|
||
|
H{ } dup dup dup set-at
|
||
|
object>bytes
|
||
|
bytes>object
|
||
|
dup keys first eq?
|
||
|
] unit-test
|