// 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 ( m2 = uint64(2) m1 = uint64(1) m0 = uint64(0) m1Spanning0 = ^uint64(0) // -1 when signed. m2Spanning0 = ^uint64(0) - 1 // -2 when signed. ) 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. {u{m1, m0, m1Spanning0, m2, m2Spanning0}, uu{u{m0, m1, m2}, u{m2Spanning0, m1Spanning0}}, false}, // Signed values spanning 0 {u{m1, m0, m1Spanning0, m2, m2Spanning0}, uu{u{m2Spanning0, m1Spanning0, m0, m1, m2}}, true}, } func TestSplitIntoRuns(t *testing.T) { Outer: for n, test := range splitTests { values := make([]Value, len(test.input)) for i, v := range test.input { values[i] = Value{"", v, test.signed, fmt.Sprint(v)} } 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 } } } } }