mirror of
https://github.com/kopia/kopia.git
synced 2025-12-23 22:57:50 -05:00
* sharded: plumbed through blob.PutOptions * blob: removed blob.Storage.SetTime() method This was only used for `kopia repo sync-to` and got replaced with an equivalent blob.PutOptions.SetTime, which wehn set to non-zero time will attempt to set the modification time on a file. Since some providers don't support changing modification time, we are able to emulate it using per-blob metadata (on B2, Azure and GCS), sadly S3 is still unsupported, because it does not support returning metadata in list results. Also added PutOptions.GetTime, which when set to not nil, will populate the provided variable with actual time that got assigned to the blob. Added tests that verify that each provider supports GetTime and SetTime according to this spec. * blob: additional test coverage for filesystem storage * blob: added PutBlobAndGetMetadata() helper and used where appropriate * fixed test failures * pr feedback * Update repo/blob/azure/azure_storage.go Co-authored-by: Shikhar Mall <mall.shikhar.in@gmail.com> * Update repo/blob/filesystem/filesystem_storage.go Co-authored-by: Shikhar Mall <mall.shikhar.in@gmail.com> * Update repo/blob/filesystem/filesystem_storage.go Co-authored-by: Shikhar Mall <mall.shikhar.in@gmail.com> * blobtesting: fixed object_locking_map.go * blobtesting: removed SetTime from ObjectLockingMap Co-authored-by: Shikhar Mall <mall.shikhar.in@gmail.com>
24 lines
447 B
Go
24 lines
447 B
Go
package timestampmeta_test
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/kopia/kopia/internal/timestampmeta"
|
|
)
|
|
|
|
var (
|
|
timeValue = time.Date(2020, 1, 2, 3, 4, 5, 0, time.UTC)
|
|
storedValue = "1577934245000000000"
|
|
)
|
|
|
|
func TestToMap(t *testing.T) {
|
|
require.Equal(t, map[string]string{
|
|
"aaa": storedValue,
|
|
}, timestampmeta.ToMap(timeValue, "aaa"))
|
|
|
|
require.Nil(t, timestampmeta.ToMap(time.Time{}, "aaa"))
|
|
}
|