package storage import ( "context" "io" "os" "testing" "time" "github.com/docker/docker/api/types" "github.com/docker/docker/api/types/container" "github.com/docker/docker/client" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" "google.golang.org/api/option" ) const storageEmulator = "gcr.io/cloud-devrel-public-resources/storage-testbench" func TestGoogleCloudStorage(t *testing.T) { assert := assert.New(t) require := require.New(t) ctx := context.Background() // Set up the Storage Emulator t.Log("Creating storage emulator...") cli, err := client.NewClientWithOpts(client.FromEnv, client.WithAPIVersionNegotiation()) require.NoError(err) emulator, err := setupEmulator(ctx, cli, storageEmulator) require.NoError(err) defer cli.ContainerStop(ctx, emulator.ID, nil) // Run the actual test t.Setenv("STORAGE_EMULATOR_HOST", "localhost:9000") bucketName := "test-bucket" projectName := "test-project" t.Log("Running test...") ctx, cancel := context.WithTimeout(context.Background(), time.Second*50) defer cancel() storage, err := NewGoogleCloudStorage(ctx, projectName, bucketName, nil, option.WithoutAuthentication()) require.NoError(err) testDEK1 := []byte("test DEK") testDEK2 := []byte("more test DEK") // request unset value _, err = storage.Get(ctx, "test:input") assert.Error(err) // test Put method assert.NoError(storage.Put(ctx, "volume01", testDEK1)) assert.NoError(storage.Put(ctx, "volume02", testDEK2)) // make sure values have been set val, err := storage.Get(ctx, "volume01") assert.NoError(err) assert.Equal(testDEK1, val) val, err = storage.Get(ctx, "volume02") assert.NoError(err) assert.Equal(testDEK2, val) _, err = storage.Get(ctx, "invalid:key") assert.Error(err) assert.ErrorIs(err, ErrDEKUnset) } func setupEmulator(ctx context.Context, cli *client.Client, imageName string) (container.ContainerCreateCreatedBody, error) { reader, err := cli.ImagePull(ctx, imageName, types.ImagePullOptions{}) if err != nil { return container.ContainerCreateCreatedBody{}, err } if _, err := io.Copy(os.Stdout, reader); err != nil { return container.ContainerCreateCreatedBody{}, err } if err := reader.Close(); err != nil { return container.ContainerCreateCreatedBody{}, err } // the 3 true statements are necessary to attach later to the container log containerConfig := &container.Config{ Image: storageEmulator, AttachStdout: true, AttachStderr: true, Tty: true, } emulator, err := cli.ContainerCreate(ctx, containerConfig, &container.HostConfig{NetworkMode: container.NetworkMode("host"), AutoRemove: true}, nil, nil, "google-cloud-storage-test") if err != nil { return emulator, err } err = cli.ContainerStart(ctx, emulator.ID, types.ContainerStartOptions{}) if err != nil { return emulator, err } logs, err := cli.ContainerLogs(ctx, emulator.ID, types.ContainerLogsOptions{ ShowStdout: true, Follow: true, }) if err != nil { return emulator, err } go io.Copy(os.Stdout, logs) return emulator, nil }