// 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) } 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 { for i := 0; i < 2; i++ { it := iterator.NewOrderedEdges(test.edges) 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 { for i := 0; i < 2; i++ { it := iterator.NewOrderedEdges(test.edges) 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) 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 { for i := 0; i < 2; i++ { it := iterator.NewOrderedWeightedEdges(test.edges) 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 { for i := 0; i < 2; i++ { it := iterator.NewOrderedWeightedEdges(test.edges) 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() } } }