mirror of
https://github.com/weaveworks/scope.git
synced 2026-03-03 02:00:43 +00:00
169 lines
5.3 KiB
Go
169 lines
5.3 KiB
Go
package render_test
|
|
|
|
import (
|
|
"reflect"
|
|
"testing"
|
|
|
|
"github.com/weaveworks/scope/render"
|
|
"github.com/weaveworks/scope/report"
|
|
"github.com/weaveworks/scope/test"
|
|
)
|
|
|
|
type mockRenderer struct {
|
|
render.RenderableNodes
|
|
edgeMetadata report.EdgeMetadata
|
|
}
|
|
|
|
func (m mockRenderer) Render(rpt report.Report) render.RenderableNodes {
|
|
return m.RenderableNodes
|
|
}
|
|
func (m mockRenderer) EdgeMetadata(rpt report.Report, localID, remoteID string) report.EdgeMetadata {
|
|
return m.edgeMetadata
|
|
}
|
|
|
|
func TestReduceRender(t *testing.T) {
|
|
renderer := render.Reduce([]render.Renderer{
|
|
mockRenderer{RenderableNodes: render.RenderableNodes{"foo": {ID: "foo"}}},
|
|
mockRenderer{RenderableNodes: render.RenderableNodes{"bar": {ID: "bar"}}},
|
|
})
|
|
|
|
want := render.RenderableNodes{"foo": {ID: "foo"}, "bar": {ID: "bar"}}
|
|
have := renderer.Render(report.MakeReport())
|
|
|
|
if !reflect.DeepEqual(want, have) {
|
|
t.Errorf("want %+v, have %+v", want, have)
|
|
}
|
|
}
|
|
|
|
func TestReduceEdge(t *testing.T) {
|
|
renderer := render.Reduce([]render.Renderer{
|
|
mockRenderer{edgeMetadata: report.EdgeMetadata{EgressPacketCount: newu64(1)}},
|
|
mockRenderer{edgeMetadata: report.EdgeMetadata{EgressPacketCount: newu64(2)}},
|
|
})
|
|
|
|
want := report.EdgeMetadata{EgressPacketCount: newu64(3)}
|
|
have := renderer.EdgeMetadata(report.MakeReport(), "", "")
|
|
|
|
if !reflect.DeepEqual(want, have) {
|
|
t.Errorf("want %+v, have %+v", want, have)
|
|
}
|
|
}
|
|
|
|
func TestMapRender1(t *testing.T) {
|
|
// 1. Check when we return false, the node gets filtered out
|
|
mapper := render.Map{
|
|
MapFunc: func(nodes render.RenderableNode) (render.RenderableNode, bool) {
|
|
return render.RenderableNode{}, false
|
|
},
|
|
Renderer: mockRenderer{RenderableNodes: render.RenderableNodes{
|
|
"foo": {ID: "foo"},
|
|
}},
|
|
}
|
|
want := render.RenderableNodes{}
|
|
have := mapper.Render(report.MakeReport())
|
|
if !reflect.DeepEqual(want, have) {
|
|
t.Errorf("want %+v, have %+v", want, have)
|
|
}
|
|
}
|
|
|
|
func TestMapRender2(t *testing.T) {
|
|
// 2. Check we can remap two nodes into one
|
|
mapper := render.Map{
|
|
MapFunc: func(nodes render.RenderableNode) (render.RenderableNode, bool) {
|
|
return render.RenderableNode{ID: "bar"}, true
|
|
},
|
|
Renderer: mockRenderer{RenderableNodes: render.RenderableNodes{
|
|
"foo": {ID: "foo"},
|
|
"baz": {ID: "baz"},
|
|
}},
|
|
}
|
|
want := sterilize(render.RenderableNodes{
|
|
"bar": render.RenderableNode{ID: "bar"},
|
|
}, false)
|
|
have := mapper.Render(report.MakeReport())
|
|
if !reflect.DeepEqual(want, have) {
|
|
t.Error(test.Diff(want, have))
|
|
}
|
|
}
|
|
|
|
func TestMapRender3(t *testing.T) {
|
|
// 3. Check we can remap adjacencies
|
|
mapper := render.Map{
|
|
MapFunc: func(nodes render.RenderableNode) (render.RenderableNode, bool) {
|
|
return render.RenderableNode{ID: "_" + nodes.ID}, true
|
|
},
|
|
Renderer: mockRenderer{RenderableNodes: render.RenderableNodes{
|
|
"foo": {ID: "foo", Adjacency: report.MakeIDList("baz")},
|
|
"baz": {ID: "baz", Adjacency: report.MakeIDList("foo")},
|
|
}},
|
|
}
|
|
want := render.RenderableNodes{
|
|
"_foo": {ID: "_foo", Adjacency: report.MakeIDList("_baz")},
|
|
"_baz": {ID: "_baz", Adjacency: report.MakeIDList("_foo")},
|
|
}
|
|
have := mapper.Render(report.MakeReport())
|
|
if !reflect.DeepEqual(want, have) {
|
|
t.Errorf("want %+v, have %+v", want, have)
|
|
}
|
|
}
|
|
|
|
func TestMapEdge(t *testing.T) {
|
|
selector := func(_ report.Report) report.Topology {
|
|
return report.Topology{
|
|
NodeMetadatas: report.NodeMetadatas{
|
|
"foo": report.MakeNodeMetadataWith(map[string]string{"id": "foo"}),
|
|
"bar": report.MakeNodeMetadataWith(map[string]string{"id": "bar"}),
|
|
},
|
|
Adjacency: report.Adjacency{
|
|
">foo": report.MakeIDList("bar"),
|
|
">bar": report.MakeIDList("foo"),
|
|
},
|
|
EdgeMetadatas: report.EdgeMetadatas{
|
|
"foo|bar": report.EdgeMetadata{EgressPacketCount: newu64(1), EgressByteCount: newu64(2)},
|
|
"bar|foo": report.EdgeMetadata{EgressPacketCount: newu64(3), EgressByteCount: newu64(4)},
|
|
},
|
|
}
|
|
}
|
|
|
|
identity := func(nmd report.NodeMetadata) (render.RenderableNode, bool) {
|
|
return render.NewRenderableNode(nmd.Metadata["id"], "", "", "", nmd), true
|
|
}
|
|
|
|
mapper := render.Map{
|
|
MapFunc: func(n render.RenderableNode) (render.RenderableNode, bool) {
|
|
return render.RenderableNode{ID: "_" + n.ID}, true
|
|
},
|
|
Renderer: render.LeafMap{
|
|
Selector: selector,
|
|
Mapper: identity,
|
|
Pseudo: nil,
|
|
},
|
|
}
|
|
|
|
if want, have := (report.EdgeMetadata{
|
|
EgressPacketCount: newu64(1),
|
|
EgressByteCount: newu64(2),
|
|
}), mapper.EdgeMetadata(report.MakeReport(), "_foo", "_bar"); !reflect.DeepEqual(want, have) {
|
|
t.Error(test.Diff(want, have))
|
|
}
|
|
}
|
|
|
|
func TestFilterRender(t *testing.T) {
|
|
renderer := render.FilterUnconnected(
|
|
mockRenderer{RenderableNodes: render.RenderableNodes{
|
|
"foo": {ID: "foo", Adjacency: report.MakeIDList("bar"), NodeMetadata: report.MakeNodeMetadata()},
|
|
"bar": {ID: "bar", Adjacency: report.MakeIDList("foo"), NodeMetadata: report.MakeNodeMetadata()},
|
|
"baz": {ID: "baz", Adjacency: report.MakeIDList(), NodeMetadata: report.MakeNodeMetadata()},
|
|
}})
|
|
want := render.RenderableNodes{
|
|
"foo": {ID: "foo", Adjacency: report.MakeIDList("bar"), NodeMetadata: report.MakeNodeMetadata()},
|
|
"bar": {ID: "bar", Adjacency: report.MakeIDList("foo"), NodeMetadata: report.MakeNodeMetadata()},
|
|
}
|
|
have := sterilize(renderer.Render(report.MakeReport()), true)
|
|
if !reflect.DeepEqual(want, have) {
|
|
t.Errorf("want %+v, have %+v", want, have)
|
|
}
|
|
}
|
|
|
|
func newu64(value uint64) *uint64 { return &value }
|