FakeGroupAuditService: Extend AuditService
This simplifies the implementation, and underscores the fact that the only new behavior introduced for tests is recording events in a side list. Change-Id: Ie2e5e7c9b22373ad8421f0d4dbd844edac0a047a
This commit is contained in:
@@ -14,30 +14,21 @@
|
|||||||
|
|
||||||
package com.google.gerrit.testing;
|
package com.google.gerrit.testing;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableSet;
|
|
||||||
import com.google.gerrit.extensions.registration.DynamicSet;
|
import com.google.gerrit.extensions.registration.DynamicSet;
|
||||||
import com.google.gerrit.reviewdb.client.Account;
|
|
||||||
import com.google.gerrit.reviewdb.client.AccountGroup;
|
|
||||||
import com.google.gerrit.server.AuditEvent;
|
import com.google.gerrit.server.AuditEvent;
|
||||||
import com.google.gerrit.server.audit.AuditListener;
|
import com.google.gerrit.server.audit.AuditListener;
|
||||||
|
import com.google.gerrit.server.audit.AuditService;
|
||||||
import com.google.gerrit.server.audit.group.GroupAuditListener;
|
import com.google.gerrit.server.audit.group.GroupAuditListener;
|
||||||
import com.google.gerrit.server.audit.group.GroupMemberAuditEvent;
|
|
||||||
import com.google.gerrit.server.audit.group.GroupSubgroupAuditEvent;
|
|
||||||
import com.google.gerrit.server.group.GroupAuditService;
|
import com.google.gerrit.server.group.GroupAuditService;
|
||||||
import com.google.gerrit.server.plugincontext.PluginSetContext;
|
import com.google.gerrit.server.plugincontext.PluginSetContext;
|
||||||
import com.google.inject.AbstractModule;
|
import com.google.inject.AbstractModule;
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
import com.google.inject.Singleton;
|
import com.google.inject.Singleton;
|
||||||
import java.sql.Timestamp;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@Singleton
|
@Singleton
|
||||||
public class FakeGroupAuditService implements GroupAuditService {
|
public class FakeGroupAuditService extends AuditService {
|
||||||
|
|
||||||
protected final PluginSetContext<GroupAuditListener> groupAuditListeners;
|
|
||||||
protected final PluginSetContext<AuditListener> auditListeners;
|
|
||||||
|
|
||||||
public final List<AuditEvent> auditEvents = new ArrayList<>();
|
public final List<AuditEvent> auditEvents = new ArrayList<>();
|
||||||
|
|
||||||
public static class Module extends AbstractModule {
|
public static class Module extends AbstractModule {
|
||||||
@@ -50,11 +41,10 @@ public class FakeGroupAuditService implements GroupAuditService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public FakeGroupAuditService(
|
FakeGroupAuditService(
|
||||||
PluginSetContext<GroupAuditListener> groupAuditListeners,
|
PluginSetContext<AuditListener> auditListeners,
|
||||||
PluginSetContext<AuditListener> auditListeners) {
|
PluginSetContext<GroupAuditListener> groupAuditListeners) {
|
||||||
this.groupAuditListeners = groupAuditListeners;
|
super(auditListeners, groupAuditListeners);
|
||||||
this.auditListeners = auditListeners;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void clearEvents() {
|
public void clearEvents() {
|
||||||
@@ -63,53 +53,10 @@ public class FakeGroupAuditService implements GroupAuditService {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void dispatch(AuditEvent action) {
|
public void dispatch(AuditEvent action) {
|
||||||
|
super.dispatch(action);
|
||||||
synchronized (auditEvents) {
|
synchronized (auditEvents) {
|
||||||
auditEvents.add(action);
|
auditEvents.add(action);
|
||||||
auditEvents.notifyAll();
|
auditEvents.notifyAll();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void dispatchAddMembers(
|
|
||||||
Account.Id actor,
|
|
||||||
AccountGroup.UUID updatedGroup,
|
|
||||||
ImmutableSet<Account.Id> addedMembers,
|
|
||||||
Timestamp addedOn) {
|
|
||||||
GroupMemberAuditEvent event =
|
|
||||||
GroupMemberAuditEvent.create(actor, updatedGroup, addedMembers, addedOn);
|
|
||||||
groupAuditListeners.runEach(l -> l.onAddMembers(event));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void dispatchDeleteMembers(
|
|
||||||
Account.Id actor,
|
|
||||||
AccountGroup.UUID updatedGroup,
|
|
||||||
ImmutableSet<Account.Id> deletedMembers,
|
|
||||||
Timestamp deletedOn) {
|
|
||||||
GroupMemberAuditEvent event =
|
|
||||||
GroupMemberAuditEvent.create(actor, updatedGroup, deletedMembers, deletedOn);
|
|
||||||
groupAuditListeners.runEach(l -> l.onDeleteMembers(event));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void dispatchAddSubgroups(
|
|
||||||
Account.Id actor,
|
|
||||||
AccountGroup.UUID updatedGroup,
|
|
||||||
ImmutableSet<AccountGroup.UUID> addedSubgroups,
|
|
||||||
Timestamp addedOn) {
|
|
||||||
GroupSubgroupAuditEvent event =
|
|
||||||
GroupSubgroupAuditEvent.create(actor, updatedGroup, addedSubgroups, addedOn);
|
|
||||||
groupAuditListeners.runEach(l -> l.onAddSubgroups(event));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void dispatchDeleteSubgroups(
|
|
||||||
Account.Id actor,
|
|
||||||
AccountGroup.UUID updatedGroup,
|
|
||||||
ImmutableSet<AccountGroup.UUID> deletedSubgroups,
|
|
||||||
Timestamp deletedOn) {
|
|
||||||
GroupSubgroupAuditEvent event =
|
|
||||||
GroupSubgroupAuditEvent.create(actor, updatedGroup, deletedSubgroups, deletedOn);
|
|
||||||
groupAuditListeners.runEach(l -> l.onDeleteSubgroups(event));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user