123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234 |
- discard """
- matrix: "--mm:orc; --mm:refc"
- """
- import std/marshal
- import std/[assertions, objectdollar, streams]
- # TODO: add static tests
- proc testit[T](x: T): string = $$to[T]($$x)
- template check1 =
- let test1: array[0..1, array[0..4, string]] = [
- ["test", "1", "2", "3", "4"], ["test", "1", "2", "3", "4"]]
- doAssert testit(test1) ==
- """[["test", "1", "2", "3", "4"], ["test", "1", "2", "3", "4"]]"""
- let test2: tuple[name: string, s: int] = ("tuple test", 56)
- doAssert testit(test2) == """{"Field0": "tuple test", "Field1": 56}"""
- static: check1()
- check1()
- type
- TE = enum
- blah, blah2
- TestObj = object
- test, asd: int
- case test2: TE
- of blah:
- help: string
- else:
- discard
- PNode = ref TNode
- TNode = object
- next, prev: PNode
- data: string
- proc buildList(): PNode =
- new(result)
- new(result.next)
- new(result.prev)
- result.data = "middle"
- result.next.data = "next"
- result.prev.data = "prev"
- result.next.next = result.prev
- result.next.prev = result
- result.prev.next = result
- result.prev.prev = result.next
- let test3 = TestObj(test: 42, test2: blah)
- doAssert testit(test3) ==
- """{"test": 42, "asd": 0, "test2": "blah", "help": ""}"""
- var test4: ref tuple[a, b: string]
- new(test4)
- test4.a = "ref string test: A"
- test4.b = "ref string test: B"
- discard testit(test4) # serialization uses the pointer address, which is not consistent
- let test5 = @[(0,1),(2,3),(4,5)]
- doAssert testit(test5) ==
- """[{"Field0": 0, "Field1": 1}, {"Field0": 2, "Field1": 3}, {"Field0": 4, "Field1": 5}]"""
- let test6: set[char] = {'A'..'Z', '_'}
- doAssert testit(test6) ==
- """[65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 95]"""
- let test7 = buildList()
- discard testit(test7) # serialization uses the pointer address, which is not consistent
- # bug #1352
- block:
- type
- Entity = object of RootObj
- name: string
- Person = object of Entity
- age: int
- bio: string
- blob: string
- let instance1 = Person(name: "Cletus", age: 12,
- bio: "Я Cletus",
- blob: "ABC\x80")
- doAssert $$instance1 == """{"age": 12, "bio": "Я Cletus", "blob": [65, 66, 67, 128], "name": "Cletus"}"""
- doAssert to[Person]($$instance1).bio == instance1.bio
- doAssert to[Person]($$instance1).blob == instance1.blob
- # bug #5757
- block:
- type
- Something = object
- x: string
- y: int
- let data1 = """{"x": "alpha", "y": 100}"""
- let data2 = """{"x": "omega", "y": 200}"""
- var r = to[Something](data1)
- doAssert $r.x & " " & $r.y == "alpha 100"
- r = to[Something](data2)
- doAssert $r.x & " " & $r.y == "omega 200"
- block:
- type
- Foo = object
- a1: string
- a2: string
- a3: seq[string]
- a4: seq[int]
- a5: seq[int]
- a6: seq[int]
- var foo = Foo(a2: "", a4: @[], a6: @[1])
- foo.a6.setLen 0
- doAssert $$foo == """{"a1": "", "a2": "", "a3": [], "a4": [], "a5": [], "a6": []}"""
- doAssert testit(foo) == """{"a1": "", "a2": "", "a3": [], "a4": [], "a5": [], "a6": []}"""
- import std/[options, json]
- # bug #15934
- block:
- let
- a1 = some(newJNull())
- a2 = none(JsonNode)
- doAssert $($$a1).to[:Option[JsonNode]] == "some(null)"
- doAssert $($$a2).to[:Option[JsonNode]] == "none(JsonNode)"
- doAssert ($$a1).to[:Option[JsonNode]] == some(newJNull())
- doAssert ($$a2).to[:Option[JsonNode]] == none(JsonNode)
- # bug #15620
- block:
- let str = """{"numeric": null}"""
- type
- LegacyEntry = object
- numeric: string
- let test = to[LegacyEntry](str)
- doAssert $test == """(numeric: "")"""
- block:
- let str = """{"numeric": null}"""
- type
- LegacyEntry = object
- numeric: seq[int]
- var test = to[LegacyEntry](str)
- doAssert $test == """(numeric: @[])"""
- # bug #16022
- block:
- let p: proc (): string = proc (): string = "hello world"
- let poc = to[typeof(p)]($$p)
- doAssert poc() == "hello world"
- block:
- type
- A {.inheritable.} = object
- B = object of A
- f: int
- let a: ref A = new(B)
- doAssert $$a[] == "{}" # not "{f: 0}"
- # bug #16496
- block:
- type
- A = ref object
- data: seq[int]
- B = ref object
- x: A
- let o = A(data: @[1, 2, 3, 4])
- let s1 = @[B(x: o), B(x: o)]
- let m = $$ s1
- let s2 = to[seq[B]](m)
- doAssert s2[0].x.data == s2[1].x.data
- doAssert s1[0].x.data == s2[1].x.data
- block:
- type
- Obj = ref object
- i: int
- b: bool
- let
- strm = newStringStream()
- var
- o = Obj(i: 1, b: false)
- t1 = @[o, o]
- t2: seq[Obj]
- doAssert t1[0] == t1[1]
- strm.store(t1)
- strm.setPosition(0)
- strm.load(t2)
- strm.close()
- doAssert t2[0] == t2[1]
- template checkMarshal(data: typed) =
- let orig = data
- let m = $$orig
- let old = to[typeof(orig)](m)
- doAssert data == old
- template main() =
- type
- Book = object
- page: int
- name: string
- let book = Book(page: 12, name: "persona")
- checkMarshal(486)
- checkMarshal(3.14)
- checkMarshal("azure sky")
- checkMarshal(book)
- checkMarshal([1, 2, 3])
- checkMarshal(@[1.5, 2.7, 3.9, 4.2])
- checkMarshal(@["dream", "is", "possible"])
- static: main()
- main()
|