mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
adding message option to the import subcommand
Signed-off-by: Taylor Jones <monitorjbl@gmail.com>
This commit is contained in:
parent
82e2dec06d
commit
936b2c6afe
6 changed files with 70 additions and 6 deletions
|
@ -23,6 +23,7 @@ func (cli *DockerCli) CmdImport(args ...string) error {
|
|||
cmd := Cli.Subcmd("import", []string{"file|URL|- [REPOSITORY[:TAG]]"}, "Create an empty filesystem image and import the contents of the\ntarball (.tar, .tar.gz, .tgz, .bzip, .tar.xz, .txz) into it, then\noptionally tag it.", true)
|
||||
flChanges := opts.NewListOpts(nil)
|
||||
cmd.Var(&flChanges, []string{"c", "-change"}, "Apply Dockerfile instruction to the created image")
|
||||
message := cmd.String([]string{"m", "-message"}, "", "Set commit message for imported image")
|
||||
cmd.Require(flag.Min, 1)
|
||||
|
||||
cmd.ParseFlags(args, true)
|
||||
|
@ -35,6 +36,7 @@ func (cli *DockerCli) CmdImport(args ...string) error {
|
|||
|
||||
v.Set("fromSrc", src)
|
||||
v.Set("repo", repository)
|
||||
v.Set("message", *message)
|
||||
for _, change := range flChanges.GetAll() {
|
||||
v.Add("changes", change)
|
||||
}
|
||||
|
|
|
@ -70,9 +70,10 @@ func (s *Server) postImagesCreate(version version.Version, w http.ResponseWriter
|
|||
}
|
||||
|
||||
var (
|
||||
image = r.Form.Get("fromImage")
|
||||
repo = r.Form.Get("repo")
|
||||
tag = r.Form.Get("tag")
|
||||
image = r.Form.Get("fromImage")
|
||||
repo = r.Form.Get("repo")
|
||||
tag = r.Form.Get("tag")
|
||||
message = r.Form.Get("message")
|
||||
)
|
||||
authEncoded := r.Header.Get("X-Registry-Auth")
|
||||
authConfig := &cliconfig.AuthConfig{}
|
||||
|
@ -126,7 +127,7 @@ func (s *Server) postImagesCreate(version version.Version, w http.ResponseWriter
|
|||
return err
|
||||
}
|
||||
|
||||
err = s.daemon.Repositories().Import(src, repo, tag, r.Body, output, newConfig)
|
||||
err = s.daemon.Repositories().Import(src, repo, tag, message, r.Body, output, newConfig)
|
||||
}
|
||||
if err != nil {
|
||||
if !output.Flushed() {
|
||||
|
|
|
@ -18,6 +18,7 @@ weight=1
|
|||
optionally tag it.
|
||||
|
||||
-c, --change=[] Apply specified Dockerfile instructions while importing the image
|
||||
-m, --message= Set commit message for imported image
|
||||
|
||||
You can specify a `URL` or `-` (dash) to take data directly from `STDIN`. The
|
||||
`URL` can point to an archive (.tar, .tar.gz, .tgz, .bzip, .tar.xz, or .txz)
|
||||
|
@ -46,6 +47,10 @@ Import to docker via pipe and `STDIN`.
|
|||
|
||||
$ cat exampleimage.tgz | docker import - exampleimagelocal:new
|
||||
|
||||
Import with a commit message
|
||||
|
||||
$ cat exampleimage.tgz | docker import --message "New image imported from tarball" - exampleimagelocal:new
|
||||
|
||||
Import to docker from a local archive.
|
||||
|
||||
$ docker import /path/to/exampleimage.tgz
|
||||
|
|
|
@ -16,7 +16,7 @@ import (
|
|||
// inConfig (if src is "-"), or from a URI specified in src. Progress output is
|
||||
// written to outStream. Repository and tag names can optionally be given in
|
||||
// the repo and tag arguments, respectively.
|
||||
func (s *TagStore) Import(src string, repo string, tag string, inConfig io.ReadCloser, outStream io.Writer, containerConfig *runconfig.Config) error {
|
||||
func (s *TagStore) Import(src string, repo string, tag string, msg string, inConfig io.ReadCloser, outStream io.Writer, containerConfig *runconfig.Config) error {
|
||||
var (
|
||||
sf = streamformatter.NewJSONStreamFormatter()
|
||||
archive io.ReadCloser
|
||||
|
@ -54,7 +54,11 @@ func (s *TagStore) Import(src string, repo string, tag string, inConfig io.ReadC
|
|||
}
|
||||
|
||||
defer archive.Close()
|
||||
img, err := s.graph.Create(archive, "", "", "Imported from "+src, "", nil, containerConfig)
|
||||
if len(msg) == 0 {
|
||||
msg = "Imported from " + src
|
||||
}
|
||||
|
||||
img, err := s.graph.Create(archive, "", "", msg, "", nil, containerConfig)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
|
|
@ -5,6 +5,7 @@ import (
|
|||
"io/ioutil"
|
||||
"os"
|
||||
"os/exec"
|
||||
"regexp"
|
||||
"strings"
|
||||
|
||||
"github.com/go-check/check"
|
||||
|
@ -72,6 +73,49 @@ func (s *DockerSuite) TestImportFile(c *check.C) {
|
|||
}
|
||||
}
|
||||
|
||||
func (s *DockerSuite) TestImportFileWithMessage(c *check.C) {
|
||||
dockerCmd(c, "run", "--name", "test-import", "busybox", "true")
|
||||
|
||||
temporaryFile, err := ioutil.TempFile("", "exportImportTest")
|
||||
if err != nil {
|
||||
c.Fatal("failed to create temporary file", "", err)
|
||||
}
|
||||
defer os.Remove(temporaryFile.Name())
|
||||
|
||||
runCmd := exec.Command(dockerBinary, "export", "test-import")
|
||||
runCmd.Stdout = bufio.NewWriter(temporaryFile)
|
||||
|
||||
_, err = runCommand(runCmd)
|
||||
if err != nil {
|
||||
c.Fatal("failed to export a container", err)
|
||||
}
|
||||
|
||||
message := "Testing commit message"
|
||||
out, _ := dockerCmd(c, "import", "-m", message, temporaryFile.Name())
|
||||
if n := strings.Count(out, "\n"); n != 1 {
|
||||
c.Fatalf("display is messed up: %d '\\n' instead of 1:\n%s", n, out)
|
||||
}
|
||||
image := strings.TrimSpace(out)
|
||||
|
||||
out, _ = dockerCmd(c, "history", image)
|
||||
split := strings.Split(out, "\n")
|
||||
|
||||
if len(split) != 3 {
|
||||
c.Fatalf("expected 3 lines from image history, got %d", len(split))
|
||||
}
|
||||
r := regexp.MustCompile("[\\s]{2,}")
|
||||
split = r.Split(split[1], -1)
|
||||
|
||||
if message != split[3] {
|
||||
c.Fatalf("expected %s in commit message, got %s", message, split[3])
|
||||
}
|
||||
|
||||
out, _ = dockerCmd(c, "run", "--rm", image, "true")
|
||||
if out != "" {
|
||||
c.Fatalf("command output should've been nothing, was %q", out)
|
||||
}
|
||||
}
|
||||
|
||||
func (s *DockerSuite) TestImportFileNonExistentFile(c *check.C) {
|
||||
_, exitCode, err := dockerCmdWithError("import", "example.com/myImage.tar")
|
||||
if exitCode == 0 || err == nil {
|
||||
|
|
|
@ -7,6 +7,7 @@ docker-import - Create an empty filesystem image and import the contents of the
|
|||
# SYNOPSIS
|
||||
**docker import**
|
||||
[**-c**|**--change**[= []**]]
|
||||
[**-m**|**--message**[=*MESSAGE*]]
|
||||
[**--help**]
|
||||
file|URL|- [REPOSITORY[:TAG]]
|
||||
|
||||
|
@ -15,6 +16,9 @@ file|URL|- [REPOSITORY[:TAG]]
|
|||
Apply specified Dockerfile instructions while importing the image
|
||||
Supported Dockerfile instructions: `CMD`|`ENTRYPOINT`|`ENV`|`EXPOSE`|`ONBUILD`|`USER`|`VOLUME`|`WORKDIR`
|
||||
|
||||
**-m**, **--message**=""
|
||||
Set commit message for imported image
|
||||
|
||||
# DESCRIPTION
|
||||
Create a new filesystem image from the contents of a tarball (`.tar`,
|
||||
`.tar.gz`, `.tgz`, `.bzip`, `.tar.xz`, `.txz`) into it, then optionally tag it.
|
||||
|
@ -35,6 +39,10 @@ Import to docker via pipe and stdin:
|
|||
|
||||
# cat exampleimage.tgz | docker import - example/imagelocal
|
||||
|
||||
Import with a commit message
|
||||
|
||||
# cat exampleimage.tgz | docker import --message "New image imported from tarball" - exampleimagelocal:new
|
||||
|
||||
Import to a Docker image from a local file.
|
||||
|
||||
# docker import /path/to/exampleimage.tgz
|
||||
|
|
Loading…
Reference in a new issue