etcd/storage/reversion_test.go

40 lines
940 B
Go

package storage
import (
"bytes"
"math"
"reflect"
"testing"
)
// TestReversion tests that reversion could be encoded to and decoded from
// bytes slice. Moreover, the lexicograph order of its byte slice representation
// follows the order of (main, sub).
func TestReversion(t *testing.T) {
tests := []reversion{
// order in (main, sub)
reversion{},
reversion{main: 1, sub: 0},
reversion{main: 1, sub: 1},
reversion{main: 2, sub: 0},
reversion{main: math.MaxInt64, sub: math.MaxInt64},
}
bs := make([][]byte, len(tests))
for i, tt := range tests {
b := newRevBytes()
revToBytes(tt, b)
bs[i] = b
if grev := bytesToRev(b); !reflect.DeepEqual(grev, tt) {
t.Errorf("#%d: reversion = %+v, want %+v", i, grev, tt)
}
}
for i := 0; i < len(tests)-1; i++ {
if bytes.Compare(bs[i], bs[i+1]) >= 0 {
t.Errorf("#%d: %v (%+v) should be smaller than %v (%+v)", i, bs[i], tests[i], bs[i+1], tests[i+1])
}
}
}