blob: 54ccc22ef9abad60678eea3035fd52df0a8441ae [file] [log] [blame]
// Copyright ©2019 The Gonum Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package testgraph
import (
"reflect"
"testing"
"gonum.org/v1/gonum/graph"
"gonum.org/v1/gonum/graph/simple"
)
var randomNodesTests = []struct {
n int
seed uint64
new func(int64) graph.Node
want []graph.Node
}{
{
n: 0,
want: nil,
},
{
n: 1,
seed: 1,
new: newSimpleNode,
want: []graph.Node{simple.Node(-106976941678315313)},
},
{
n: 1,
seed: 2,
new: newSimpleNode,
want: []graph.Node{simple.Node(6816453162648937526)},
},
{
n: 4,
seed: 1,
new: newSimpleNode,
want: []graph.Node{
simple.Node(-106976941678315313),
simple.Node(867649948573917593),
simple.Node(-4246677790793934368),
simple.Node(406519965772129914),
},
},
{
n: 4,
seed: 2,
new: newSimpleNode,
want: []graph.Node{
simple.Node(6816453162648937526),
simple.Node(-4921844272880608907),
simple.Node(159088832891557680),
simple.Node(-2611333848016927708),
},
},
}
func newSimpleNode(id int64) graph.Node { return simple.Node(id) }
func TestRandomNodesIterate(t *testing.T) {
for _, test := range randomNodesTests {
for i := 0; i < 2; i++ {
it := NewRandomNodes(test.n, test.seed, test.new)
if it.Len() != len(test.want) {
t.Errorf("unexpected iterator length for round %d: got:%d want:%d", i, it.Len(), len(test.want))
}
var got []graph.Node
for it.Next() {
got = append(got, it.Node())
}
if !reflect.DeepEqual(got, test.want) {
t.Errorf("unexpected iterator output for round %d: got:%#v want:%#v", i, got, test.want)
}
it.Reset()
}
}
}