Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -564,7 +564,11 @@ public Blob update(BlobInfo blobInfo, BlobTargetOption... options) {
} else {
StorageObject tmp = codecs.blobInfo().encode(updated);
StorageObject pb = new StorageObject();
Stream.concat(modifiedFields.stream(), BlobField.REQUIRED_FIELDS.stream())
Stream.of(
modifiedFields.stream(),
BlobField.REQUIRED_FIELDS.stream(),
Stream.of(BlobField.GENERATION))
.flatMap(s -> s) // .flatten()
.map(
f -> {
if (f instanceof NestedNamedField) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@
import java.util.stream.Stream;
import java.util.stream.StreamSupport;
import javax.crypto.spec.SecretKeySpec;
import org.checkerframework.checker.nullness.qual.NonNull;
import org.junit.Test;
import org.junit.runner.RunWith;

Expand Down Expand Up @@ -1582,4 +1583,28 @@ public void testUpdateBlob_noModification() {
Blob gen2 = storage.update(gen1);
assertThat(gen2).isEqualTo(gen1);
}

@Test
public void blob_update() throws Exception {
ImmutableMap<@NonNull String, @NonNull String> meta1 = ImmutableMap.of("k1", "v1");
ImmutableMap<@NonNull String, @NonNull String> meta2 = ImmutableMap.of("k1", "v2");
ImmutableMap<@NonNull String, @NonNull String> meta3 = ImmutableMap.of("k1", "v1", "k2", "n1");

String randomObjectName = generator.randomObjectName();
BlobInfo info1 =
BlobInfo.newBuilder(versionedBucket, randomObjectName).setMetadata(meta1).build();
BlobInfo info2 =
BlobInfo.newBuilder(versionedBucket, randomObjectName).setMetadata(meta2).build();

BlobInfo gen1 = storage.create(info1);
BlobInfo gen2 = storage.create(info2);

BlobInfo update1 = gen1.toBuilder().setMetadata(meta3).build();

BlobInfo gen1_2 = storage.update(update1);

assertAll(
() -> assertThat(gen1_2.getMetadata()).isEqualTo(meta3),
() -> assertThat(gen1_2.getGeneration()).isEqualTo(gen1.getGeneration()));
}
}