mirror of
https://github.com/gogrlx/nats-server.git
synced 2026-04-02 11:48:43 -07:00
Allow a buffer to be passed in to relive GC pressure. Signed-off-by: Derek Collison <derek@nats.io>
93 lines
2.2 KiB
Go
93 lines
2.2 KiB
Go
// Copyright 2021 The NATS Authors
|
|
// 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 server
|
|
|
|
import (
|
|
"math"
|
|
"math/rand"
|
|
"testing"
|
|
)
|
|
|
|
func TestNRGAppendEntryEncode(t *testing.T) {
|
|
ae := &appendEntry{
|
|
term: 1,
|
|
pindex: 0,
|
|
}
|
|
|
|
// Test leader should be _EMPTY_ or exactly idLen long
|
|
ae.leader = "foo_bar_baz"
|
|
_, err := ae.encode(nil)
|
|
require_Error(t, err, errLeaderLen)
|
|
|
|
// Empty ok (noLeader)
|
|
ae.leader = noLeader // _EMPTY_
|
|
_, err = ae.encode(nil)
|
|
require_NoError(t, err)
|
|
|
|
ae.leader = "DEREK123"
|
|
_, err = ae.encode(nil)
|
|
require_NoError(t, err)
|
|
|
|
// Buffer reuse
|
|
var rawSmall [32]byte
|
|
var rawBigger [64]byte
|
|
|
|
b := rawSmall[:]
|
|
ae.encode(b)
|
|
if b[0] != 0 {
|
|
t.Fatalf("Expected arg buffer to not be used")
|
|
}
|
|
b = rawBigger[:]
|
|
ae.encode(b)
|
|
if b[0] == 0 {
|
|
t.Fatalf("Expected arg buffer to be used")
|
|
}
|
|
|
|
// Test max number of entries.
|
|
for i := 0; i < math.MaxUint16+1; i++ {
|
|
ae.entries = append(ae.entries, &Entry{EntryNormal, nil})
|
|
}
|
|
_, err = ae.encode(b)
|
|
require_Error(t, err, errTooManyEntries)
|
|
}
|
|
|
|
func TestNRGAppendEntryDecode(t *testing.T) {
|
|
ae := &appendEntry{
|
|
leader: "12345678",
|
|
term: 1,
|
|
pindex: 0,
|
|
}
|
|
for i := 0; i < math.MaxUint16; i++ {
|
|
ae.entries = append(ae.entries, &Entry{EntryNormal, nil})
|
|
}
|
|
buf, err := ae.encode(nil)
|
|
require_NoError(t, err)
|
|
|
|
// Truncate buffer first.
|
|
var node *raft
|
|
short := buf[0 : len(buf)-1024]
|
|
_, err = node.decodeAppendEntry(short, nil, _EMPTY_)
|
|
require_Error(t, err, errBadAppendEntry)
|
|
|
|
for i := 0; i < 100; i++ {
|
|
b := append(buf[:0:0], buf...)
|
|
bi := rand.Intn(len(b))
|
|
if b[bi] != 0 {
|
|
b[bi] = 0
|
|
_, err = node.decodeAppendEntry(b, nil, _EMPTY_)
|
|
require_Error(t, err, errBadAppendEntry)
|
|
}
|
|
}
|
|
}
|