mirror of
https://github.com/nim-lang/Nim.git
synced 2025-12-28 17:04:41 +00:00
* Improve marshal
Use runnableExamples
Refactor tests
* Readd {.inheritable.} test
Apply suggestions
149 lines
3.7 KiB
Nim
149 lines
3.7 KiB
Nim
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}"
|