175 lines
4.7 KiB
Go
175 lines
4.7 KiB
Go
/*
|
|
Copyright 2018 Google LLC
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package util
|
|
|
|
import (
|
|
"archive/tar"
|
|
"bytes"
|
|
"compress/gzip"
|
|
"fmt"
|
|
"io"
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/GoogleContainerTools/kaniko/testutil"
|
|
)
|
|
|
|
var regularFiles = []string{"file", "file.tar", "file.tar.gz"}
|
|
var uncompressedTars = []string{"uncompressed", "uncompressed.tar"}
|
|
var compressedTars = []string{"compressed", "compressed.tar.gz"}
|
|
|
|
func Test_IsLocalTarArchive(t *testing.T) {
|
|
testDir := t.TempDir()
|
|
if err := setUpFilesAndTars(testDir); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
// Test we get the correct result for regular files
|
|
for _, regularFile := range regularFiles {
|
|
isTarArchive := IsFileLocalTarArchive(filepath.Join(testDir, regularFile))
|
|
testutil.CheckErrorAndDeepEqual(t, false, nil, false, isTarArchive)
|
|
}
|
|
// Test we get the correct result for uncompressed tars
|
|
for _, uncompressedTar := range uncompressedTars {
|
|
isTarArchive := IsFileLocalTarArchive(filepath.Join(testDir, uncompressedTar))
|
|
testutil.CheckErrorAndDeepEqual(t, false, nil, true, isTarArchive)
|
|
}
|
|
// Test we get the correct result for compressed tars
|
|
for _, compressedTar := range compressedTars {
|
|
isTarArchive := IsFileLocalTarArchive(filepath.Join(testDir, compressedTar))
|
|
testutil.CheckErrorAndDeepEqual(t, false, nil, true, isTarArchive)
|
|
}
|
|
}
|
|
|
|
func Test_AddFileToTar(t *testing.T) {
|
|
testDir := t.TempDir()
|
|
|
|
path := filepath.Join(testDir, regularFiles[0])
|
|
if err := os.WriteFile(path, []byte("hello"), os.ModePerm); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
// use a pre-determined time with non-zero microseconds to avoid flakiness
|
|
mtime := time.UnixMicro(1635533172891395)
|
|
if err := os.Chtimes(path, mtime, mtime); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
buf := new(bytes.Buffer)
|
|
tarw := NewTar(buf)
|
|
if err := tarw.AddFileToTar(path); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
tarw.Close()
|
|
|
|
// Check that the mtime is correct (#1808)
|
|
tarReader := tar.NewReader(buf)
|
|
hdr, err := tarReader.Next()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
testutil.CheckDeepEqual(t, mtime, hdr.ModTime)
|
|
}
|
|
|
|
func setUpFilesAndTars(testDir string) error {
|
|
regularFilesAndContents := map[string]string{
|
|
regularFiles[0]: "",
|
|
regularFiles[1]: "something",
|
|
regularFiles[2]: "here",
|
|
}
|
|
if err := testutil.SetupFiles(testDir, regularFilesAndContents); err != nil {
|
|
return err
|
|
}
|
|
|
|
for _, uncompressedTar := range uncompressedTars {
|
|
tarFile, err := os.Create(filepath.Join(testDir, uncompressedTar))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if err := createTar(testDir, tarFile); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
for _, compressedTar := range compressedTars {
|
|
tarFile, err := os.Create(filepath.Join(testDir, compressedTar))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
gzr := gzip.NewWriter(tarFile)
|
|
if err := createTar(testDir, gzr); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func createTar(testdir string, writer io.Writer) error {
|
|
t := NewTar(writer)
|
|
defer t.Close()
|
|
for _, regFile := range regularFiles {
|
|
filePath := filepath.Join(testdir, regFile)
|
|
if err := t.AddFileToTar(filePath); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func Test_CreateTarballOfDirectory(t *testing.T) {
|
|
tmpDir := t.TempDir()
|
|
wantErr := false
|
|
createFilesInTempDir(t, tmpDir)
|
|
f := &bytes.Buffer{}
|
|
err := CreateTarballOfDirectory(tmpDir, f)
|
|
testutil.CheckError(t, wantErr, err)
|
|
|
|
extracedFilesDir := filepath.Join(tmpDir, "extracted")
|
|
err = os.Mkdir(extracedFilesDir, 0755)
|
|
if err != nil {
|
|
t.Error(err)
|
|
return
|
|
}
|
|
files, err := UnTar(f, extracedFilesDir)
|
|
testutil.CheckError(t, wantErr, err)
|
|
for _, filePath := range files {
|
|
fileInfo, err := os.Lstat(filePath)
|
|
testutil.CheckError(t, wantErr, err)
|
|
if fileInfo.IsDir() {
|
|
// skip directory
|
|
continue
|
|
}
|
|
file, err := os.Open(filePath)
|
|
testutil.CheckError(t, wantErr, err)
|
|
body, err := io.ReadAll(file)
|
|
testutil.CheckError(t, wantErr, err)
|
|
index := filepath.Base(filePath)
|
|
testutil.CheckDeepEqual(t, string(body), fmt.Sprintf("hello from %s\n", index))
|
|
}
|
|
}
|
|
|
|
func createFilesInTempDir(t *testing.T, tmpDir string) {
|
|
for i := 0; i < 2; i++ {
|
|
fName := filepath.Join(tmpDir, fmt.Sprint(i))
|
|
content := fmt.Sprintf("hello from %d\n", i)
|
|
if err := os.WriteFile(fName, []byte(content), 0666); err != nil {
|
|
t.Error(err)
|
|
return
|
|
}
|
|
}
|
|
}
|