aboutsummaryrefslogtreecommitdiff
path: root/json_test.go
diff options
context:
space:
mode:
authorNeonXP <i@neonxp.dev>2022-12-27 02:37:02 +0300
committerNeonXP <i@neonxp.dev>2022-12-27 02:40:03 +0300
commit76a7f461ebbde70ea0e3d4f9b79c08139acaee7c (patch)
tree5e6dcb05f00be5109b3465ef16a6e9169a27497e /json_test.go
parent6f1d1df79f161cfc695f74d271d689ba72c44d09 (diff)
Completely rewritedv0.1.0
Diffstat (limited to 'json_test.go')
-rw-r--r--json_test.go143
1 files changed, 109 insertions, 34 deletions
diff --git a/json_test.go b/json_test.go
index 515f697..b058417 100644
--- a/json_test.go
+++ b/json_test.go
@@ -1,66 +1,141 @@
-package json
+package json_test
import (
"reflect"
"testing"
- "go.neonxp.dev/json/model"
+ "go.neonxp.dev/json"
+ "go.neonxp.dev/json/std"
)
-func TestQuery(t *testing.T) {
+func TestJSON_Unmarshal(t *testing.T) {
+ j := &json.JSON{
+ Factory: std.Factory,
+ }
type args struct {
- json string
- query string
+ input string
}
tests := []struct {
name string
args args
- want model.Node
+ want json.Node
wantErr bool
}{
{
- name: "Complex",
+ name: "object with strings",
args: args{
- json: `{
- "key1": "value1",
- "key2": [
- "item 1",
- "item 2",
- "item 3",
- "item 4",
- "item 5",
- "item 6",
- {
- "status": "invalid"
- },
+ input: `{
+ "hello": "world",
+ }`,
+ },
+ want: std.ObjectNode{
+ "hello": &std.StringNode{Value: "world"},
+ },
+ wantErr: false,
+ },
+ {
+ name: "complex object",
+ args: args{
+ input: `{
+ "string key": "string value",
+ "number key": 123.321,
+ "bool key": true,
+ "object": {
+ "one": "two",
+ "object 2": {
+ "three": "four"
+ }
+ },
+ "array": [
+ "one",
+ 2,
+ true,
+ null,
{
- "status": "valid",
- "embededArray": [
- "not target",
- "not target",
- "not target",
- "target",
- "not target",
- "not target",
- ]
+ "five": "six"
}
]
}`,
- query: "key2.7.embededArray.3",
},
- want: model.NewNode("target"),
- wantErr: false,
+ want: std.ObjectNode{
+ "string key": j.MustNode("string value"),
+ "number key": j.MustNode(123.321),
+ "bool key": j.MustNode(true),
+ "object": std.ObjectNode{
+ "one": j.MustNode("two"),
+ "object 2": std.ObjectNode{
+ "three": j.MustNode("four"),
+ },
+ },
+ "array": &std.ArrayNode{
+ j.MustNode("one"),
+ j.MustNode(2),
+ j.MustNode(true),
+ j.MustNode(nil),
+ std.ObjectNode{
+ "five": j.MustNode("six"),
+ },
+ },
+ },
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
- got, err := Query(tt.args.json, tt.args.query)
+ got, err := j.Unmarshal(tt.args.input)
if (err != nil) != tt.wantErr {
- t.Errorf("Query() error = %v, wantErr %v", err, tt.wantErr)
+ t.Errorf("JSON.Unmarshal() error = %v, wantErr %v", err, tt.wantErr)
return
}
if !reflect.DeepEqual(got, tt.want) {
- t.Errorf("Query() = %v, want %v", got, tt.want)
+ t.Errorf("JSON.Unmarshal() = %v, want %v", got, tt.want)
+ }
+ })
+ }
+}
+
+func TestJSON_Marshal(t *testing.T) {
+ j := &json.JSON{
+ Factory: std.Factory,
+ }
+ type args struct {
+ n json.Node
+ }
+ tests := []struct {
+ name string
+ args args
+ want string
+ }{
+ {
+ name: "complex object",
+ args: args{
+ n: std.ObjectNode{
+ "string key": j.MustNode("string value"),
+ "number key": j.MustNode(123.321),
+ "bool key": j.MustNode(true),
+ "object": std.ObjectNode{
+ "one": j.MustNode("two"),
+ "object 2": std.ObjectNode{
+ "three": j.MustNode("four"),
+ },
+ },
+ "array": &std.ArrayNode{
+ j.MustNode("one"),
+ j.MustNode(2),
+ j.MustNode(true),
+ j.MustNode(nil),
+ std.ObjectNode{
+ "five": j.MustNode("six"),
+ },
+ },
+ },
+ },
+ want: `{"string key":"string value","number key":123.321,"bool key":true,"object":{"one":"two","object 2":{"three":"four"}},"array":["one",2,true,null,{"five":"six"}]}`,
+ },
+ }
+ for _, tt := range tests {
+ t.Run(tt.name, func(t *testing.T) {
+ if got := j.Marshal(tt.args.n); len(got) != len(tt.want) {
+ t.Errorf("JSON.Marshal() = %v, want %v", got, tt.want)
}
})
}