| /* |
| * 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 ( |
| "bytes" |
| "context" |
| "io" |
| "math" |
| "net" |
| "net/http" |
| "testing" |
| ) |
| |
| const PROTOCOL_BINARY_DATA_SIZE = 155 |
| |
| var ( |
| protocol_bdata []byte // test data for writing; same as data |
| BOOL_VALUES []bool |
| BYTE_VALUES []int8 |
| INT16_VALUES []int16 |
| INT32_VALUES []int32 |
| INT64_VALUES []int64 |
| DOUBLE_VALUES []float64 |
| STRING_VALUES []string |
| UUID_VALUES []Tuuid |
| ) |
| |
| func init() { |
| protocol_bdata = make([]byte, PROTOCOL_BINARY_DATA_SIZE) |
| for i := range PROTOCOL_BINARY_DATA_SIZE { |
| protocol_bdata[i] = byte((i + 'a') % 255) |
| } |
| BOOL_VALUES = []bool{false, true, false, false, true} |
| BYTE_VALUES = []int8{117, 0, 1, 32, 127, -128, -1} |
| INT16_VALUES = []int16{459, 0, 1, -1, -128, 127, 32767, -32768} |
| INT32_VALUES = []int32{459, 0, 1, -1, -128, 127, 32767, 2147483647, -2147483535} |
| INT64_VALUES = []int64{459, 0, 1, -1, -128, 127, 32767, 2147483647, -2147483535, 34359738481, -35184372088719, -9223372036854775808, 9223372036854775807} |
| DOUBLE_VALUES = []float64{459.3, 0.0, -1.0, 1.0, 0.5, 0.3333, 3.14159, 1.537e-38, 1.673e25, 6.02214179e23, -6.02214179e23, INFINITY.Float64(), NEGATIVE_INFINITY.Float64(), NAN.Float64()} |
| STRING_VALUES = []string{"", "a", "st[uf]f", "st,u:ff with spaces", "stuff\twith\nescape\\characters'...\"lots{of}fun</xml>"} |
| UUID_VALUES = []Tuuid{ |
| {}, |
| Must(ParseTuuid("6ba7b810-9dad-11d1-80b4-00c04fd430c8")), |
| Must(ParseTuuid("6ba7b811-9dad-11d1-80b4-00c04fd430c8")), |
| Must(ParseTuuid("6ba7b812-9dad-11d1-80b4-00c04fd430c8")), |
| Must(ParseTuuid("6ba7b814-9dad-11d1-80b4-00c04fd430c8")), |
| } |
| } |
| |
| type HTTPEchoServer struct{} |
| type HTTPHeaderEchoServer struct{} |
| |
| func (p *HTTPEchoServer) ServeHTTP(w http.ResponseWriter, req *http.Request) { |
| buf, err := io.ReadAll(req.Body) |
| if err != nil { |
| w.WriteHeader(http.StatusBadRequest) |
| w.Write(buf) |
| } else { |
| w.WriteHeader(http.StatusOK) |
| w.Write(buf) |
| } |
| } |
| |
| func (p *HTTPHeaderEchoServer) ServeHTTP(w http.ResponseWriter, req *http.Request) { |
| buf, err := io.ReadAll(req.Body) |
| if err != nil { |
| w.WriteHeader(http.StatusBadRequest) |
| w.Write(buf) |
| } else { |
| w.WriteHeader(http.StatusOK) |
| w.Write(buf) |
| } |
| } |
| |
| func HttpClientSetupForTest(t *testing.T) (net.Listener, net.Addr) { |
| addr, err := FindAvailableTCPServerPort(40000) |
| if err != nil { |
| t.Fatalf("Unable to find available tcp port addr: %s", err) |
| return nil, addr |
| } |
| l, err := net.Listen(addr.Network(), addr.String()) |
| if err != nil { |
| t.Fatalf("Unable to setup tcp listener on %s: %s", addr.String(), err) |
| return l, addr |
| } |
| go http.Serve(l, &HTTPEchoServer{}) |
| return l, addr |
| } |
| |
| func HttpClientSetupForHeaderTest(t *testing.T) (net.Listener, net.Addr) { |
| addr, err := FindAvailableTCPServerPort(40000) |
| if err != nil { |
| t.Fatalf("Unable to find available tcp port addr: %s", err) |
| return nil, addr |
| } |
| l, err := net.Listen(addr.Network(), addr.String()) |
| if err != nil { |
| t.Fatalf("Unable to setup tcp listener on %s: %s", addr.String(), err) |
| return l, addr |
| } |
| go http.Serve(l, &HTTPHeaderEchoServer{}) |
| return l, addr |
| } |
| |
| func ReadWriteProtocolTest(t *testing.T, protocolFactory TProtocolFactory) { |
| buf := bytes.NewBuffer(make([]byte, 0, 1024)) |
| l, addr := HttpClientSetupForTest(t) |
| defer l.Close() |
| transports := []TTransportFactory{ |
| NewTMemoryBufferTransportFactory(1024), |
| NewStreamTransportFactory(buf, buf, true), |
| NewTFramedTransportFactory(NewTMemoryBufferTransportFactory(1024)), |
| NewTZlibTransportFactoryWithFactory(0, NewTMemoryBufferTransportFactory(1024)), |
| NewTZlibTransportFactoryWithFactory(6, NewTMemoryBufferTransportFactory(1024)), |
| NewTZlibTransportFactoryWithFactory(9, NewTFramedTransportFactory(NewTMemoryBufferTransportFactory(1024))), |
| NewTHttpPostClientTransportFactory("http://" + addr.String()), |
| } |
| for _, tf := range transports { |
| trans, err := tf.GetTransport(nil) |
| if err != nil { |
| t.Error(err) |
| continue |
| } |
| p := protocolFactory.GetProtocol(trans) |
| ReadWriteBool(t, p, trans) |
| trans.Close() |
| } |
| for _, tf := range transports { |
| trans, err := tf.GetTransport(nil) |
| if err != nil { |
| t.Error(err) |
| continue |
| } |
| p := protocolFactory.GetProtocol(trans) |
| ReadWriteByte(t, p, trans) |
| trans.Close() |
| } |
| for _, tf := range transports { |
| trans, err := tf.GetTransport(nil) |
| if err != nil { |
| t.Error(err) |
| continue |
| } |
| p := protocolFactory.GetProtocol(trans) |
| ReadWriteI16(t, p, trans) |
| trans.Close() |
| } |
| for _, tf := range transports { |
| trans, err := tf.GetTransport(nil) |
| if err != nil { |
| t.Error(err) |
| continue |
| } |
| p := protocolFactory.GetProtocol(trans) |
| ReadWriteI32(t, p, trans) |
| trans.Close() |
| } |
| for _, tf := range transports { |
| trans, err := tf.GetTransport(nil) |
| if err != nil { |
| t.Error(err) |
| continue |
| } |
| p := protocolFactory.GetProtocol(trans) |
| ReadWriteI64(t, p, trans) |
| trans.Close() |
| } |
| for _, tf := range transports { |
| trans, err := tf.GetTransport(nil) |
| if err != nil { |
| t.Error(err) |
| continue |
| } |
| p := protocolFactory.GetProtocol(trans) |
| ReadWriteDouble(t, p, trans) |
| trans.Close() |
| } |
| for _, tf := range transports { |
| trans, err := tf.GetTransport(nil) |
| if err != nil { |
| t.Error(err) |
| continue |
| } |
| p := protocolFactory.GetProtocol(trans) |
| ReadWriteString(t, p, trans) |
| trans.Close() |
| } |
| for _, tf := range transports { |
| trans, err := tf.GetTransport(nil) |
| if err != nil { |
| t.Error(err) |
| continue |
| } |
| p := protocolFactory.GetProtocol(trans) |
| ReadWriteBinary(t, p, trans) |
| trans.Close() |
| } |
| for _, tf := range transports { |
| trans, err := tf.GetTransport(nil) |
| if err != nil { |
| t.Error(err) |
| continue |
| } |
| p := protocolFactory.GetProtocol(trans) |
| ReadWriteUUID(t, p, trans) |
| trans.Close() |
| } |
| for _, tf := range transports { |
| trans, err := tf.GetTransport(nil) |
| if err != nil { |
| t.Error(err) |
| continue |
| } |
| p := protocolFactory.GetProtocol(trans) |
| ReadWriteI64(t, p, trans) |
| ReadWriteDouble(t, p, trans) |
| ReadWriteBinary(t, p, trans) |
| ReadWriteByte(t, p, trans) |
| ReadWriteUUID(t, p, trans) |
| trans.Close() |
| } |
| |
| t.Run("UnmatchedBeginEnd", func(t *testing.T) { |
| UnmatchedBeginEndProtocolTest(t, protocolFactory) |
| }) |
| } |
| |
| func ReadWriteBool(t testing.TB, p TProtocol, trans TTransport) { |
| thetype := TType(BOOL) |
| thelen := len(BOOL_VALUES) |
| err := p.WriteListBegin(context.Background(), thetype, thelen) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error writing list begin: %q", "ReadWriteBool", p, trans, err, thetype) |
| } |
| for k, v := range BOOL_VALUES { |
| err = p.WriteBool(context.Background(), v) |
| if err != nil { |
| t.Errorf("%s: %T %T %v Error writing bool in list at index %v: %v", "ReadWriteBool", p, trans, err, k, v) |
| } |
| } |
| p.WriteListEnd(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %v Error writing list end: %v", "ReadWriteBool", p, trans, err, BOOL_VALUES) |
| } |
| p.Flush(context.Background()) |
| thetype2, thelen2, err := p.ReadListBegin(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %v Error reading list: %v", "ReadWriteBool", p, trans, err, BOOL_VALUES) |
| } |
| _, ok := p.(*TSimpleJSONProtocol) |
| if !ok { |
| if thetype != thetype2 { |
| t.Errorf("%s: %T %T type %s != type %s", "ReadWriteBool", p, trans, thetype, thetype2) |
| } |
| if thelen != thelen2 { |
| t.Errorf("%s: %T %T len %v != len %v", "ReadWriteBool", p, trans, thelen, thelen2) |
| } |
| } |
| for k, v := range BOOL_VALUES { |
| value, err := p.ReadBool(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %v Error reading bool at index %v: %v", "ReadWriteBool", p, trans, err, k, v) |
| } |
| if v != value { |
| t.Errorf("%s: index %v %v %v %v != %v", "ReadWriteBool", k, p, trans, v, value) |
| } |
| } |
| err = p.ReadListEnd(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T Unable to read list end: %q", "ReadWriteBool", p, trans, err) |
| } |
| } |
| |
| func ReadWriteByte(t testing.TB, p TProtocol, trans TTransport) { |
| thetype := TType(BYTE) |
| thelen := len(BYTE_VALUES) |
| err := p.WriteListBegin(context.Background(), thetype, thelen) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error writing list begin: %q", "ReadWriteByte", p, trans, err, thetype) |
| } |
| for k, v := range BYTE_VALUES { |
| err = p.WriteByte(context.Background(), v) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error writing byte in list at index %d: %q", "ReadWriteByte", p, trans, err, k, v) |
| } |
| } |
| err = p.WriteListEnd(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error writing list end: %q", "ReadWriteByte", p, trans, err, BYTE_VALUES) |
| } |
| err = p.Flush(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error flushing list of bytes: %q", "ReadWriteByte", p, trans, err, BYTE_VALUES) |
| } |
| thetype2, thelen2, err := p.ReadListBegin(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading list: %q", "ReadWriteByte", p, trans, err, BYTE_VALUES) |
| } |
| _, ok := p.(*TSimpleJSONProtocol) |
| if !ok { |
| if thetype != thetype2 { |
| t.Errorf("%s: %T %T type %s != type %s", "ReadWriteByte", p, trans, thetype, thetype2) |
| } |
| if thelen != thelen2 { |
| t.Errorf("%s: %T %T len %v != len %v", "ReadWriteByte", p, trans, thelen, thelen2) |
| } |
| } |
| for k, v := range BYTE_VALUES { |
| value, err := p.ReadByte(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading byte at index %d: %q", "ReadWriteByte", p, trans, err, k, v) |
| } |
| if v != value { |
| t.Errorf("%s: %T %T %d != %d", "ReadWriteByte", p, trans, v, value) |
| } |
| } |
| err = p.ReadListEnd(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T Unable to read list end: %q", "ReadWriteByte", p, trans, err) |
| } |
| } |
| |
| func ReadWriteI16(t testing.TB, p TProtocol, trans TTransport) { |
| thetype := TType(I16) |
| thelen := len(INT16_VALUES) |
| p.WriteListBegin(context.Background(), thetype, thelen) |
| for _, v := range INT16_VALUES { |
| p.WriteI16(context.Background(), v) |
| } |
| p.WriteListEnd(context.Background()) |
| p.Flush(context.Background()) |
| thetype2, thelen2, err := p.ReadListBegin(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading list: %q", "ReadWriteI16", p, trans, err, INT16_VALUES) |
| } |
| _, ok := p.(*TSimpleJSONProtocol) |
| if !ok { |
| if thetype != thetype2 { |
| t.Errorf("%s: %T %T type %s != type %s", "ReadWriteI16", p, trans, thetype, thetype2) |
| } |
| if thelen != thelen2 { |
| t.Errorf("%s: %T %T len %v != len %v", "ReadWriteI16", p, trans, thelen, thelen2) |
| } |
| } |
| for k, v := range INT16_VALUES { |
| value, err := p.ReadI16(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading int16 at index %d: %q", "ReadWriteI16", p, trans, err, k, v) |
| } |
| if v != value { |
| t.Errorf("%s: %T %T %d != %d", "ReadWriteI16", p, trans, v, value) |
| } |
| } |
| err = p.ReadListEnd(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T Unable to read list end: %q", "ReadWriteI16", p, trans, err) |
| } |
| } |
| |
| func ReadWriteI32(t testing.TB, p TProtocol, trans TTransport) { |
| thetype := TType(I32) |
| thelen := len(INT32_VALUES) |
| p.WriteListBegin(context.Background(), thetype, thelen) |
| for _, v := range INT32_VALUES { |
| p.WriteI32(context.Background(), v) |
| } |
| p.WriteListEnd(context.Background()) |
| p.Flush(context.Background()) |
| thetype2, thelen2, err := p.ReadListBegin(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading list: %q", "ReadWriteI32", p, trans, err, INT32_VALUES) |
| } |
| _, ok := p.(*TSimpleJSONProtocol) |
| if !ok { |
| if thetype != thetype2 { |
| t.Errorf("%s: %T %T type %s != type %s", "ReadWriteI32", p, trans, thetype, thetype2) |
| } |
| if thelen != thelen2 { |
| t.Errorf("%s: %T %T len %v != len %v", "ReadWriteI32", p, trans, thelen, thelen2) |
| } |
| } |
| for k, v := range INT32_VALUES { |
| value, err := p.ReadI32(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading int32 at index %d: %q", "ReadWriteI32", p, trans, err, k, v) |
| } |
| if v != value { |
| t.Errorf("%s: %T %T %d != %d", "ReadWriteI32", p, trans, v, value) |
| } |
| } |
| if err != nil { |
| t.Errorf("%s: %T %T Unable to read list end: %q", "ReadWriteI32", p, trans, err) |
| } |
| } |
| |
| func ReadWriteI64(t testing.TB, p TProtocol, trans TTransport) { |
| thetype := TType(I64) |
| thelen := len(INT64_VALUES) |
| p.WriteListBegin(context.Background(), thetype, thelen) |
| for _, v := range INT64_VALUES { |
| p.WriteI64(context.Background(), v) |
| } |
| p.WriteListEnd(context.Background()) |
| p.Flush(context.Background()) |
| thetype2, thelen2, err := p.ReadListBegin(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading list: %q", "ReadWriteI64", p, trans, err, INT64_VALUES) |
| } |
| _, ok := p.(*TSimpleJSONProtocol) |
| if !ok { |
| if thetype != thetype2 { |
| t.Errorf("%s: %T %T type %s != type %s", "ReadWriteI64", p, trans, thetype, thetype2) |
| } |
| if thelen != thelen2 { |
| t.Errorf("%s: %T %T len %v != len %v", "ReadWriteI64", p, trans, thelen, thelen2) |
| } |
| } |
| for k, v := range INT64_VALUES { |
| value, err := p.ReadI64(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading int64 at index %d: %q", "ReadWriteI64", p, trans, err, k, v) |
| } |
| if v != value { |
| t.Errorf("%s: %T %T %q != %q", "ReadWriteI64", p, trans, v, value) |
| } |
| } |
| if err != nil { |
| t.Errorf("%s: %T %T Unable to read list end: %q", "ReadWriteI64", p, trans, err) |
| } |
| } |
| |
| func ReadWriteDouble(t testing.TB, p TProtocol, trans TTransport) { |
| thetype := TType(DOUBLE) |
| thelen := len(DOUBLE_VALUES) |
| p.WriteListBegin(context.Background(), thetype, thelen) |
| for _, v := range DOUBLE_VALUES { |
| p.WriteDouble(context.Background(), v) |
| } |
| p.WriteListEnd(context.Background()) |
| p.Flush(context.Background()) |
| thetype2, thelen2, err := p.ReadListBegin(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %v Error reading list: %v", "ReadWriteDouble", p, trans, err, DOUBLE_VALUES) |
| } |
| if thetype != thetype2 { |
| t.Errorf("%s: %T %T type %s != type %s", "ReadWriteDouble", p, trans, thetype, thetype2) |
| } |
| if thelen != thelen2 { |
| t.Errorf("%s: %T %T len %v != len %v", "ReadWriteDouble", p, trans, thelen, thelen2) |
| } |
| for k, v := range DOUBLE_VALUES { |
| value, err := p.ReadDouble(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading double at index %d: %v", "ReadWriteDouble", p, trans, err, k, v) |
| } |
| if math.IsNaN(v) { |
| if !math.IsNaN(value) { |
| t.Errorf("%s: %T %T math.IsNaN(%v) != math.IsNaN(%v)", "ReadWriteDouble", p, trans, v, value) |
| } |
| } else if v != value { |
| t.Errorf("%s: %T %T %v != %v", "ReadWriteDouble", p, trans, v, value) |
| } |
| } |
| err = p.ReadListEnd(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T Unable to read list end: %q", "ReadWriteDouble", p, trans, err) |
| } |
| } |
| |
| func ReadWriteString(t testing.TB, p TProtocol, trans TTransport) { |
| thetype := TType(STRING) |
| thelen := len(STRING_VALUES) |
| p.WriteListBegin(context.Background(), thetype, thelen) |
| for _, v := range STRING_VALUES { |
| p.WriteString(context.Background(), v) |
| } |
| p.WriteListEnd(context.Background()) |
| p.Flush(context.Background()) |
| thetype2, thelen2, err := p.ReadListBegin(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading list: %q", "ReadWriteString", p, trans, err, STRING_VALUES) |
| } |
| _, ok := p.(*TSimpleJSONProtocol) |
| if !ok { |
| if thetype != thetype2 { |
| t.Errorf("%s: %T %T type %s != type %s", "ReadWriteString", p, trans, thetype, thetype2) |
| } |
| if thelen != thelen2 { |
| t.Errorf("%s: %T %T len %v != len %v", "ReadWriteString", p, trans, thelen, thelen2) |
| } |
| } |
| for k, v := range STRING_VALUES { |
| value, err := p.ReadString(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading string at index %d: %q", "ReadWriteString", p, trans, err, k, v) |
| } |
| if v != value { |
| t.Errorf("%s: %T %T %v != %v", "ReadWriteString", p, trans, v, value) |
| } |
| } |
| if err != nil { |
| t.Errorf("%s: %T %T Unable to read list end: %q", "ReadWriteString", p, trans, err) |
| } |
| } |
| |
| func ReadWriteBinary(t testing.TB, p TProtocol, trans TTransport) { |
| v := protocol_bdata |
| p.WriteBinary(context.Background(), v) |
| p.Flush(context.Background()) |
| value, err := p.ReadBinary(context.Background()) |
| if err != nil { |
| t.Errorf("%s: %T %T Unable to read binary: %s", "ReadWriteBinary", p, trans, err.Error()) |
| } |
| if len(v) != len(value) { |
| t.Errorf("%s: %T %T len(v) != len(value)... %d != %d", "ReadWriteBinary", p, trans, len(v), len(value)) |
| } else { |
| for i := range v { |
| if v[i] != value[i] { |
| t.Errorf("%s: %T %T %s != %s", "ReadWriteBinary", p, trans, v, value) |
| } |
| } |
| } |
| } |
| |
| func ReadWriteUUID(t testing.TB, p TProtocol, trans TTransport) { |
| ctx := context.Background() |
| thetype := TType(UUID) |
| thelen := len(UUID_VALUES) |
| p.WriteListBegin(ctx, thetype, thelen) |
| for _, v := range UUID_VALUES { |
| p.WriteUUID(ctx, v) |
| } |
| p.WriteListEnd(ctx) |
| p.Flush(ctx) |
| thetype2, thelen2, err := p.ReadListBegin(ctx) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading list: %q", "ReadWriteUUID", p, trans, err, STRING_VALUES) |
| } |
| _, ok := p.(*TSimpleJSONProtocol) |
| if !ok { |
| if thetype != thetype2 { |
| t.Errorf("%s: %T %T type %s != type %s", "ReadWriteUUID", p, trans, thetype, thetype2) |
| } |
| if thelen != thelen2 { |
| t.Errorf("%s: %T %T len %v != len %v", "ReadWriteUUID", p, trans, thelen, thelen2) |
| } |
| } |
| for k, v := range UUID_VALUES { |
| value, err := p.ReadUUID(ctx) |
| if err != nil { |
| t.Errorf("%s: %T %T %q Error reading UUID at index %d: %q", "ReadWriteUUID", p, trans, err, k, v) |
| } |
| if v != value { |
| t.Errorf("%s: %T %T %v != %v", "ReadWriteUUID", p, trans, v, value) |
| } |
| } |
| if err != nil { |
| t.Errorf("%s: %T %T Unable to read list end: %q", "ReadWriteUUID", p, trans, err) |
| } |
| } |
| |
| func UnmatchedBeginEndProtocolTest(t *testing.T, protocolFactory TProtocolFactory) { |
| // NOTE: not all protocol implementations do strict state check to |
| // return an error on unmatched Begin/End calls. |
| // This test is only meant to make sure that those unmatched Begin/End |
| // calls won't cause panic. There's no real "test" here. |
| trans := NewTMemoryBuffer() |
| t.Run("Read", func(t *testing.T) { |
| t.Run("Message", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.ReadMessageEnd(context.Background()) |
| p.ReadMessageEnd(context.Background()) |
| }) |
| t.Run("Struct", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.ReadStructEnd(context.Background()) |
| p.ReadStructEnd(context.Background()) |
| }) |
| t.Run("Field", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.ReadFieldEnd(context.Background()) |
| p.ReadFieldEnd(context.Background()) |
| }) |
| t.Run("Map", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.ReadMapEnd(context.Background()) |
| p.ReadMapEnd(context.Background()) |
| }) |
| t.Run("List", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.ReadListEnd(context.Background()) |
| p.ReadListEnd(context.Background()) |
| }) |
| t.Run("Set", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.ReadSetEnd(context.Background()) |
| p.ReadSetEnd(context.Background()) |
| }) |
| }) |
| t.Run("Write", func(t *testing.T) { |
| t.Run("Message", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.WriteMessageEnd(context.Background()) |
| p.WriteMessageEnd(context.Background()) |
| }) |
| t.Run("Struct", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.WriteStructEnd(context.Background()) |
| p.WriteStructEnd(context.Background()) |
| }) |
| t.Run("Field", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.WriteFieldEnd(context.Background()) |
| p.WriteFieldEnd(context.Background()) |
| }) |
| t.Run("Map", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.WriteMapEnd(context.Background()) |
| p.WriteMapEnd(context.Background()) |
| }) |
| t.Run("List", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.WriteListEnd(context.Background()) |
| p.WriteListEnd(context.Background()) |
| }) |
| t.Run("Set", func(t *testing.T) { |
| trans.Reset() |
| p := protocolFactory.GetProtocol(trans) |
| p.WriteSetEnd(context.Background()) |
| p.WriteSetEnd(context.Background()) |
| }) |
| }) |
| trans.Close() |
| } |