| // Copyright (C) 2018 The Android Open Source Project |
| // |
| // 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 com.google.gerrit.entities.converter; |
| |
| import static com.google.common.truth.Truth.assertThat; |
| import static com.google.common.truth.extensions.proto.ProtoTruth.assertThat; |
| import static com.google.gerrit.proto.testing.SerializedClassSubject.assertThatSerializedClass; |
| |
| import com.google.common.collect.ImmutableMap; |
| import com.google.gerrit.entities.Account; |
| import com.google.gerrit.entities.Change; |
| import com.google.gerrit.entities.LabelId; |
| import com.google.gerrit.entities.PatchSet; |
| import com.google.gerrit.entities.PatchSetApproval; |
| import com.google.gerrit.proto.Entities; |
| import com.google.gerrit.proto.testing.SerializedClassSubject; |
| import com.google.inject.TypeLiteral; |
| import java.lang.reflect.Type; |
| import java.time.Instant; |
| import java.util.Optional; |
| import org.junit.Test; |
| |
| public class PatchSetApprovalProtoConverterTest { |
| private final PatchSetApprovalProtoConverter protoConverter = |
| PatchSetApprovalProtoConverter.INSTANCE; |
| |
| @Test |
| public void allValuesConvertedToProto() { |
| PatchSetApproval patchSetApproval = |
| PatchSetApproval.builder() |
| .key( |
| PatchSetApproval.key( |
| PatchSet.id(Change.id(42), 14), Account.id(100013), LabelId.create("label-8"))) |
| .uuid(Optional.of(PatchSetApproval.uuid("577fb248e474018276351785930358ec0450e9f7"))) |
| .value(456) |
| .granted(Instant.ofEpochMilli(987654L)) |
| .tag("tag-21") |
| .realAccountId(Account.id(612)) |
| .postSubmit(true) |
| .copied(true) |
| .build(); |
| |
| Entities.PatchSetApproval proto = protoConverter.toProto(patchSetApproval); |
| |
| Entities.PatchSetApproval expectedProto = |
| Entities.PatchSetApproval.newBuilder() |
| .setKey( |
| Entities.PatchSetApproval_Key.newBuilder() |
| .setPatchSetId( |
| Entities.PatchSet_Id.newBuilder() |
| .setChangeId(Entities.Change_Id.newBuilder().setId(42)) |
| .setId(14)) |
| .setAccountId(Entities.Account_Id.newBuilder().setId(100013)) |
| .setLabelId(Entities.LabelId.newBuilder().setId("label-8"))) |
| .setUuid("577fb248e474018276351785930358ec0450e9f7") |
| .setValue(456) |
| .setGranted(987654L) |
| .setTag("tag-21") |
| .setRealAccountId(Entities.Account_Id.newBuilder().setId(612)) |
| .setPostSubmit(true) |
| .setCopied(true) |
| .build(); |
| assertThat(proto).isEqualTo(expectedProto); |
| } |
| |
| @Test |
| public void mandatoryValuesConvertedToProto() { |
| PatchSetApproval patchSetApproval = |
| PatchSetApproval.builder() |
| .key( |
| PatchSetApproval.key( |
| PatchSet.id(Change.id(42), 14), Account.id(100013), LabelId.create("label-8"))) |
| .value(456) |
| .granted(Instant.ofEpochMilli(987654L)) |
| .build(); |
| |
| Entities.PatchSetApproval proto = protoConverter.toProto(patchSetApproval); |
| |
| Entities.PatchSetApproval expectedProto = |
| Entities.PatchSetApproval.newBuilder() |
| .setKey( |
| Entities.PatchSetApproval_Key.newBuilder() |
| .setPatchSetId( |
| Entities.PatchSet_Id.newBuilder() |
| .setChangeId(Entities.Change_Id.newBuilder().setId(42)) |
| .setId(14)) |
| .setAccountId(Entities.Account_Id.newBuilder().setId(100013)) |
| .setLabelId(Entities.LabelId.newBuilder().setId("label-8"))) |
| .setValue(456) |
| .setGranted(987654L) |
| // This value can't be unset when our entity class is given. |
| .setPostSubmit(false) |
| .setCopied(false) |
| .build(); |
| assertThat(proto).isEqualTo(expectedProto); |
| } |
| |
| @Test |
| public void allValuesConvertedToProtoAndBackAgain() { |
| PatchSetApproval patchSetApproval = |
| PatchSetApproval.builder() |
| .key( |
| PatchSetApproval.key( |
| PatchSet.id(Change.id(42), 14), Account.id(100013), LabelId.create("label-8"))) |
| .uuid(Optional.of(PatchSetApproval.uuid("577fb248e474018276351785930358ec0450e9f7"))) |
| .value(456) |
| .granted(Instant.ofEpochMilli(987654L)) |
| .tag("tag-21") |
| .realAccountId(Account.id(612)) |
| .postSubmit(true) |
| .copied(true) |
| .build(); |
| |
| PatchSetApproval convertedPatchSetApproval = |
| protoConverter.fromProto(protoConverter.toProto(patchSetApproval)); |
| assertThat(convertedPatchSetApproval).isEqualTo(patchSetApproval); |
| } |
| |
| @Test |
| public void mandatoryValuesConvertedToProtoAndBackAgain() { |
| PatchSetApproval patchSetApproval = |
| PatchSetApproval.builder() |
| .key( |
| PatchSetApproval.key( |
| PatchSet.id(Change.id(42), 14), Account.id(100013), LabelId.create("label-8"))) |
| .value(456) |
| .granted(Instant.ofEpochMilli(987654L)) |
| .build(); |
| |
| PatchSetApproval convertedPatchSetApproval = |
| protoConverter.fromProto(protoConverter.toProto(patchSetApproval)); |
| assertThat(convertedPatchSetApproval).isEqualTo(patchSetApproval); |
| } |
| |
| // We need this special test as some values are only optional in the protobuf definition but can |
| // never be unset in our entity object. |
| @Test |
| public void protoWithOnlyRequiredValuesCanBeConvertedBack() { |
| Entities.PatchSetApproval proto = |
| Entities.PatchSetApproval.newBuilder() |
| .setKey( |
| Entities.PatchSetApproval_Key.newBuilder() |
| .setPatchSetId( |
| Entities.PatchSet_Id.newBuilder() |
| .setChangeId(Entities.Change_Id.newBuilder().setId(42)) |
| .setId(14)) |
| .setAccountId(Entities.Account_Id.newBuilder().setId(100013)) |
| .setLabelId(Entities.LabelId.newBuilder().setId("label-8"))) |
| .build(); |
| PatchSetApproval patchSetApproval = protoConverter.fromProto(proto); |
| |
| assertThat(patchSetApproval.patchSetId()).isEqualTo(PatchSet.id(Change.id(42), 14)); |
| assertThat(patchSetApproval.accountId()).isEqualTo(Account.id(100013)); |
| assertThat(patchSetApproval.labelId()).isEqualTo(LabelId.create("label-8")); |
| // Default values for unset protobuf fields which can't be unset in the entity object. |
| assertThat(patchSetApproval.value()).isEqualTo(0); |
| assertThat(patchSetApproval.granted()).isEqualTo(Instant.EPOCH); |
| assertThat(patchSetApproval.postSubmit()).isEqualTo(false); |
| assertThat(patchSetApproval.copied()).isEqualTo(false); |
| } |
| |
| /** See {@link SerializedClassSubject} for background and what to do if this test fails. */ |
| @Test |
| public void fieldsExistAsExpected() { |
| assertThatSerializedClass(PatchSetApproval.class) |
| .hasAutoValueMethods( |
| ImmutableMap.<String, Type>builder() |
| .put("key", PatchSetApproval.Key.class) |
| .put("uuid", new TypeLiteral<Optional<PatchSetApproval.UUID>>() {}.getType()) |
| .put("value", short.class) |
| .put("granted", Instant.class) |
| .put("tag", new TypeLiteral<Optional<String>>() {}.getType()) |
| .put("realAccountId", Account.Id.class) |
| .put("postSubmit", boolean.class) |
| .put("copied", boolean.class) |
| .put("toBuilder", PatchSetApproval.Builder.class) |
| .build()); |
| } |
| } |