diff --git a/internal/provider/archive-dir.zip b/internal/provider/archive-dir.zip index b88214af..448134cf 100644 Binary files a/internal/provider/archive-dir.zip and b/internal/provider/archive-dir.zip differ diff --git a/internal/provider/archive-file.zip b/internal/provider/archive-file.zip index b2a7ea85..34a7e1ae 100644 Binary files a/internal/provider/archive-file.zip and b/internal/provider/archive-file.zip differ diff --git a/internal/provider/zip_archiver.go b/internal/provider/zip_archiver.go index 087d0d9f..c0888eb7 100644 --- a/internal/provider/zip_archiver.go +++ b/internal/provider/zip_archiver.go @@ -61,8 +61,8 @@ func (a *ZipArchiver) ArchiveFile(infilename string) error { } fh.Name = filepath.ToSlash(fi.Name()) fh.Method = zip.Deflate - // fh.Modified alone isn't enough when using a zero value - fh.SetModTime(time.Time{}) + oldestZipSupportedModTime, _ := time.Parse(time.RFC3339, "1980-01-01T00:00:00+00:00") + fh.Modified = oldestZipSupportedModTime if a.outputFileMode != "" { filemode, err := strconv.ParseUint(a.outputFileMode, 0, 32) @@ -144,8 +144,8 @@ func (a *ZipArchiver) ArchiveDir(indirname string, excludes []string) error { } fh.Name = filepath.ToSlash(relname) fh.Method = zip.Deflate - // fh.Modified alone isn't enough when using a zero value - fh.SetModTime(time.Time{}) + oldestZipSupportedModTime, _ := time.Parse(time.RFC3339, "1980-01-01T00:00:00+00:00") + fh.Modified = oldestZipSupportedModTime if a.outputFileMode != "" { filemode, err := strconv.ParseUint(a.outputFileMode, 0, 32) diff --git a/internal/provider/zip_archiver_test.go b/internal/provider/zip_archiver_test.go index 2c5b0133..8da48f5c 100644 --- a/internal/provider/zip_archiver_test.go +++ b/internal/provider/zip_archiver_test.go @@ -94,6 +94,9 @@ func TestZipArchiver_FileModified(t *testing.T) { if !bytes.Equal(expectedContents, actualContents) { t.Fatalf("zip contents do not match, potentially a modified time issue") } + + oldestZipSupportedModTime, _ := time.Parse(time.RFC3339, "1980-01-01T00:00:00+00:00") + ensureModifiedtimes(t, zipFilePath, oldestZipSupportedModTime) } func TestZipArchiver_Dir(t *testing.T) { @@ -153,6 +156,20 @@ func TestZipArchiver_Multiple(t *testing.T) { ensureContents(t, zipfilepath, content) } +func ensureModifiedtimes(t *testing.T, zipfilepath string, modifiedTime time.Time) { + r, err := zip.OpenReader(zipfilepath) + if err != nil { + t.Fatalf("could not open zip file: %s", err) + } + defer r.Close() + + for _, cf := range r.File { + if !cf.Modified.Equal(modifiedTime) { + t.Fatalf("Modified time does not match, got %s, want %s", cf.Modified, modifiedTime) + } + } +} + func ensureContents(t *testing.T, zipfilepath string, wants map[string][]byte) { t.Helper() r, err := zip.OpenReader(zipfilepath)