blob: 933ffb40e142f5484cb66bec2eac8d66bc9c710d [file] [log] [blame]
// 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.ChangeMessage;
import com.google.gerrit.entities.PatchSet;
import com.google.gerrit.proto.Entities;
import com.google.gerrit.proto.testing.SerializedClassSubject;
import com.google.protobuf.Parser;
import java.lang.reflect.Type;
import java.sql.Timestamp;
import org.junit.Test;
public class ChangeMessageProtoConverterTest {
private final ChangeMessageProtoConverter changeMessageProtoConverter =
ChangeMessageProtoConverter.INSTANCE;
@Test
public void allValuesConvertedToProto() {
ChangeMessage changeMessage =
new ChangeMessage(
ChangeMessage.key(Change.id(543), "change-message-21"),
Account.id(63),
new Timestamp(9876543),
PatchSet.id(Change.id(34), 13));
changeMessage.setMessage("This is a change message.");
changeMessage.setTag("An arbitrary tag.");
changeMessage.setRealAuthor(Account.id(10003));
Entities.ChangeMessage proto = changeMessageProtoConverter.toProto(changeMessage);
Entities.ChangeMessage expectedProto =
Entities.ChangeMessage.newBuilder()
.setKey(
Entities.ChangeMessage_Key.newBuilder()
.setChangeId(Entities.Change_Id.newBuilder().setId(543))
.setUuid("change-message-21"))
.setAuthorId(Entities.Account_Id.newBuilder().setId(63))
.setWrittenOn(9876543)
.setMessage("This is a change message.")
.setPatchset(
Entities.PatchSet_Id.newBuilder()
.setChangeId(Entities.Change_Id.newBuilder().setId(34))
.setId(13))
.setTag("An arbitrary tag.")
.setRealAuthor(Entities.Account_Id.newBuilder().setId(10003))
.build();
assertThat(proto).isEqualTo(expectedProto);
}
@Test
public void mainValuesConvertedToProto() {
ChangeMessage changeMessage =
new ChangeMessage(
ChangeMessage.key(Change.id(543), "change-message-21"),
Account.id(63),
new Timestamp(9876543),
PatchSet.id(Change.id(34), 13));
Entities.ChangeMessage proto = changeMessageProtoConverter.toProto(changeMessage);
Entities.ChangeMessage expectedProto =
Entities.ChangeMessage.newBuilder()
.setKey(
Entities.ChangeMessage_Key.newBuilder()
.setChangeId(Entities.Change_Id.newBuilder().setId(543))
.setUuid("change-message-21"))
.setAuthorId(Entities.Account_Id.newBuilder().setId(63))
.setWrittenOn(9876543)
.setPatchset(
Entities.PatchSet_Id.newBuilder()
.setChangeId(Entities.Change_Id.newBuilder().setId(34))
.setId(13))
.build();
assertThat(proto).isEqualTo(expectedProto);
}
// This test documents a special behavior which is necessary to ensure binary compatibility.
@Test
public void realAuthorIsNotAutomaticallySetToAuthorWhenConvertedToProto() {
ChangeMessage changeMessage =
new ChangeMessage(
ChangeMessage.key(Change.id(543), "change-message-21"), Account.id(63), null, null);
Entities.ChangeMessage proto = changeMessageProtoConverter.toProto(changeMessage);
Entities.ChangeMessage expectedProto =
Entities.ChangeMessage.newBuilder()
.setKey(
Entities.ChangeMessage_Key.newBuilder()
.setChangeId(Entities.Change_Id.newBuilder().setId(543))
.setUuid("change-message-21"))
.setAuthorId(Entities.Account_Id.newBuilder().setId(63))
.build();
assertThat(proto).isEqualTo(expectedProto);
}
@Test
public void mandatoryValuesConvertedToProto() {
// writtenOn may not be null according to the column definition but it's optional for the
// protobuf definition. -> assume as optional and hence test null
ChangeMessage changeMessage =
new ChangeMessage(ChangeMessage.key(Change.id(543), "change-message-21"), null, null, null);
Entities.ChangeMessage proto = changeMessageProtoConverter.toProto(changeMessage);
Entities.ChangeMessage expectedProto =
Entities.ChangeMessage.newBuilder()
.setKey(
Entities.ChangeMessage_Key.newBuilder()
.setChangeId(Entities.Change_Id.newBuilder().setId(543))
.setUuid("change-message-21"))
.build();
assertThat(proto).isEqualTo(expectedProto);
}
@Test
public void allValuesConvertedToProtoAndBackAgain() {
ChangeMessage changeMessage =
new ChangeMessage(
ChangeMessage.key(Change.id(543), "change-message-21"),
Account.id(63),
new Timestamp(9876543),
PatchSet.id(Change.id(34), 13));
changeMessage.setMessage("This is a change message.");
changeMessage.setTag("An arbitrary tag.");
changeMessage.setRealAuthor(Account.id(10003));
ChangeMessage convertedChangeMessage =
changeMessageProtoConverter.fromProto(changeMessageProtoConverter.toProto(changeMessage));
assertThat(convertedChangeMessage).isEqualTo(changeMessage);
}
@Test
public void mainValuesConvertedToProtoAndBackAgain() {
ChangeMessage changeMessage =
new ChangeMessage(
ChangeMessage.key(Change.id(543), "change-message-21"),
Account.id(63),
new Timestamp(9876543),
PatchSet.id(Change.id(34), 13));
ChangeMessage convertedChangeMessage =
changeMessageProtoConverter.fromProto(changeMessageProtoConverter.toProto(changeMessage));
assertThat(convertedChangeMessage).isEqualTo(changeMessage);
}
@Test
public void mandatoryValuesConvertedToProtoAndBackAgain() {
ChangeMessage changeMessage =
new ChangeMessage(ChangeMessage.key(Change.id(543), "change-message-21"), null, null, null);
ChangeMessage convertedChangeMessage =
changeMessageProtoConverter.fromProto(changeMessageProtoConverter.toProto(changeMessage));
assertThat(convertedChangeMessage).isEqualTo(changeMessage);
}
@Test
public void protoCanBeParsedFromBytes() throws Exception {
Entities.ChangeMessage proto =
Entities.ChangeMessage.newBuilder()
.setKey(
Entities.ChangeMessage_Key.newBuilder()
.setChangeId(Entities.Change_Id.newBuilder().setId(543))
.setUuid("change-message-21"))
.build();
byte[] bytes = proto.toByteArray();
Parser<Entities.ChangeMessage> parser = changeMessageProtoConverter.getParser();
Entities.ChangeMessage parsedProto = parser.parseFrom(bytes);
assertThat(parsedProto).isEqualTo(proto);
}
/** See {@link SerializedClassSubject} for background and what to do if this test fails. */
@Test
public void fieldsExistAsExpected() {
assertThatSerializedClass(ChangeMessage.class)
.hasFields(
ImmutableMap.<String, Type>builder()
.put("key", ChangeMessage.Key.class)
.put("author", Account.Id.class)
.put("writtenOn", Timestamp.class)
.put("message", String.class)
.put("patchset", PatchSet.Id.class)
.put("tag", String.class)
.put("realAuthor", Account.Id.class)
.build());
}
}