import std/marshal # TODO: add static tests proc testit[T](x: T): string = $$to[T]($$x) 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}""" 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: "")""" # 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}"