summaryrefslogtreecommitdiff
path: root/src/mongo/gotools/src/github.com/mongodb/mongo-tools/legacy/json/hex_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'src/mongo/gotools/src/github.com/mongodb/mongo-tools/legacy/json/hex_test.go')
-rw-r--r--src/mongo/gotools/src/github.com/mongodb/mongo-tools/legacy/json/hex_test.go125
1 files changed, 0 insertions, 125 deletions
diff --git a/src/mongo/gotools/src/github.com/mongodb/mongo-tools/legacy/json/hex_test.go b/src/mongo/gotools/src/github.com/mongodb/mongo-tools/legacy/json/hex_test.go
deleted file mode 100644
index 86fdaaa2ac4..00000000000
--- a/src/mongo/gotools/src/github.com/mongodb/mongo-tools/legacy/json/hex_test.go
+++ /dev/null
@@ -1,125 +0,0 @@
-// Copyright (C) MongoDB, Inc. 2014-present.
-//
-// Licensed under the Apache License, Version 2.0 (the "License"); you may
-// not use this file except in compliance with the License. You may obtain
-// a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
-
-package json
-
-import (
- "fmt"
- "github.com/mongodb/mongo-tools/legacy/testtype"
- . "github.com/smartystreets/goconvey/convey"
- "testing"
-)
-
-func TestHexadecimalNumber(t *testing.T) {
- testtype.SkipUnlessTestType(t, testtype.UnitTestType)
- value := "0x123"
- intValue := 0x123
-
- Convey("When unmarshalling JSON with hexadecimal numeric values", t, func() {
- Convey("works for a single key", func() {
- var jsonMap map[string]interface{}
- key := "key"
- data := fmt.Sprintf(`{"%v":%v}`, key, value)
-
- err := Unmarshal([]byte(data), &jsonMap)
- So(err, ShouldBeNil)
- jsonValue, ok := jsonMap[key].(int32)
- So(ok, ShouldBeTrue)
- So(jsonValue, ShouldEqual, intValue)
- })
-
- Convey("works for multiple keys", func() {
- var jsonMap map[string]interface{}
-
- key1, key2, key3 := "key1", "key2", "key3"
- value1, value2, value3 := "0x100", "0x101", "0x102"
- data := fmt.Sprintf(`{"%v":%v,"%v":%v,"%v":%v}`,
- key1, value1, key2, value2, key3, value3)
-
- err := Unmarshal([]byte(data), &jsonMap)
- So(err, ShouldBeNil)
-
- jsonValue1, ok := jsonMap[key1].(int32)
- So(ok, ShouldBeTrue)
- So(jsonValue1, ShouldEqual, 0x100)
-
- jsonValue2, ok := jsonMap[key2].(int32)
- So(ok, ShouldBeTrue)
- So(jsonValue2, ShouldEqual, 0x101)
-
- jsonValue3, ok := jsonMap[key3].(int32)
- So(ok, ShouldBeTrue)
- So(jsonValue3, ShouldEqual, 0x102)
- })
-
- Convey("works in an array", func() {
- var jsonMap map[string]interface{}
-
- key := "key"
- data := fmt.Sprintf(`{"%v":[%v,%v,%v]}`,
- key, value, value, value)
-
- err := Unmarshal([]byte(data), &jsonMap)
- So(err, ShouldBeNil)
-
- jsonArray, ok := jsonMap[key].([]interface{})
- So(ok, ShouldBeTrue)
-
- for _, _jsonValue := range jsonArray {
- jsonValue, ok := _jsonValue.(int32)
- So(ok, ShouldBeTrue)
- So(jsonValue, ShouldEqual, intValue)
- }
- })
-
- Convey("can have a sign ('+' or '-')", func() {
- var jsonMap map[string]interface{}
-
- key := "key"
- data := fmt.Sprintf(`{"%v":+%v}`, key, value)
-
- err := Unmarshal([]byte(data), &jsonMap)
- So(err, ShouldBeNil)
-
- jsonValue, ok := jsonMap[key].(int32)
- So(ok, ShouldBeTrue)
- So(jsonValue, ShouldEqual, intValue)
-
- data = fmt.Sprintf(`{"%v":-%v}`, key, value)
-
- err = Unmarshal([]byte(data), &jsonMap)
- So(err, ShouldBeNil)
-
- jsonValue, ok = jsonMap[key].(int32)
- So(ok, ShouldBeTrue)
- So(jsonValue, ShouldEqual, -intValue)
- })
-
- Convey("can use '0x' or '0X' prefix", func() {
- var jsonMap map[string]interface{}
-
- key := "key"
- value := "123"
- data := fmt.Sprintf(`{"%v":0x%v}`, key, value)
-
- err := Unmarshal([]byte(data), &jsonMap)
- So(err, ShouldBeNil)
-
- jsonValue, ok := jsonMap[key].(int32)
- So(ok, ShouldBeTrue)
- So(jsonValue, ShouldEqual, intValue)
-
- data = fmt.Sprintf(`{"%v":0X%v}`, key, value)
-
- err = Unmarshal([]byte(data), &jsonMap)
- So(err, ShouldBeNil)
-
- jsonValue, ok = jsonMap[key].(int32)
- So(ok, ShouldBeTrue)
- So(jsonValue, ShouldEqual, intValue)
- })
- })
-}