Files
tidb/pkg/util/codec/bytes_test.go

121 lines
4.1 KiB
Go

// Copyright 2015 PingCAP, Inc.
//
// 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
//
// 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 codec
import (
"testing"
"github.com/stretchr/testify/require"
)
func TestFastSlowFastReverse(t *testing.T) {
if !supportsUnaligned {
return
}
b := []byte{1, 2, 3, 4, 5, 6, 7, 8, 255, 0, 0, 0, 0, 0, 0, 0, 0, 247}
r1 := b
fastReverseBytes(b)
r2 := b
reverseBytes(r2)
require.Equal(t, r1, r2)
}
func TestBytesCodec(t *testing.T) {
inputs := []struct {
enc []byte
dec []byte
desc bool
}{
{[]byte{}, []byte{0, 0, 0, 0, 0, 0, 0, 0, 247}, false},
{[]byte{}, []byte{255, 255, 255, 255, 255, 255, 255, 255, 8}, true},
{[]byte{0}, []byte{0, 0, 0, 0, 0, 0, 0, 0, 248}, false},
{[]byte{0}, []byte{255, 255, 255, 255, 255, 255, 255, 255, 7}, true},
{[]byte{1, 2, 3}, []byte{1, 2, 3, 0, 0, 0, 0, 0, 250}, false},
{[]byte{1, 2, 3}, []byte{254, 253, 252, 255, 255, 255, 255, 255, 5}, true},
{[]byte{1, 2, 3, 0}, []byte{1, 2, 3, 0, 0, 0, 0, 0, 251}, false},
{[]byte{1, 2, 3, 0}, []byte{254, 253, 252, 255, 255, 255, 255, 255, 4}, true},
{[]byte{1, 2, 3, 4, 5, 6, 7}, []byte{1, 2, 3, 4, 5, 6, 7, 0, 254}, false},
{[]byte{1, 2, 3, 4, 5, 6, 7}, []byte{254, 253, 252, 251, 250, 249, 248, 255, 1}, true},
{[]byte{0, 0, 0, 0, 0, 0, 0, 0}, []byte{0, 0, 0, 0, 0, 0, 0, 0, 255, 0, 0, 0, 0, 0, 0, 0, 0, 247}, false},
{[]byte{0, 0, 0, 0, 0, 0, 0, 0}, []byte{255, 255, 255, 255, 255, 255, 255, 255, 0, 255, 255, 255, 255, 255, 255, 255, 255, 8}, true},
{[]byte{1, 2, 3, 4, 5, 6, 7, 8}, []byte{1, 2, 3, 4, 5, 6, 7, 8, 255, 0, 0, 0, 0, 0, 0, 0, 0, 247}, false},
{[]byte{1, 2, 3, 4, 5, 6, 7, 8}, []byte{254, 253, 252, 251, 250, 249, 248, 247, 0, 255, 255, 255, 255, 255, 255, 255, 255, 8}, true},
{[]byte{1, 2, 3, 4, 5, 6, 7, 8, 9}, []byte{1, 2, 3, 4, 5, 6, 7, 8, 255, 9, 0, 0, 0, 0, 0, 0, 0, 248}, false},
{[]byte{1, 2, 3, 4, 5, 6, 7, 8, 9}, []byte{254, 253, 252, 251, 250, 249, 248, 247, 0, 246, 255, 255, 255, 255, 255, 255, 255, 7}, true},
}
for _, input := range inputs {
require.Len(t, input.dec, EncodedBytesLength(len(input.enc)))
if input.desc {
b := EncodeBytesDesc(nil, input.enc)
require.Equal(t, input.dec, b)
_, d, err := DecodeBytesDesc(b, nil)
require.NoError(t, err)
require.Equal(t, input.enc, d)
} else {
b := EncodeBytes(nil, input.enc)
require.Equal(t, input.dec, b)
_, d, err := DecodeBytes(b, nil)
require.NoError(t, err)
require.Equal(t, input.enc, d)
}
}
// Test error decode.
errInputs := [][]byte{
{1, 2, 3, 4},
{0, 0, 0, 0, 0, 0, 0, 247},
{0, 0, 0, 0, 0, 0, 0, 0, 246},
{0, 0, 0, 0, 0, 0, 0, 1, 247},
{1, 2, 3, 4, 5, 6, 7, 8, 0},
{1, 2, 3, 4, 5, 6, 7, 8, 255, 1},
{1, 2, 3, 4, 5, 6, 7, 8, 255, 1, 2, 3, 4, 5, 6, 7, 8},
{1, 2, 3, 4, 5, 6, 7, 8, 255, 1, 2, 3, 4, 5, 6, 7, 8, 255},
{1, 2, 3, 4, 5, 6, 7, 8, 255, 1, 2, 3, 4, 5, 6, 7, 8, 0},
}
for _, input := range errInputs {
_, _, err := DecodeBytes(input, nil)
require.Error(t, err)
}
}
func TestBytesCodecExt(t *testing.T) {
inputs := []struct {
enc []byte
dec []byte
}{
{[]byte{}, []byte{0, 0, 0, 0, 0, 0, 0, 0, 247}},
{[]byte{1, 2, 3}, []byte{1, 2, 3, 0, 0, 0, 0, 0, 250}},
{[]byte{1, 2, 3, 4, 5, 6, 7, 8, 9}, []byte{1, 2, 3, 4, 5, 6, 7, 8, 255, 9, 0, 0, 0, 0, 0, 0, 0, 248}},
}
// `assertEqual` is to deal with test case for `[]byte{}` & `[]byte(nil)`.
assertEqual := func(expected []byte, acutal []byte) {
require.Equal(t, len(expected), len(acutal))
for i := range expected {
require.Equal(t, expected[i], acutal[i])
}
}
for _, input := range inputs {
assertEqual(input.enc, EncodeBytesExt(nil, input.enc, true))
assertEqual(input.dec, EncodeBytesExt(nil, input.enc, false))
}
}