2015-12-29 16:14:54 +03:00
|
|
|
// Copyright 2014 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
// This file contains tests for some of the internal functions.
|
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Helpers to save typing in the test cases.
|
|
|
|
type u []uint64
|
|
|
|
type uu [][]uint64
|
|
|
|
|
|
|
|
type SplitTest struct {
|
|
|
|
input u
|
|
|
|
output uu
|
|
|
|
signed bool
|
|
|
|
}
|
|
|
|
|
|
|
|
var (
|
2018-03-09 19:55:00 +03:00
|
|
|
m2 = uint64(2)
|
|
|
|
m1 = uint64(1)
|
|
|
|
m0 = uint64(0)
|
|
|
|
m1Spanning0 = ^uint64(0) // -1 when signed.
|
|
|
|
m2Spanning0 = ^uint64(0) - 1 // -2 when signed.
|
2015-12-29 16:14:54 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
var splitTests = []SplitTest{
|
|
|
|
// No need for a test for the empty case; that's picked off before splitIntoRuns.
|
|
|
|
// Single value.
|
|
|
|
{u{1}, uu{u{1}}, false},
|
|
|
|
// Out of order.
|
|
|
|
{u{3, 2, 1}, uu{u{1, 2, 3}}, true},
|
|
|
|
// Out of order.
|
|
|
|
{u{3, 2, 1}, uu{u{1, 2, 3}}, false},
|
|
|
|
// A gap at the beginning.
|
|
|
|
{u{1, 33, 32, 31}, uu{u{1}, u{31, 32, 33}}, true},
|
|
|
|
// A gap in the middle, in mixed order.
|
|
|
|
{u{33, 7, 32, 31, 9, 8}, uu{u{7, 8, 9}, u{31, 32, 33}}, true},
|
|
|
|
// Gaps throughout
|
|
|
|
{u{33, 44, 1, 32, 45, 31}, uu{u{1}, u{31, 32, 33}, u{44, 45}}, true},
|
|
|
|
// Unsigned values spanning 0.
|
2018-03-09 19:55:00 +03:00
|
|
|
{u{m1, m0, m1Spanning0, m2, m2Spanning0}, uu{u{m0, m1, m2}, u{m2Spanning0, m1Spanning0}}, false},
|
2015-12-29 16:14:54 +03:00
|
|
|
// Signed values spanning 0
|
2018-03-09 19:55:00 +03:00
|
|
|
{u{m1, m0, m1Spanning0, m2, m2Spanning0}, uu{u{m2Spanning0, m1Spanning0, m0, m1, m2}}, true},
|
2015-12-29 16:14:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestSplitIntoRuns(t *testing.T) {
|
|
|
|
Outer:
|
|
|
|
for n, test := range splitTests {
|
|
|
|
values := make([]Value, len(test.input))
|
|
|
|
for i, v := range test.input {
|
2019-05-25 19:02:36 +03:00
|
|
|
values[i] = Value{"", v, test.signed, fmt.Sprint(v), ""}
|
2015-12-29 16:14:54 +03:00
|
|
|
}
|
|
|
|
runs := splitIntoRuns(values)
|
|
|
|
if len(runs) != len(test.output) {
|
|
|
|
t.Errorf("#%d: %v: got %d runs; expected %d", n, test.input, len(runs), len(test.output))
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
for i, run := range runs {
|
|
|
|
if len(run) != len(test.output[i]) {
|
|
|
|
t.Errorf("#%d: got %v; expected %v", n, runs, test.output)
|
|
|
|
continue Outer
|
|
|
|
}
|
|
|
|
for j, v := range run {
|
|
|
|
if v.value != test.output[i][j] {
|
|
|
|
t.Errorf("#%d: got %v; expected %v", n, runs, test.output)
|
|
|
|
continue Outer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|