123456789101112131415161718192021222324252627282930313233343536373839 |
- 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])
- }
- }
- }
|