Use io.Copy when creating files

This commit is contained in:
Priya Wadhwa 2018-03-19 16:37:12 -07:00
parent 5ba9510ee8
commit b3ec877b60
No known key found for this signature in database
GPG Key ID: 0D0DAFD8F7AA73AE
3 changed files with 13 additions and 7 deletions

0
integration_tests/context/foo Normal file → Executable file
View File

View File

@ -21,7 +21,6 @@ import (
"github.com/containers/image/manifest"
"github.com/docker/docker/builder/dockerfile/instructions"
"github.com/sirupsen/logrus"
"io/ioutil"
"os"
"path/filepath"
"strings"
@ -65,11 +64,12 @@ func (c *CopyCommand) ExecuteCommand(config *manifest.Schema2Config) error {
} else {
// ... Else, we want to copy over a file
logrus.Infof("Copying file %s to %s", file, destPath)
contents, err := ioutil.ReadFile(filepath.Join(c.buildcontext, file))
srcFile, err := os.Open(filepath.Join(c.buildcontext, file))
if err != nil {
return err
}
if err := util.CreateFile(destPath, contents, fi.Mode()); err != nil {
defer srcFile.Close()
if err := util.CreateFile(destPath, srcFile, fi.Mode()); err != nil {
return err
}
}

View File

@ -23,7 +23,6 @@ import (
"github.com/containers/image/docker"
"github.com/sirupsen/logrus"
"io"
"io/ioutil"
"os"
"path/filepath"
"strings"
@ -124,8 +123,8 @@ func FilepathExists(path string) bool {
return !os.IsNotExist(err)
}
// CreateFile creates a file at path with contents specified
func CreateFile(path string, contents []byte, perm os.FileMode) error {
// CreateFile creates a file at path and copies over contents from the reader
func CreateFile(path string, reader io.Reader, perm os.FileMode) error {
// Create directory path if it doesn't exist
baseDir := filepath.Dir(path)
if _, err := os.Stat(baseDir); os.IsNotExist(err) {
@ -134,5 +133,12 @@ func CreateFile(path string, contents []byte, perm os.FileMode) error {
return err
}
}
return ioutil.WriteFile(path, contents, perm)
dest, err := os.Create(path)
if err != nil {
return err
}
if _, err := io.Copy(dest, reader); err != nil {
return err
}
return dest.Chmod(perm)
}