mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Merge pull request #8737 from brahmaroutu/resize_uponstart_8728
Allowing resize tty to only work when container is started
This commit is contained in:
commit
a71b2ec54a
3 changed files with 58 additions and 1 deletions
|
@ -691,6 +691,9 @@ func (container *Container) Restart(seconds int) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (container *Container) Resize(h, w int) error {
|
func (container *Container) Resize(h, w int) error {
|
||||||
|
if !container.IsRunning() {
|
||||||
|
return fmt.Errorf("Cannot resize container %s, container is not running", container.ID)
|
||||||
|
}
|
||||||
return container.command.ProcessConfig.Terminal.Resize(h, w)
|
return container.command.ProcessConfig.Terminal.Resize(h, w)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
53
integration-cli/docker_api_resize_test.go
Normal file
53
integration-cli/docker_api_resize_test.go
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os/exec"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestResizeApiResponse(t *testing.T) {
|
||||||
|
runCmd := exec.Command(dockerBinary, "run", "-d", "busybox", "true")
|
||||||
|
out, _, err := runCommandWithOutput(runCmd)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf(out, err)
|
||||||
|
}
|
||||||
|
defer deleteAllContainers()
|
||||||
|
cleanedContainerID := stripTrailingCharacters(out)
|
||||||
|
|
||||||
|
endpoint := "/containers/" + cleanedContainerID + "/resize?h=40&w=40"
|
||||||
|
_, err = sockRequest("POST", endpoint)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("resize Request failed %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
logDone("container resize - when started")
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestResizeApiResponseWhenContainerNotStarted(t *testing.T) {
|
||||||
|
runCmd := exec.Command(dockerBinary, "run", "-d", "busybox", "true")
|
||||||
|
out, _, err := runCommandWithOutput(runCmd)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf(out, err)
|
||||||
|
}
|
||||||
|
defer deleteAllContainers()
|
||||||
|
cleanedContainerID := stripTrailingCharacters(out)
|
||||||
|
|
||||||
|
// make sure the exited cintainer is not running
|
||||||
|
runCmd = exec.Command(dockerBinary, "wait", cleanedContainerID)
|
||||||
|
out, _, err = runCommandWithOutput(runCmd)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf(out, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
endpoint := "/containers/" + cleanedContainerID + "/resize?h=40&w=40"
|
||||||
|
body, err := sockRequest("POST", endpoint)
|
||||||
|
if err == nil {
|
||||||
|
t.Fatalf("resize should fail when container is not started")
|
||||||
|
}
|
||||||
|
if !strings.Contains(string(body), "Cannot resize container") && !strings.Contains(string(body), cleanedContainerID) {
|
||||||
|
t.Fatalf("resize should fail with message 'Cannot resize container' but instead received %s", string(body))
|
||||||
|
}
|
||||||
|
|
||||||
|
logDone("container resize - when not started should not resize")
|
||||||
|
}
|
|
@ -254,7 +254,8 @@ func sockRequest(method, endpoint string) ([]byte, error) {
|
||||||
}
|
}
|
||||||
defer resp.Body.Close()
|
defer resp.Body.Close()
|
||||||
if resp.StatusCode != http.StatusOK {
|
if resp.StatusCode != http.StatusOK {
|
||||||
return nil, fmt.Errorf("received status != 200 OK: %s", resp.Status)
|
body, _ := ioutil.ReadAll(resp.Body)
|
||||||
|
return body, fmt.Errorf("received status != 200 OK: %s", resp.Status)
|
||||||
}
|
}
|
||||||
|
|
||||||
return ioutil.ReadAll(resp.Body)
|
return ioutil.ReadAll(resp.Body)
|
||||||
|
|
Loading…
Reference in a new issue