Merge pull request #118 from mrunalp/ctr_name

Allow overriding the container name in the config
This commit is contained in:
Antonio Murdaca 2016-10-07 20:49:39 +02:00 committed by GitHub
commit 0cf8daa786

View file

@ -35,6 +35,11 @@ var createContainerCommand = cli.Command{
Value: "config.json", Value: "config.json",
Usage: "the path of a container config file", Usage: "the path of a container config file",
}, },
cli.StringFlag{
Name: "name",
Value: "",
Usage: "the name of 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.
@ -49,7 +54,7 @@ var createContainerCommand = cli.Command{
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")
} }
// Test RuntimeServiceClient.CreateContainer // Test RuntimeServiceClient.CreateContainer
err = CreateContainer(client, context.String("pod"), context.String("config")) err = CreateContainer(client, context.String("pod"), context.String("config"), context.String("name"))
if err != nil { if err != nil {
return fmt.Errorf("Creating container failed: %v", err) return fmt.Errorf("Creating container failed: %v", err)
} }
@ -187,12 +192,17 @@ 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) error { func CreateContainer(client pb.RuntimeServiceClient, sandbox string, path string, name string) error {
config, err := loadContainerConfig(path) config, err := loadContainerConfig(path)
if err != nil { if err != nil {
return err return err
} }
// Override the name by the one specified through CLI
if name != "" {
config.Metadata.Name = &name
}
r, err := client.CreateContainer(context.Background(), &pb.CreateContainerRequest{ r, err := client.CreateContainer(context.Background(), &pb.CreateContainerRequest{
PodSandboxId: &sandbox, PodSandboxId: &sandbox,
Config: config, Config: config,