mirror of
https://github.com/gonum/gonum.git
synced 2025-10-05 23:26:52 +08:00
117 lines
3.5 KiB
Go
117 lines
3.5 KiB
Go
// Copyright ©2018 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 iterator_test
|
|
|
|
import (
|
|
"reflect"
|
|
"testing"
|
|
|
|
"gonum.org/v1/gonum/graph"
|
|
"gonum.org/v1/gonum/graph/iterator"
|
|
"gonum.org/v1/gonum/graph/simple"
|
|
)
|
|
|
|
type edge struct{ f, t int }
|
|
|
|
func (e edge) From() graph.Node { return simple.Node(e.f) }
|
|
func (e edge) To() graph.Node { return simple.Node(e.t) }
|
|
func (e edge) ReversedEdge() graph.Edge { return edge{f: e.t, t: e.f} }
|
|
|
|
var orderedEdgesTests = []struct {
|
|
edges []graph.Edge
|
|
}{
|
|
{edges: nil},
|
|
{edges: []graph.Edge{edge{f: 1, t: 2}}},
|
|
{edges: []graph.Edge{edge{f: 1, t: 2}, edge{f: 2, t: 3}, edge{f: 3, t: 4}, edge{f: 4, t: 5}}},
|
|
{edges: []graph.Edge{edge{f: 5, t: 4}, edge{f: 4, t: 3}, edge{f: 3, t: 2}, edge{f: 2, t: 1}}},
|
|
}
|
|
|
|
func TestOrderedEdgesIterate(t *testing.T) {
|
|
for _, test := range orderedEdgesTests {
|
|
it := iterator.NewOrderedEdges(test.edges)
|
|
for i := 0; i < 2; i++ {
|
|
if it.Len() != len(test.edges) {
|
|
t.Errorf("unexpected iterator length for round %d: got:%d want:%d", i, it.Len(), len(test.edges))
|
|
}
|
|
var got []graph.Edge
|
|
for it.Next() {
|
|
got = append(got, it.Edge())
|
|
}
|
|
want := test.edges
|
|
if !reflect.DeepEqual(got, want) {
|
|
t.Errorf("unexpected iterator output for round %d: got:%#v want:%#v", i, got, want)
|
|
}
|
|
it.Reset()
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestOrderedEdgesSlice(t *testing.T) {
|
|
for _, test := range orderedEdgesTests {
|
|
it := iterator.NewOrderedEdges(test.edges)
|
|
for i := 0; i < 2; i++ {
|
|
got := it.EdgeSlice()
|
|
want := test.edges
|
|
if !reflect.DeepEqual(got, want) {
|
|
t.Errorf("unexpected iterator output for round %d: got:%#v want:%#v", i, got, want)
|
|
}
|
|
it.Reset()
|
|
}
|
|
}
|
|
}
|
|
|
|
type weightedEdge struct {
|
|
f, t int
|
|
w float64
|
|
}
|
|
|
|
func (e weightedEdge) From() graph.Node { return simple.Node(e.f) }
|
|
func (e weightedEdge) To() graph.Node { return simple.Node(e.t) }
|
|
func (e weightedEdge) ReversedEdge() graph.Edge { e.f, e.t = e.t, e.f; return e }
|
|
func (e weightedEdge) Weight() float64 { return e.w }
|
|
|
|
var orderedWeightedEdgesTests = []struct {
|
|
edges []graph.WeightedEdge
|
|
}{
|
|
{edges: nil},
|
|
{edges: []graph.WeightedEdge{weightedEdge{f: 1, t: 2, w: 1}}},
|
|
{edges: []graph.WeightedEdge{weightedEdge{f: 1, t: 2, w: 1}, weightedEdge{f: 2, t: 3, w: 2}, weightedEdge{f: 3, t: 4, w: 3}, weightedEdge{f: 4, t: 5, w: 4}}},
|
|
{edges: []graph.WeightedEdge{weightedEdge{f: 5, t: 4, w: 4}, weightedEdge{f: 4, t: 3, w: 3}, weightedEdge{f: 3, t: 2, w: 2}, weightedEdge{f: 2, t: 1, w: 1}}},
|
|
}
|
|
|
|
func TestOrderedWeightedEdgesIterate(t *testing.T) {
|
|
for _, test := range orderedWeightedEdgesTests {
|
|
it := iterator.NewOrderedWeightedEdges(test.edges)
|
|
for i := 0; i < 2; i++ {
|
|
if it.Len() != len(test.edges) {
|
|
t.Errorf("unexpected iterator length for round %d: got:%d want:%d", i, it.Len(), len(test.edges))
|
|
}
|
|
var got []graph.WeightedEdge
|
|
for it.Next() {
|
|
got = append(got, it.WeightedEdge())
|
|
}
|
|
want := test.edges
|
|
if !reflect.DeepEqual(got, want) {
|
|
t.Errorf("unexpected iterator output for round %d: got:%#v want:%#v", i, got, want)
|
|
}
|
|
it.Reset()
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestOrderedWeightedEdgesSlice(t *testing.T) {
|
|
for _, test := range orderedWeightedEdgesTests {
|
|
it := iterator.NewOrderedWeightedEdges(test.edges)
|
|
for i := 0; i < 2; i++ {
|
|
got := it.WeightedEdgeSlice()
|
|
want := test.edges
|
|
if !reflect.DeepEqual(got, want) {
|
|
t.Errorf("unexpected iterator output for round %d: got:%#v want:%#v", i, got, want)
|
|
}
|
|
it.Reset()
|
|
}
|
|
}
|
|
}
|