Merge pull request #146 from mrunalp/create_label

Allow adding labels at container create time
This commit is contained in:
Antonio Murdaca 2016-10-14 21:29:52 +02:00 committed by GitHub
commit 3a69841225
2 changed files with 64 additions and 8 deletions

View file

@ -24,6 +24,17 @@ var containerCommand = cli.Command{
}, },
} }
type createOptions struct {
// configPath is path to the config for container
configPath string
// name sets the container name
name string
// podID of the container
podID string
// labels for the container
labels map[string]string
}
var createContainerCommand = cli.Command{ var createContainerCommand = cli.Command{
Name: "create", Name: "create",
Usage: "create a container", Usage: "create a container",
@ -42,6 +53,10 @@ var createContainerCommand = cli.Command{
Value: "", Value: "",
Usage: "the name of the container", Usage: "the name of the container",
}, },
cli.StringSliceFlag{
Name: "label",
Usage: "add key=value labels to the container",
},
}, },
Action: func(context *cli.Context) error { Action: func(context *cli.Context) error {
// Set up a connection to the server. // Set up a connection to the server.
@ -55,8 +70,24 @@ var createContainerCommand = cli.Command{
if !context.IsSet("pod") { if !context.IsSet("pod") {
return fmt.Errorf("Please specify the id of the pod sandbox to which the container belongs via the --pod option") return fmt.Errorf("Please specify the id of the pod sandbox to which the container belongs via the --pod option")
} }
opts := createOptions{
configPath: context.String("config"),
name: context.String("name"),
podID: context.String("pod"),
labels: make(map[string]string),
}
for _, l := range context.StringSlice("label") {
pair := strings.Split(l, "=")
if len(pair) != 2 {
return fmt.Errorf("incorrectly specified label: %v", l)
}
opts.labels[pair[0]] = pair[1]
}
// Test RuntimeServiceClient.CreateContainer // Test RuntimeServiceClient.CreateContainer
err = CreateContainer(client, context.String("pod"), context.String("config"), context.String("name")) err = CreateContainer(client, opts)
if err != nil { if err != nil {
return fmt.Errorf("Creating container failed: %v", err) return fmt.Errorf("Creating container failed: %v", err)
} }
@ -247,19 +278,23 @@ var listContainersCommand = cli.Command{
// CreateContainer sends a CreateContainerRequest to the server, and parses // CreateContainer sends a CreateContainerRequest to the server, and parses
// the returned CreateContainerResponse. // the returned CreateContainerResponse.
func CreateContainer(client pb.RuntimeServiceClient, sandbox string, path string, name string) error { func CreateContainer(client pb.RuntimeServiceClient, opts createOptions) error {
config, err := loadContainerConfig(path) config, err := loadContainerConfig(opts.configPath)
if err != nil { if err != nil {
return err return err
} }
// Override the name by the one specified through CLI // Override the name by the one specified through CLI
if name != "" { if opts.name != "" {
config.Metadata.Name = &name config.Metadata.Name = &opts.name
}
for k, v := range opts.labels {
config.Labels[k] = v
} }
r, err := client.CreateContainer(context.Background(), &pb.CreateContainerRequest{ r, err := client.CreateContainer(context.Background(), &pb.CreateContainerRequest{
PodSandboxId: &sandbox, PodSandboxId: &opts.podID,
Config: config, Config: config,
}) })
if err != nil { if err != nil {

View file

@ -251,11 +251,19 @@ function teardown() {
echo "$output" echo "$output"
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
pod_id="$output" pod_id="$output"
run ocic ctr create --config "$TESTDATA"/container_redis.json --pod "$pod_id" run ocic ctr create --config "$TESTDATA"/container_redis.json --pod "$pod_id" --name ctr1 --label "a=b" --label "c=d" --label "e=f"
echo "$output" echo "$output"
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
ctr1_id="$output" ctr1_id="$output"
run ocic ctr list --label "tier=backend" --quiet run ocic ctr create --config "$TESTDATA"/container_redis.json --pod "$pod_id" --name ctr2 --label "a=b" --label "c=d"
echo "$output"
[ "$status" -eq 0 ]
ctr2_id="$output"
run ocic ctr create --config "$TESTDATA"/container_redis.json --pod "$pod_id" --name ctr3 --label "a=b"
echo "$output"
[ "$status" -eq 0 ]
ctr3_id="$output"
run ocic ctr list --label "tier=backend" --label "a=b" --label "c=d" --label "e=f" --quiet
echo "$output" echo "$output"
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "$output" != "" ]] [[ "$output" != "" ]]
@ -264,6 +272,19 @@ function teardown() {
echo "$output" echo "$output"
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "$output" == "" ]] [[ "$output" == "" ]]
run ocic ctr list --label "a=b" --label "c=d" --quiet
echo "$output"
[ "$status" -eq 0 ]
[[ "$output" != "" ]]
[[ "$output" =~ "$ctr1_id" ]]
[[ "$output" =~ "$ctr2_id" ]]
run ocic ctr list --label "a=b" --quiet
echo "$output"
[ "$status" -eq 0 ]
[[ "$output" != "" ]]
[[ "$output" =~ "$ctr1_id" ]]
[[ "$output" =~ "$ctr2_id" ]]
[[ "$output" =~ "$ctr3_id" ]]
run ocic pod remove --id "$pod_id" run ocic pod remove --id "$pod_id"
echo "$output" echo "$output"
[ "$status" -eq 0 ] [ "$status" -eq 0 ]