Merge pull request #1048 from crosbymichael/state-json

Use same state object for state and list
This commit is contained in:
Qiang Huang 2016-09-22 19:48:43 +08:00 committed by GitHub
commit a2a6e828a9
3 changed files with 10 additions and 28 deletions

View File

@ -22,6 +22,8 @@ const formatOptions = `table or json`
// containerState represents the platform agnostic pieces relating to a // containerState represents the platform agnostic pieces relating to a
// running container's status and state // running container's status and state
type containerState struct { type containerState struct {
// Version is the OCI version for the container
Version string `json:"ociVersion"`
// ID is the container ID // ID is the container ID
ID string `json:"id"` ID string `json:"id"`
// InitProcessPid is the init process id in the parent namespace // InitProcessPid is the init process id in the parent namespace
@ -30,6 +32,8 @@ type containerState struct {
Status string `json:"status"` Status string `json:"status"`
// Bundle is the path on the filesystem to the bundle // Bundle is the path on the filesystem to the bundle
Bundle string `json:"bundle"` Bundle string `json:"bundle"`
// Rootfs is a path to a directory containing the container's root filesystem.
Rootfs string `json:"rootfs"`
// Created is the unix timestamp for the creation time of the container in UTC // Created is the unix timestamp for the creation time of the container in UTC
Created time.Time `json:"created"` Created time.Time `json:"created"`
// Annotations is the user defined annotations added to the config. // Annotations is the user defined annotations added to the config.
@ -140,10 +144,12 @@ func getContainers(context *cli.Context) ([]containerState, error) {
} }
bundle, annotations := utils.Annotations(state.Config.Labels) bundle, annotations := utils.Annotations(state.Config.Labels)
s = append(s, containerState{ s = append(s, containerState{
Version: state.BaseState.Config.Version,
ID: state.BaseState.ID, ID: state.BaseState.ID,
InitProcessPid: pid, InitProcessPid: pid,
Status: containerStatus.String(), Status: containerStatus.String(),
Bundle: bundle, Bundle: bundle,
Rootfs: state.BaseState.Config.Rootfs,
Created: state.BaseState.Created, Created: state.BaseState.Created,
Annotations: annotations, Annotations: annotations,
}) })

View File

@ -5,36 +5,12 @@ package main
import ( import (
"encoding/json" "encoding/json"
"os" "os"
"time"
"github.com/opencontainers/runc/libcontainer" "github.com/opencontainers/runc/libcontainer"
"github.com/opencontainers/runc/libcontainer/utils" "github.com/opencontainers/runc/libcontainer/utils"
"github.com/urfave/cli" "github.com/urfave/cli"
) )
// cState represents the platform agnostic pieces relating to a running
// container's status and state. Note: The fields in this structure adhere to
// the opencontainers/runtime-spec/specs-go requirement for json fields that must be returned
// in a state command.
type cState struct {
// Version is the OCI version for the container
Version string `json:"ociVersion"`
// ID is the container ID
ID string `json:"id"`
// InitProcessPid is the init process id in the parent namespace
InitProcessPid int `json:"pid"`
// Bundle is the path on the filesystem to the bundle
Bundle string `json:"bundlePath"`
// Rootfs is a path to a directory containing the container's root filesystem.
Rootfs string `json:"rootfsPath"`
// Status is the current status of the container, running, paused, ...
Status string `json:"status"`
// Created is the unix timestamp for the creation time of the container in UTC
Created time.Time `json:"created"`
// Annotations is the user defined annotations added to the config.
Annotations map[string]string `json:"annotations,omitempty"`
}
var stateCommand = cli.Command{ var stateCommand = cli.Command{
Name: "state", Name: "state",
Usage: "output the state of a container", Usage: "output the state of a container",
@ -61,7 +37,7 @@ instance of a container.`,
pid = 0 pid = 0
} }
bundle, annotations := utils.Annotations(state.Config.Labels) bundle, annotations := utils.Annotations(state.Config.Labels)
cs := cState{ cs := containerState{
Version: state.BaseState.Config.Version, Version: state.BaseState.Config.Version,
ID: state.BaseState.ID, ID: state.BaseState.ID,
InitProcessPid: pid, InitProcessPid: pid,

View File

@ -47,7 +47,7 @@ function teardown() {
ROOT=$HELLO_BUNDLE runc list --format json ROOT=$HELLO_BUNDLE runc list --format json
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "${lines[0]}" == [\[][\{]"\"id\""[:]"\"test_box1\""[,]"\"pid\""[:]*[0-9][,]"\"status\""[:]*"\"running\""[,]"\"bundle\""[:]*$BUSYBOX_BUNDLE*[,]"\"created\""[:]*[0-9]*[\}]* ]] [[ "${lines[0]}" == [\[][\{]"\"ociVersion\""[:]"\""*[0-9][\.]*[0-9][\.]*[0-9]*"\""[,]"\"id\""[:]"\"test_box1\""[,]"\"pid\""[:]*[0-9][,]"\"status\""[:]*"\"running\""[,]"\"bundle\""[:]*$BUSYBOX_BUNDLE*[,]"\"rootfs\""[:]"\""*"\""[,]"\"created\""[:]*[0-9]*[\}]* ]]
[[ "${lines[0]}" == *[,][\{]"\"id\""[:]"\"test_box2\""[,]"\"pid\""[:]*[0-9][,]"\"status\""[:]*"\"running\""[,]"\"bundle\""[:]*$BUSYBOX_BUNDLE*[,]"\"created\""[:]*[0-9]*[\}]* ]] [[ "${lines[0]}" == *[,][\{]"\"ociVersion\""[:]"\""*[0-9][\.]*[0-9][\.]*[0-9]*"\""[,]"\"id\""[:]"\"test_box2\""[,]"\"pid\""[:]*[0-9][,]"\"status\""[:]*"\"running\""[,]"\"bundle\""[:]*$BUSYBOX_BUNDLE*[,]"\"rootfs\""[:]"\""*"\""[,]"\"created\""[:]*[0-9]*[\}]* ]]
[[ "${lines[0]}" == *[,][\{]"\"id\""[:]"\"test_box3\""[,]"\"pid\""[:]*[0-9][,]"\"status\""[:]*"\"running\""[,]"\"bundle\""[:]*$BUSYBOX_BUNDLE*[,]"\"created\""[:]*[0-9]*[\}][\]] ]] [[ "${lines[0]}" == *[,][\{]"\"ociVersion\""[:]"\""*[0-9][\.]*[0-9][\.]*[0-9]*"\""[,]"\"id\""[:]"\"test_box3\""[,]"\"pid\""[:]*[0-9][,]"\"status\""[:]*"\"running\""[,]"\"bundle\""[:]*$BUSYBOX_BUNDLE*[,]"\"rootfs\""[:]"\""*"\""[,]"\"created\""[:]*[0-9]*[\}][\]] ]]
} }