]> git.proxmox.com Git - ceph.git/blobdiff - ceph/src/jaegertracing/thrift/lib/go/thrift/json_protocol_test.go
import quincy beta 17.1.0
[ceph.git] / ceph / src / jaegertracing / thrift / lib / go / thrift / json_protocol_test.go
diff --git a/ceph/src/jaegertracing/thrift/lib/go/thrift/json_protocol_test.go b/ceph/src/jaegertracing/thrift/lib/go/thrift/json_protocol_test.go
deleted file mode 100644 (file)
index 59c4d64..0000000
+++ /dev/null
@@ -1,650 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you 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
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-
-package thrift
-
-import (
-       "context"
-       "encoding/base64"
-       "encoding/json"
-       "fmt"
-       "math"
-       "strconv"
-       "testing"
-)
-
-func TestWriteJSONProtocolBool(t *testing.T) {
-       thetype := "boolean"
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       for _, value := range BOOL_VALUES {
-               if e := p.WriteBool(value); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if e := p.Flush(context.Background()); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error flushing: %s", thetype, value, e.Error())
-               }
-               s := trans.String()
-               expected := ""
-               if value {
-                       expected = "1"
-               } else {
-                       expected = "0"
-               }
-               if s != expected {
-                       t.Fatalf("Bad value for %s %v: %s expected", thetype, value, s)
-               }
-               v := -1
-               if err := json.Unmarshal([]byte(s), &v); err != nil || (v != 0) != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-               }
-               trans.Reset()
-       }
-       trans.Close()
-}
-
-func TestReadJSONProtocolBool(t *testing.T) {
-       thetype := "boolean"
-       for _, value := range BOOL_VALUES {
-               trans := NewTMemoryBuffer()
-               p := NewTJSONProtocol(trans)
-               if value {
-                       trans.Write([]byte{'1'}) // not JSON_TRUE
-               } else {
-                       trans.Write([]byte{'0'}) // not JSON_FALSE
-               }
-               trans.Flush(context.Background())
-               s := trans.String()
-               v, e := p.ReadBool()
-               if e != nil {
-                       t.Fatalf("Unable to read %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if v != value {
-                       t.Fatalf("Bad value for %s value %v, wrote: %v, received: %v", thetype, value, s, v)
-               }
-               vv := -1
-               if err := json.Unmarshal([]byte(s), &vv); err != nil || (vv != 0) != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, vv)
-               }
-               trans.Reset()
-               trans.Close()
-       }
-}
-
-func TestWriteJSONProtocolByte(t *testing.T) {
-       thetype := "byte"
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       for _, value := range BYTE_VALUES {
-               if e := p.WriteByte(value); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if e := p.Flush(context.Background()); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error flushing: %s", thetype, value, e.Error())
-               }
-               s := trans.String()
-               if s != fmt.Sprint(value) {
-                       t.Fatalf("Bad value for %s %v: %s", thetype, value, s)
-               }
-               v := int8(0)
-               if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-               }
-               trans.Reset()
-       }
-       trans.Close()
-}
-
-func TestReadJSONProtocolByte(t *testing.T) {
-       thetype := "byte"
-       for _, value := range BYTE_VALUES {
-               trans := NewTMemoryBuffer()
-               p := NewTJSONProtocol(trans)
-               trans.WriteString(strconv.Itoa(int(value)))
-               trans.Flush(context.Background())
-               s := trans.String()
-               v, e := p.ReadByte()
-               if e != nil {
-                       t.Fatalf("Unable to read %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if v != value {
-                       t.Fatalf("Bad value for %s value %v, wrote: %v, received: %v", thetype, value, s, v)
-               }
-               if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-               }
-               trans.Reset()
-               trans.Close()
-       }
-}
-
-func TestWriteJSONProtocolI16(t *testing.T) {
-       thetype := "int16"
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       for _, value := range INT16_VALUES {
-               if e := p.WriteI16(value); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if e := p.Flush(context.Background()); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error flushing: %s", thetype, value, e.Error())
-               }
-               s := trans.String()
-               if s != fmt.Sprint(value) {
-                       t.Fatalf("Bad value for %s %v: %s", thetype, value, s)
-               }
-               v := int16(0)
-               if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-               }
-               trans.Reset()
-       }
-       trans.Close()
-}
-
-func TestReadJSONProtocolI16(t *testing.T) {
-       thetype := "int16"
-       for _, value := range INT16_VALUES {
-               trans := NewTMemoryBuffer()
-               p := NewTJSONProtocol(trans)
-               trans.WriteString(strconv.Itoa(int(value)))
-               trans.Flush(context.Background())
-               s := trans.String()
-               v, e := p.ReadI16()
-               if e != nil {
-                       t.Fatalf("Unable to read %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if v != value {
-                       t.Fatalf("Bad value for %s value %v, wrote: %v, received: %v", thetype, value, s, v)
-               }
-               if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-               }
-               trans.Reset()
-               trans.Close()
-       }
-}
-
-func TestWriteJSONProtocolI32(t *testing.T) {
-       thetype := "int32"
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       for _, value := range INT32_VALUES {
-               if e := p.WriteI32(value); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if e := p.Flush(context.Background()); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error flushing: %s", thetype, value, e.Error())
-               }
-               s := trans.String()
-               if s != fmt.Sprint(value) {
-                       t.Fatalf("Bad value for %s %v: %s", thetype, value, s)
-               }
-               v := int32(0)
-               if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-               }
-               trans.Reset()
-       }
-       trans.Close()
-}
-
-func TestReadJSONProtocolI32(t *testing.T) {
-       thetype := "int32"
-       for _, value := range INT32_VALUES {
-               trans := NewTMemoryBuffer()
-               p := NewTJSONProtocol(trans)
-               trans.WriteString(strconv.Itoa(int(value)))
-               trans.Flush(context.Background())
-               s := trans.String()
-               v, e := p.ReadI32()
-               if e != nil {
-                       t.Fatalf("Unable to read %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if v != value {
-                       t.Fatalf("Bad value for %s value %v, wrote: %v, received: %v", thetype, value, s, v)
-               }
-               if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-               }
-               trans.Reset()
-               trans.Close()
-       }
-}
-
-func TestWriteJSONProtocolI64(t *testing.T) {
-       thetype := "int64"
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       for _, value := range INT64_VALUES {
-               if e := p.WriteI64(value); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if e := p.Flush(context.Background()); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error flushing: %s", thetype, value, e.Error())
-               }
-               s := trans.String()
-               if s != fmt.Sprint(value) {
-                       t.Fatalf("Bad value for %s %v: %s", thetype, value, s)
-               }
-               v := int64(0)
-               if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-               }
-               trans.Reset()
-       }
-       trans.Close()
-}
-
-func TestReadJSONProtocolI64(t *testing.T) {
-       thetype := "int64"
-       for _, value := range INT64_VALUES {
-               trans := NewTMemoryBuffer()
-               p := NewTJSONProtocol(trans)
-               trans.WriteString(strconv.FormatInt(value, 10))
-               trans.Flush(context.Background())
-               s := trans.String()
-               v, e := p.ReadI64()
-               if e != nil {
-                       t.Fatalf("Unable to read %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if v != value {
-                       t.Fatalf("Bad value for %s value %v, wrote: %v, received: %v", thetype, value, s, v)
-               }
-               if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-               }
-               trans.Reset()
-               trans.Close()
-       }
-}
-
-func TestWriteJSONProtocolDouble(t *testing.T) {
-       thetype := "double"
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       for _, value := range DOUBLE_VALUES {
-               if e := p.WriteDouble(value); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if e := p.Flush(context.Background()); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error flushing: %s", thetype, value, e.Error())
-               }
-               s := trans.String()
-               if math.IsInf(value, 1) {
-                       if s != jsonQuote(JSON_INFINITY) {
-                               t.Fatalf("Bad value for %s %v, wrote: %v, expected: %v", thetype, value, s, jsonQuote(JSON_INFINITY))
-                       }
-               } else if math.IsInf(value, -1) {
-                       if s != jsonQuote(JSON_NEGATIVE_INFINITY) {
-                               t.Fatalf("Bad value for %s %v, wrote: %v, expected: %v", thetype, value, s, jsonQuote(JSON_NEGATIVE_INFINITY))
-                       }
-               } else if math.IsNaN(value) {
-                       if s != jsonQuote(JSON_NAN) {
-                               t.Fatalf("Bad value for %s %v, wrote: %v, expected: %v", thetype, value, s, jsonQuote(JSON_NAN))
-                       }
-               } else {
-                       if s != fmt.Sprint(value) {
-                               t.Fatalf("Bad value for %s %v: %s", thetype, value, s)
-                       }
-                       v := float64(0)
-                       if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                               t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-                       }
-               }
-               trans.Reset()
-       }
-       trans.Close()
-}
-
-func TestReadJSONProtocolDouble(t *testing.T) {
-       thetype := "double"
-       for _, value := range DOUBLE_VALUES {
-               trans := NewTMemoryBuffer()
-               p := NewTJSONProtocol(trans)
-               n := NewNumericFromDouble(value)
-               trans.WriteString(n.String())
-               trans.Flush(context.Background())
-               s := trans.String()
-               v, e := p.ReadDouble()
-               if e != nil {
-                       t.Fatalf("Unable to read %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if math.IsInf(value, 1) {
-                       if !math.IsInf(v, 1) {
-                               t.Fatalf("Bad value for %s %v, wrote: %v, received: %v", thetype, value, s, v)
-                       }
-               } else if math.IsInf(value, -1) {
-                       if !math.IsInf(v, -1) {
-                               t.Fatalf("Bad value for %s %v, wrote: %v, received: %v", thetype, value, s, v)
-                       }
-               } else if math.IsNaN(value) {
-                       if !math.IsNaN(v) {
-                               t.Fatalf("Bad value for %s %v, wrote: %v, received: %v", thetype, value, s, v)
-                       }
-               } else {
-                       if v != value {
-                               t.Fatalf("Bad value for %s value %v, wrote: %v, received: %v", thetype, value, s, v)
-                       }
-                       if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                               t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-                       }
-               }
-               trans.Reset()
-               trans.Close()
-       }
-}
-
-func TestWriteJSONProtocolString(t *testing.T) {
-       thetype := "string"
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       for _, value := range STRING_VALUES {
-               if e := p.WriteString(value); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if e := p.Flush(context.Background()); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error flushing: %s", thetype, value, e.Error())
-               }
-               s := trans.String()
-               if s[0] != '"' || s[len(s)-1] != '"' {
-                       t.Fatalf("Bad value for %s '%v', wrote '%v', expected: %v", thetype, value, s, fmt.Sprint("\"", value, "\""))
-               }
-               v := new(string)
-               if err := json.Unmarshal([]byte(s), v); err != nil || *v != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, *v)
-               }
-               trans.Reset()
-       }
-       trans.Close()
-}
-
-func TestReadJSONProtocolString(t *testing.T) {
-       thetype := "string"
-       for _, value := range STRING_VALUES {
-               trans := NewTMemoryBuffer()
-               p := NewTJSONProtocol(trans)
-               trans.WriteString(jsonQuote(value))
-               trans.Flush(context.Background())
-               s := trans.String()
-               v, e := p.ReadString()
-               if e != nil {
-                       t.Fatalf("Unable to read %s value %v due to error: %s", thetype, value, e.Error())
-               }
-               if v != value {
-                       t.Fatalf("Bad value for %s value %v, wrote: %v, received: %v", thetype, value, s, v)
-               }
-               v1 := new(string)
-               if err := json.Unmarshal([]byte(s), v1); err != nil || *v1 != value {
-                       t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, *v1)
-               }
-               trans.Reset()
-               trans.Close()
-       }
-}
-
-func TestWriteJSONProtocolBinary(t *testing.T) {
-       thetype := "binary"
-       value := protocol_bdata
-       b64value := make([]byte, base64.StdEncoding.EncodedLen(len(protocol_bdata)))
-       base64.StdEncoding.Encode(b64value, value)
-       b64String := string(b64value)
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       if e := p.WriteBinary(value); e != nil {
-               t.Fatalf("Unable to write %s value %v due to error: %s", thetype, value, e.Error())
-       }
-       if e := p.Flush(context.Background()); e != nil {
-               t.Fatalf("Unable to write %s value %v due to error flushing: %s", thetype, value, e.Error())
-       }
-       s := trans.String()
-       expectedString := fmt.Sprint("\"", b64String, "\"")
-       if s != expectedString {
-               t.Fatalf("Bad value for %s %v\n  wrote:  \"%v\"\nexpected: \"%v\"", thetype, value, s, expectedString)
-       }
-       v1, err := p.ReadBinary()
-       if err != nil {
-               t.Fatalf("Unable to read binary: %s", err.Error())
-       }
-       if len(v1) != len(value) {
-               t.Fatalf("Invalid value for binary\nexpected: \"%v\"\n   read: \"%v\"", value, v1)
-       }
-       for k, v := range value {
-               if v1[k] != v {
-                       t.Fatalf("Invalid value for binary at %v\nexpected: \"%v\"\n   read: \"%v\"", k, v, v1[k])
-               }
-       }
-       trans.Close()
-}
-
-func TestReadJSONProtocolBinary(t *testing.T) {
-       thetype := "binary"
-       value := protocol_bdata
-       b64value := make([]byte, base64.StdEncoding.EncodedLen(len(protocol_bdata)))
-       base64.StdEncoding.Encode(b64value, value)
-       b64String := string(b64value)
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       trans.WriteString(jsonQuote(b64String))
-       trans.Flush(context.Background())
-       s := trans.String()
-       v, e := p.ReadBinary()
-       if e != nil {
-               t.Fatalf("Unable to read %s value %v due to error: %s", thetype, value, e.Error())
-       }
-       if len(v) != len(value) {
-               t.Fatalf("Bad value for %s value length %v, wrote: %v, received length: %v", thetype, len(value), s, len(v))
-       }
-       for i := 0; i < len(v); i++ {
-               if v[i] != value[i] {
-                       t.Fatalf("Bad value for %s at index %d value %v, wrote: %v, received: %v", thetype, i, value[i], s, v[i])
-               }
-       }
-       v1 := new(string)
-       if err := json.Unmarshal([]byte(s), v1); err != nil || *v1 != b64String {
-               t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, *v1)
-       }
-       trans.Reset()
-       trans.Close()
-}
-
-func TestWriteJSONProtocolList(t *testing.T) {
-       thetype := "list"
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       p.WriteListBegin(TType(DOUBLE), len(DOUBLE_VALUES))
-       for _, value := range DOUBLE_VALUES {
-               if e := p.WriteDouble(value); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error: %s", thetype, value, e.Error())
-               }
-       }
-       p.WriteListEnd()
-       if e := p.Flush(context.Background()); e != nil {
-               t.Fatalf("Unable to write %s due to error flushing: %s", thetype, e.Error())
-       }
-       str := trans.String()
-       str1 := new([]interface{})
-       err := json.Unmarshal([]byte(str), str1)
-       if err != nil {
-               t.Fatalf("Unable to decode %s, wrote: %s", thetype, str)
-       }
-       l := *str1
-       if len(l) < 2 {
-               t.Fatalf("List must be at least of length two to include metadata")
-       }
-       if l[0] != "dbl" {
-               t.Fatal("Invalid type for list, expected: ", STRING, ", but was: ", l[0])
-       }
-       if int(l[1].(float64)) != len(DOUBLE_VALUES) {
-               t.Fatal("Invalid length for list, expected: ", len(DOUBLE_VALUES), ", but was: ", l[1])
-       }
-       for k, value := range DOUBLE_VALUES {
-               s := l[k+2]
-               if math.IsInf(value, 1) {
-                       if s.(string) != JSON_INFINITY {
-                               t.Fatalf("Bad value for %s at index %v %v, wrote: %q, expected: %q, originally wrote: %q", thetype, k, value, s, jsonQuote(JSON_INFINITY), str)
-                       }
-               } else if math.IsInf(value, 0) {
-                       if s.(string) != JSON_NEGATIVE_INFINITY {
-                               t.Fatalf("Bad value for %s at index %v %v, wrote: %q, expected: %q, originally wrote: %q", thetype, k, value, s, jsonQuote(JSON_NEGATIVE_INFINITY), str)
-                       }
-               } else if math.IsNaN(value) {
-                       if s.(string) != JSON_NAN {
-                               t.Fatalf("Bad value for %s at index %v  %v, wrote: %q, expected: %q, originally wrote: %q", thetype, k, value, s, jsonQuote(JSON_NAN), str)
-                       }
-               } else {
-                       if s.(float64) != value {
-                               t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s'", thetype, value, s)
-                       }
-               }
-               trans.Reset()
-       }
-       trans.Close()
-}
-
-func TestWriteJSONProtocolSet(t *testing.T) {
-       thetype := "set"
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       p.WriteSetBegin(TType(DOUBLE), len(DOUBLE_VALUES))
-       for _, value := range DOUBLE_VALUES {
-               if e := p.WriteDouble(value); e != nil {
-                       t.Fatalf("Unable to write %s value %v due to error: %s", thetype, value, e.Error())
-               }
-       }
-       p.WriteSetEnd()
-       if e := p.Flush(context.Background()); e != nil {
-               t.Fatalf("Unable to write %s due to error flushing: %s", thetype, e.Error())
-       }
-       str := trans.String()
-       str1 := new([]interface{})
-       err := json.Unmarshal([]byte(str), str1)
-       if err != nil {
-               t.Fatalf("Unable to decode %s, wrote: %s", thetype, str)
-       }
-       l := *str1
-       if len(l) < 2 {
-               t.Fatalf("Set must be at least of length two to include metadata")
-       }
-       if l[0] != "dbl" {
-               t.Fatal("Invalid type for set, expected: ", DOUBLE, ", but was: ", l[0])
-       }
-       if int(l[1].(float64)) != len(DOUBLE_VALUES) {
-               t.Fatal("Invalid length for set, expected: ", len(DOUBLE_VALUES), ", but was: ", l[1])
-       }
-       for k, value := range DOUBLE_VALUES {
-               s := l[k+2]
-               if math.IsInf(value, 1) {
-                       if s.(string) != JSON_INFINITY {
-                               t.Fatalf("Bad value for %s at index %v %v, wrote: %q, expected: %q, originally wrote: %q", thetype, k, value, s, jsonQuote(JSON_INFINITY), str)
-                       }
-               } else if math.IsInf(value, 0) {
-                       if s.(string) != JSON_NEGATIVE_INFINITY {
-                               t.Fatalf("Bad value for %s at index %v %v, wrote: %q, expected: %q, originally wrote: %q", thetype, k, value, s, jsonQuote(JSON_NEGATIVE_INFINITY), str)
-                       }
-               } else if math.IsNaN(value) {
-                       if s.(string) != JSON_NAN {
-                               t.Fatalf("Bad value for %s at index %v  %v, wrote: %q, expected: %q, originally wrote: %q", thetype, k, value, s, jsonQuote(JSON_NAN), str)
-                       }
-               } else {
-                       if s.(float64) != value {
-                               t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s'", thetype, value, s)
-                       }
-               }
-               trans.Reset()
-       }
-       trans.Close()
-}
-
-func TestWriteJSONProtocolMap(t *testing.T) {
-       thetype := "map"
-       trans := NewTMemoryBuffer()
-       p := NewTJSONProtocol(trans)
-       p.WriteMapBegin(TType(I32), TType(DOUBLE), len(DOUBLE_VALUES))
-       for k, value := range DOUBLE_VALUES {
-               if e := p.WriteI32(int32(k)); e != nil {
-                       t.Fatalf("Unable to write %s key int32 value %v due to error: %s", thetype, k, e.Error())
-               }
-               if e := p.WriteDouble(value); e != nil {
-                       t.Fatalf("Unable to write %s value float64 value %v due to error: %s", thetype, value, e.Error())
-               }
-       }
-       p.WriteMapEnd()
-       if e := p.Flush(context.Background()); e != nil {
-               t.Fatalf("Unable to write %s due to error flushing: %s", thetype, e.Error())
-       }
-       str := trans.String()
-       if str[0] != '[' || str[len(str)-1] != ']' {
-               t.Fatalf("Bad value for %s, wrote: %v, in go: %v", thetype, str, DOUBLE_VALUES)
-       }
-       expectedKeyType, expectedValueType, expectedSize, err := p.ReadMapBegin()
-       if err != nil {
-               t.Fatalf("Error while reading map begin: %s", err.Error())
-       }
-       if expectedKeyType != I32 {
-               t.Fatal("Expected map key type ", I32, ", but was ", expectedKeyType)
-       }
-       if expectedValueType != DOUBLE {
-               t.Fatal("Expected map value type ", DOUBLE, ", but was ", expectedValueType)
-       }
-       if expectedSize != len(DOUBLE_VALUES) {
-               t.Fatal("Expected map size of ", len(DOUBLE_VALUES), ", but was ", expectedSize)
-       }
-       for k, value := range DOUBLE_VALUES {
-               ik, err := p.ReadI32()
-               if err != nil {
-                       t.Fatalf("Bad key for %s index %v, wrote: %v, expected: %v, error: %s", thetype, k, ik, string(k), err.Error())
-               }
-               if int(ik) != k {
-                       t.Fatalf("Bad key for %s index %v, wrote: %v, expected: %v", thetype, k, ik, k)
-               }
-               dv, err := p.ReadDouble()
-               if err != nil {
-                       t.Fatalf("Bad value for %s index %v, wrote: %v, expected: %v, error: %s", thetype, k, dv, value, err.Error())
-               }
-               s := strconv.FormatFloat(dv, 'g', 10, 64)
-               if math.IsInf(value, 1) {
-                       if !math.IsInf(dv, 1) {
-                               t.Fatalf("Bad value for %s at index %v %v, wrote: %v, expected: %v", thetype, k, value, s, jsonQuote(JSON_INFINITY))
-                       }
-               } else if math.IsInf(value, 0) {
-                       if !math.IsInf(dv, 0) {
-                               t.Fatalf("Bad value for %s at index %v %v, wrote: %v, expected: %v", thetype, k, value, s, jsonQuote(JSON_NEGATIVE_INFINITY))
-                       }
-               } else if math.IsNaN(value) {
-                       if !math.IsNaN(dv) {
-                               t.Fatalf("Bad value for %s at index %v  %v, wrote: %v, expected: %v", thetype, k, value, s, jsonQuote(JSON_NAN))
-                       }
-               } else {
-                       expected := strconv.FormatFloat(value, 'g', 10, 64)
-                       if s != expected {
-                               t.Fatalf("Bad value for %s at index %v %v, wrote: %v, expected %v", thetype, k, value, s, expected)
-                       }
-                       v := float64(0)
-                       if err := json.Unmarshal([]byte(s), &v); err != nil || v != value {
-                               t.Fatalf("Bad json-decoded value for %s %v, wrote: '%s', expected: '%v'", thetype, value, s, v)
-                       }
-               }
-       }
-       err = p.ReadMapEnd()
-       if err != nil {
-               t.Fatalf("Error while reading map end: %s", err.Error())
-       }
-       trans.Close()
-}