mirror of
https://github.com/weaveworks/scope.git
synced 2026-02-14 18:09:59 +00:00
* Pass Go context down to Renderers This is useful for cancellation or tracing. * Add tracing spans to app Also log things like number of nodes in Map, total number of reports.
97 lines
2.5 KiB
Go
97 lines
2.5 KiB
Go
package render_test
|
|
|
|
import (
|
|
"context"
|
|
"reflect"
|
|
"testing"
|
|
|
|
"github.com/weaveworks/common/test"
|
|
"github.com/weaveworks/scope/render"
|
|
"github.com/weaveworks/scope/report"
|
|
)
|
|
|
|
type mockRenderer struct {
|
|
report.Nodes
|
|
}
|
|
|
|
func (m mockRenderer) Render(_ context.Context, rpt report.Report) render.Nodes {
|
|
return render.Nodes{Nodes: m.Nodes}
|
|
}
|
|
|
|
func TestReduceRender(t *testing.T) {
|
|
renderer := render.Reduce([]render.Renderer{
|
|
mockRenderer{Nodes: report.Nodes{"foo": report.MakeNode("foo")}},
|
|
mockRenderer{Nodes: report.Nodes{"bar": report.MakeNode("bar")}},
|
|
})
|
|
|
|
want := report.Nodes{
|
|
"foo": report.MakeNode("foo"),
|
|
"bar": report.MakeNode("bar"),
|
|
}
|
|
have := renderer.Render(context.Background(), report.MakeReport()).Nodes
|
|
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 report.Node) report.Node {
|
|
return report.Node{}
|
|
},
|
|
Renderer: mockRenderer{Nodes: report.Nodes{
|
|
"foo": report.MakeNode("foo"),
|
|
}},
|
|
}
|
|
want := report.Nodes{}
|
|
have := mapper.Render(context.Background(), report.MakeReport()).Nodes
|
|
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 report.Node) report.Node {
|
|
return report.MakeNode("bar")
|
|
},
|
|
Renderer: mockRenderer{Nodes: report.Nodes{
|
|
"foo": report.MakeNode("foo"),
|
|
"baz": report.MakeNode("baz"),
|
|
}},
|
|
}
|
|
want := report.Nodes{
|
|
"bar": report.MakeNode("bar"),
|
|
}
|
|
have := mapper.Render(context.Background(), report.MakeReport()).Nodes
|
|
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 report.Node) report.Node {
|
|
id := "_" + nodes.ID
|
|
return report.MakeNode(id)
|
|
},
|
|
Renderer: mockRenderer{Nodes: report.Nodes{
|
|
"foo": report.MakeNode("foo").WithAdjacent("baz"),
|
|
"baz": report.MakeNode("baz").WithAdjacent("foo"),
|
|
}},
|
|
}
|
|
want := report.Nodes{
|
|
"_foo": report.MakeNode("_foo").WithAdjacent("_baz"),
|
|
"_baz": report.MakeNode("_baz").WithAdjacent("_foo"),
|
|
}
|
|
have := mapper.Render(context.Background(), report.MakeReport()).Nodes
|
|
if !reflect.DeepEqual(want, have) {
|
|
t.Error(test.Diff(want, have))
|
|
}
|
|
}
|
|
|
|
func newu64(value uint64) *uint64 { return &value }
|