8232312c1e
Move some calls to container.LogEvent down lower so that there's less of a chance of them being missed. Also add a few more events that appear to have been missed. Added testcases for new events: commit, copy, resize, attach, rename, top Signed-off-by: Doug Davis <dug@us.ibm.com>
45 lines
916 B
Go
45 lines
916 B
Go
package daemon
|
|
|
|
import (
|
|
"fmt"
|
|
)
|
|
|
|
func (daemon *Daemon) ContainerRename(oldName, newName string) error {
|
|
if oldName == "" || newName == "" {
|
|
return fmt.Errorf("usage: docker rename OLD_NAME NEW_NAME")
|
|
}
|
|
|
|
container, err := daemon.Get(oldName)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
oldName = container.Name
|
|
|
|
container.Lock()
|
|
defer container.Unlock()
|
|
if newName, err = daemon.reserveName(container.ID, newName); err != nil {
|
|
return fmt.Errorf("Error when allocating new name: %s", err)
|
|
}
|
|
|
|
container.Name = newName
|
|
|
|
undo := func() {
|
|
container.Name = oldName
|
|
daemon.reserveName(container.ID, oldName)
|
|
daemon.containerGraph.Delete(newName)
|
|
}
|
|
|
|
if err := daemon.containerGraph.Delete(oldName); err != nil {
|
|
undo()
|
|
return fmt.Errorf("Failed to delete container %q: %v", oldName, err)
|
|
}
|
|
|
|
if err := container.toDisk(); err != nil {
|
|
undo()
|
|
return err
|
|
}
|
|
|
|
container.LogEvent("rename")
|
|
return nil
|
|
}
|