Add serializer for NotifyConfig
This commit adds a serializer for the NotifyConfig entitiy. The eventual goal is that we serialize CachedProjectConfig. The entity is too large to be serialized directly, though, so we divide and conquer. This commit moves the AutoValue representation to the entities package to allow the serializer packages to keep its dependencies minimal. Change-Id: I6876624bbe5d99c3ca187984f1214bf2066850fa
This commit is contained in:
@@ -19,6 +19,7 @@ import com.google.common.collect.ImmutableSet;
|
||||
import com.google.common.truth.Truth;
|
||||
import com.google.common.truth.extensions.proto.ProtoTruth;
|
||||
import com.google.gerrit.entities.Account;
|
||||
import com.google.gerrit.entities.NotifyConfig;
|
||||
import com.google.gerrit.entities.Project;
|
||||
import com.google.gerrit.server.cache.proto.Cache;
|
||||
import com.google.gerrit.server.config.CachedPreferences;
|
||||
@@ -103,7 +104,7 @@ public class AccountCacheTest {
|
||||
CachedAccountDetails original =
|
||||
CachedAccountDetails.create(
|
||||
ACCOUNT,
|
||||
ImmutableMap.of(key, ImmutableSet.of(ProjectWatches.NotifyType.ALL_COMMENTS)),
|
||||
ImmutableMap.of(key, ImmutableSet.of(NotifyConfig.NotifyType.ALL_COMMENTS)),
|
||||
CachedPreferences.fromString(""));
|
||||
|
||||
byte[] serialized = SERIALIZER.serialize(original);
|
||||
@@ -127,7 +128,7 @@ public class AccountCacheTest {
|
||||
CachedAccountDetails original =
|
||||
CachedAccountDetails.create(
|
||||
ACCOUNT,
|
||||
ImmutableMap.of(key, ImmutableSet.of(ProjectWatches.NotifyType.ALL_COMMENTS)),
|
||||
ImmutableMap.of(key, ImmutableSet.of(NotifyConfig.NotifyType.ALL_COMMENTS)),
|
||||
CachedPreferences.fromString(""));
|
||||
|
||||
byte[] serialized = SERIALIZER.serialize(original);
|
||||
|
||||
@@ -19,8 +19,8 @@ import static com.google.common.truth.Truth.assertWithMessage;
|
||||
|
||||
import com.google.common.collect.ImmutableSet;
|
||||
import com.google.gerrit.entities.Account;
|
||||
import com.google.gerrit.entities.NotifyConfig.NotifyType;
|
||||
import com.google.gerrit.entities.Project;
|
||||
import com.google.gerrit.server.account.ProjectWatches.NotifyType;
|
||||
import com.google.gerrit.server.account.ProjectWatches.NotifyValue;
|
||||
import com.google.gerrit.server.account.ProjectWatches.ProjectWatchKey;
|
||||
import com.google.gerrit.server.git.ValidationError;
|
||||
|
||||
@@ -20,8 +20,8 @@ import static com.google.gerrit.server.cache.serialize.entities.ContributorAgree
|
||||
|
||||
import com.google.common.collect.ImmutableList;
|
||||
import com.google.gerrit.common.data.ContributorAgreement;
|
||||
import com.google.gerrit.common.data.GroupReference;
|
||||
import com.google.gerrit.common.data.PermissionRule;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import org.junit.Test;
|
||||
|
||||
public class ContributorAgreementSerializerTest {
|
||||
|
||||
@@ -18,8 +18,8 @@ import static com.google.common.truth.Truth.assertThat;
|
||||
import static com.google.gerrit.server.cache.serialize.entities.GroupReferenceSerializer.deserialize;
|
||||
import static com.google.gerrit.server.cache.serialize.entities.GroupReferenceSerializer.serialize;
|
||||
|
||||
import com.google.gerrit.common.data.GroupReference;
|
||||
import com.google.gerrit.entities.AccountGroup;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import org.junit.Test;
|
||||
|
||||
public class GroupReferenceSerializerTest {
|
||||
|
||||
47
javatests/com/google/gerrit/server/cache/serialize/entities/NotifyConfigSerializerTest.java
vendored
Normal file
47
javatests/com/google/gerrit/server/cache/serialize/entities/NotifyConfigSerializerTest.java
vendored
Normal file
@@ -0,0 +1,47 @@
|
||||
// Copyright (C) 2020 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.server.cache.serialize.entities;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
import static com.google.gerrit.server.cache.serialize.entities.NotifyConfigSerializer.deserialize;
|
||||
import static com.google.gerrit.server.cache.serialize.entities.NotifyConfigSerializer.serialize;
|
||||
|
||||
import com.google.common.collect.ImmutableSet;
|
||||
import com.google.gerrit.entities.Address;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import com.google.gerrit.entities.NotifyConfig;
|
||||
import org.junit.Test;
|
||||
|
||||
public class NotifyConfigSerializerTest {
|
||||
@Test
|
||||
public void roundTrip() {
|
||||
NotifyConfig autoValue =
|
||||
NotifyConfig.builder()
|
||||
.setName("foo-bar")
|
||||
.addAddress(Address.create("address@example.com"))
|
||||
.addGroup(GroupReference.create("group-uuid"))
|
||||
.setHeader(NotifyConfig.Header.CC)
|
||||
.setFilter("filter")
|
||||
.setNotify(ImmutableSet.of(NotifyConfig.NotifyType.ALL_COMMENTS))
|
||||
.build();
|
||||
assertThat(deserialize(serialize(autoValue))).isEqualTo(autoValue);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void roundTripWithMinimalValues() {
|
||||
NotifyConfig autoValue = NotifyConfig.builder().setName("foo-bar").build();
|
||||
assertThat(deserialize(serialize(autoValue))).isEqualTo(autoValue);
|
||||
}
|
||||
}
|
||||
@@ -18,8 +18,8 @@ import static com.google.common.truth.Truth.assertThat;
|
||||
import static com.google.gerrit.server.cache.serialize.entities.PermissionRuleSerializer.deserialize;
|
||||
import static com.google.gerrit.server.cache.serialize.entities.PermissionRuleSerializer.serialize;
|
||||
|
||||
import com.google.gerrit.common.data.GroupReference;
|
||||
import com.google.gerrit.common.data.PermissionRule;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import org.junit.Test;
|
||||
|
||||
public class PermissionRuleSerializerTest {
|
||||
|
||||
@@ -18,9 +18,9 @@ import static com.google.common.truth.Truth.assertThat;
|
||||
import static com.google.gerrit.server.cache.serialize.entities.PermissionSerializer.deserialize;
|
||||
import static com.google.gerrit.server.cache.serialize.entities.PermissionSerializer.serialize;
|
||||
|
||||
import com.google.gerrit.common.data.GroupReference;
|
||||
import com.google.gerrit.common.data.Permission;
|
||||
import com.google.gerrit.common.data.PermissionRule;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import org.junit.Test;
|
||||
|
||||
public class PermissionSerializerTest {
|
||||
|
||||
@@ -17,9 +17,9 @@ package com.google.gerrit.server.group.db;
|
||||
import static com.google.gerrit.extensions.common.testing.CommitInfoSubject.assertThat;
|
||||
|
||||
import com.google.gerrit.common.Nullable;
|
||||
import com.google.gerrit.common.data.GroupDescription;
|
||||
import com.google.gerrit.entities.Account;
|
||||
import com.google.gerrit.entities.AccountGroup;
|
||||
import com.google.gerrit.entities.GroupDescription;
|
||||
import com.google.gerrit.entities.RefNames;
|
||||
import com.google.gerrit.extensions.common.CommitInfo;
|
||||
import com.google.gerrit.server.config.AllUsersName;
|
||||
|
||||
@@ -25,9 +25,9 @@ import static org.hamcrest.MatcherAssert.assertThat;
|
||||
import com.google.common.collect.ImmutableSet;
|
||||
import com.google.common.collect.Sets;
|
||||
import com.google.gerrit.common.Nullable;
|
||||
import com.google.gerrit.common.data.GroupDescription;
|
||||
import com.google.gerrit.entities.Account;
|
||||
import com.google.gerrit.entities.AccountGroup;
|
||||
import com.google.gerrit.entities.GroupDescription;
|
||||
import com.google.gerrit.entities.Project;
|
||||
import com.google.gerrit.entities.RefNames;
|
||||
import com.google.gerrit.server.extensions.events.GitReferenceUpdated;
|
||||
|
||||
@@ -25,9 +25,9 @@ import static java.nio.charset.StandardCharsets.UTF_8;
|
||||
import static org.eclipse.jgit.lib.Constants.OBJ_BLOB;
|
||||
|
||||
import com.google.common.collect.ImmutableList;
|
||||
import com.google.gerrit.common.data.GroupReference;
|
||||
import com.google.gerrit.common.data.testing.GroupReferenceSubject;
|
||||
import com.google.gerrit.entities.AccountGroup;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import com.google.gerrit.entities.Project;
|
||||
import com.google.gerrit.entities.RefNames;
|
||||
import com.google.gerrit.exceptions.DuplicateKeyException;
|
||||
|
||||
@@ -28,11 +28,11 @@ import com.google.gerrit.acceptance.testsuite.project.ProjectOperations;
|
||||
import com.google.gerrit.acceptance.testsuite.project.TestProjectUpdate;
|
||||
import com.google.gerrit.common.data.AccessSection;
|
||||
import com.google.gerrit.common.data.GlobalCapability;
|
||||
import com.google.gerrit.common.data.GroupReference;
|
||||
import com.google.gerrit.common.data.Permission;
|
||||
import com.google.gerrit.common.data.PermissionRule;
|
||||
import com.google.gerrit.entities.Account;
|
||||
import com.google.gerrit.entities.AccountGroup;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import com.google.gerrit.entities.Project;
|
||||
import com.google.gerrit.server.account.AccountManager;
|
||||
import com.google.gerrit.server.account.AuthRequest;
|
||||
|
||||
@@ -23,8 +23,8 @@ import static org.mockito.Mockito.mock;
|
||||
import static org.mockito.Mockito.times;
|
||||
import static org.mockito.Mockito.verify;
|
||||
|
||||
import com.google.gerrit.common.data.GroupReference;
|
||||
import com.google.gerrit.entities.AccountGroup;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import com.google.gerrit.entities.Project;
|
||||
import com.google.gerrit.server.git.ValidationError;
|
||||
import java.io.IOException;
|
||||
|
||||
@@ -22,12 +22,12 @@ import com.google.common.collect.ImmutableList;
|
||||
import com.google.common.collect.Iterables;
|
||||
import com.google.gerrit.common.data.AccessSection;
|
||||
import com.google.gerrit.common.data.ContributorAgreement;
|
||||
import com.google.gerrit.common.data.GroupReference;
|
||||
import com.google.gerrit.common.data.LabelType;
|
||||
import com.google.gerrit.common.data.Permission;
|
||||
import com.google.gerrit.common.data.PermissionRule;
|
||||
import com.google.gerrit.entities.AccountGroup;
|
||||
import com.google.gerrit.entities.BranchOrderSection;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import com.google.gerrit.entities.Project;
|
||||
import com.google.gerrit.entities.RefNames;
|
||||
import com.google.gerrit.extensions.client.InheritableBoolean;
|
||||
|
||||
@@ -44,7 +44,6 @@ import com.google.common.truth.ThrowableSubject;
|
||||
import com.google.gerrit.acceptance.config.GerritConfig;
|
||||
import com.google.gerrit.acceptance.testsuite.project.ProjectOperations;
|
||||
import com.google.gerrit.common.Nullable;
|
||||
import com.google.gerrit.common.data.GroupReference;
|
||||
import com.google.gerrit.common.data.LabelType;
|
||||
import com.google.gerrit.common.data.Permission;
|
||||
import com.google.gerrit.common.data.PermissionRule;
|
||||
@@ -52,6 +51,7 @@ import com.google.gerrit.entities.Account;
|
||||
import com.google.gerrit.entities.AccountGroup;
|
||||
import com.google.gerrit.entities.BranchNameKey;
|
||||
import com.google.gerrit.entities.Change;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import com.google.gerrit.entities.Patch;
|
||||
import com.google.gerrit.entities.PatchSet;
|
||||
import com.google.gerrit.entities.Project;
|
||||
|
||||
@@ -23,11 +23,11 @@ import static com.google.gerrit.server.schema.testing.AllProjectsCreatorTestUtil
|
||||
import static com.google.gerrit.truth.ConfigSubject.assertThat;
|
||||
|
||||
import com.google.common.collect.ImmutableList;
|
||||
import com.google.gerrit.common.data.GroupReference;
|
||||
import com.google.gerrit.common.data.LabelType;
|
||||
import com.google.gerrit.common.data.LabelValue;
|
||||
import com.google.gerrit.entities.AccountGroup;
|
||||
import com.google.gerrit.entities.BooleanProjectConfig;
|
||||
import com.google.gerrit.entities.GroupReference;
|
||||
import com.google.gerrit.extensions.client.InheritableBoolean;
|
||||
import com.google.gerrit.server.GerritPersonIdent;
|
||||
import com.google.gerrit.server.account.GroupUuid;
|
||||
|
||||
Reference in New Issue
Block a user