Merge pull request #1332 from weaveworks/1091-docker-rename

Support docker rename events
This commit is contained in:
Paul Bellamy
2016-04-20 09:45:40 +01:00
3 changed files with 35 additions and 9 deletions

View File

@@ -334,9 +334,6 @@ export default class NodesChart extends React.Component {
const stateNodes = this.initNodes(props.nodes, state.nodes); const stateNodes = this.initNodes(props.nodes, state.nodes);
const stateEdges = this.initEdges(props.nodes, stateNodes); const stateEdges = this.initEdges(props.nodes, stateNodes);
const nodeMetrics = stateNodes.map(node => makeMap({
metrics: node.get('metrics')
}));
const nodeScale = this.getNodeScale(props.nodes, state.width, state.height); const nodeScale = this.getNodeScale(props.nodes, state.width, state.height);
const nextState = { nodeScale }; const nextState = { nodeScale };
@@ -356,12 +353,15 @@ export default class NodesChart extends React.Component {
log(`graph layout took ${timedLayouter.time}ms`); log(`graph layout took ${timedLayouter.time}ms`);
// inject metrics and save coordinates for restore // inject metrics and save coordinates for restore
const layoutNodes = graph.nodes let layoutNodes = graph.nodes
.mergeDeep(nodeMetrics)
.map(node => node.merge({ .map(node => node.merge({
px: node.get('x'), px: node.get('x'),
py: node.get('y') py: node.get('y')
})); }));
// Re-apply in case layout runner's node cache applied stale node metadata
layoutNodes = layoutNodes.mergeDeep(stateNodes);
const layoutEdges = graph.edges const layoutEdges = graph.edges
.map(edge => edge.set('ppoints', edge.get('points'))); .map(edge => edge.set('ppoints', edge.get('points')));

View File

@@ -14,6 +14,7 @@ import (
const ( const (
CreateEvent = "create" CreateEvent = "create"
DestroyEvent = "destroy" DestroyEvent = "destroy"
RenameEvent = "rename"
StartEvent = "start" StartEvent = "start"
DieEvent = "die" DieEvent = "die"
PauseEvent = "pause" PauseEvent = "pause"
@@ -238,7 +239,7 @@ func (r *registry) updateImages() error {
func (r *registry) handleEvent(event *docker_client.APIEvents) { func (r *registry) handleEvent(event *docker_client.APIEvents) {
switch event.Status { switch event.Status {
case CreateEvent, StartEvent, DieEvent, DestroyEvent, PauseEvent, UnpauseEvent: case CreateEvent, RenameEvent, StartEvent, DieEvent, DestroyEvent, PauseEvent, UnpauseEvent:
r.updateContainerState(event.ID) r.updateContainerState(event.ID)
} }
} }

View File

@@ -203,9 +203,22 @@ var (
}, },
}, },
} }
apiContainer1 = client.APIContainers{ID: "ping"} renamedContainer = &client.Container{
apiContainer2 = client.APIContainers{ID: "wiff"} ID: "renamed",
apiImage1 = client.APIImages{ID: "baz", RepoTags: []string{"bang", "not-chosen"}} Name: "renamed",
Image: "baz",
State: client.State{Pid: 1, Running: true},
Config: &client.Config{
Labels: map[string]string{
"foo1": "bar1",
"foo2": "bar2",
},
},
}
apiContainer1 = client.APIContainers{ID: "ping"}
apiContainer2 = client.APIContainers{ID: "wiff"}
renamedAPIContainer = client.APIContainers{ID: "renamed"}
apiImage1 = client.APIImages{ID: "baz", RepoTags: []string{"bang", "not-chosen"}}
) )
func newMockClient() *mockDockerClient { func newMockClient() *mockDockerClient {
@@ -350,5 +363,17 @@ func TestRegistryEvents(t *testing.T) {
want := []docker.Container{} want := []docker.Container{}
check(want) check(want)
} }
{
mdc.Lock()
mdc.apiContainers = []client.APIContainers{renamedAPIContainer}
mdc.containers[renamedContainer.ID] = renamedContainer
mdc.Unlock()
mdc.send(&client.APIEvents{Status: docker.RenameEvent, ID: renamedContainer.ID})
runtime.Gosched()
want := []docker.Container{&mockContainer{renamedContainer}}
check(want)
}
}) })
} }