7fb7a477d7
No substantial code change. - Api --> API - Cli --> CLI - Http, Https --> HTTP, HTTPS - Id --> ID - Uid,Gid,Pid --> UID,PID,PID - Ipam --> IPAM - Tls --> TLS (TestDaemonNoTlsCliTlsVerifyWithEnv --> TestDaemonTLSVerifyIssue13964) Didn't touch in this commit: - Git: because it is officially "Git": https://git-scm.com/ - Tar: because it is officially "Tar": https://www.gnu.org/software/tar/ - Cpu, Nat, Mac, Ipc, Shm: for keeping a consistency with existing production code (not changable, for compatibility) Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
73 lines
1.8 KiB
Go
73 lines
1.8 KiB
Go
package main
|
|
|
|
import (
|
|
"encoding/json"
|
|
"io"
|
|
"net/http"
|
|
"net/url"
|
|
"strconv"
|
|
"strings"
|
|
"time"
|
|
|
|
"github.com/docker/docker/pkg/integration/checker"
|
|
"github.com/docker/docker/pkg/jsonmessage"
|
|
"github.com/go-check/check"
|
|
)
|
|
|
|
func (s *DockerSuite) TestEventsAPIEmptyOutput(c *check.C) {
|
|
type apiResp struct {
|
|
resp *http.Response
|
|
err error
|
|
}
|
|
chResp := make(chan *apiResp)
|
|
go func() {
|
|
resp, body, err := sockRequestRaw("GET", "/events", nil, "")
|
|
body.Close()
|
|
chResp <- &apiResp{resp, err}
|
|
}()
|
|
|
|
select {
|
|
case r := <-chResp:
|
|
c.Assert(r.err, checker.IsNil)
|
|
c.Assert(r.resp.StatusCode, checker.Equals, http.StatusOK)
|
|
case <-time.After(3 * time.Second):
|
|
c.Fatal("timeout waiting for events api to respond, should have responded immediately")
|
|
}
|
|
}
|
|
|
|
func (s *DockerSuite) TestEventsAPIBackwardsCompatible(c *check.C) {
|
|
since := daemonTime(c).Unix()
|
|
ts := strconv.FormatInt(since, 10)
|
|
|
|
out, _ := runSleepingContainer(c, "--name=foo", "-d")
|
|
containerID := strings.TrimSpace(out)
|
|
c.Assert(waitRun(containerID), checker.IsNil)
|
|
|
|
q := url.Values{}
|
|
q.Set("since", ts)
|
|
|
|
_, body, err := sockRequestRaw("GET", "/events?"+q.Encode(), nil, "")
|
|
c.Assert(err, checker.IsNil)
|
|
defer body.Close()
|
|
|
|
dec := json.NewDecoder(body)
|
|
var containerCreateEvent *jsonmessage.JSONMessage
|
|
for {
|
|
var event jsonmessage.JSONMessage
|
|
if err := dec.Decode(&event); err != nil {
|
|
if err == io.EOF {
|
|
break
|
|
}
|
|
c.Fatal(err)
|
|
}
|
|
if event.Status == "create" && event.ID == containerID {
|
|
containerCreateEvent = &event
|
|
break
|
|
}
|
|
}
|
|
|
|
c.Assert(containerCreateEvent, checker.Not(checker.IsNil))
|
|
c.Assert(containerCreateEvent.Status, checker.Equals, "create")
|
|
c.Assert(containerCreateEvent.ID, checker.Equals, containerID)
|
|
c.Assert(containerCreateEvent.From, checker.Equals, "busybox")
|
|
}
|