mirror of
https://github.com/google/nomulus.git
synced 2025-04-30 12:07:51 +02:00
Don't create unnecessary synthetic History objects (#1796)
This commit is contained in:
parent
2388cece95
commit
09b2d48270
2 changed files with 51 additions and 14 deletions
|
@ -60,15 +60,22 @@ public class CreateSyntheticDomainHistoriesPipeline implements Serializable {
|
||||||
private static final String HISTORY_REASON =
|
private static final String HISTORY_REASON =
|
||||||
"Create synthetic domain histories to fix RDE for b/248112997";
|
"Create synthetic domain histories to fix RDE for b/248112997";
|
||||||
private static final DateTime BAD_PIPELINE_START_TIME =
|
private static final DateTime BAD_PIPELINE_START_TIME =
|
||||||
DateTime.parse("2022-09-05T00:00:00.000Z");
|
DateTime.parse("2022-09-05T09:00:00.000Z");
|
||||||
|
private static final DateTime BAD_PIPELINE_END_TIME = DateTime.parse("2022-09-10T12:00:00.000Z");
|
||||||
|
|
||||||
static void setup(Pipeline pipeline, String registryAdminRegistrarId) {
|
static void setup(Pipeline pipeline, String registryAdminRegistrarId) {
|
||||||
pipeline
|
pipeline
|
||||||
.apply(
|
.apply(
|
||||||
"Read all domain repo IDs",
|
"Read all domain repo IDs",
|
||||||
RegistryJpaIO.read(
|
RegistryJpaIO.read(
|
||||||
"SELECT repoId FROM Domain WHERE deletionTime > :badPipelineStartTime",
|
"SELECT d.repoId FROM Domain d WHERE deletionTime > :badPipelineStartTime AND NOT"
|
||||||
ImmutableMap.of("badPipelineStartTime", BAD_PIPELINE_START_TIME),
|
+ " EXISTS (SELECT 1 FROM DomainHistory dh WHERE dh.domainRepoId = d.repoId"
|
||||||
|
+ " AND dh.modificationTime > :badPipelineEndTime)",
|
||||||
|
ImmutableMap.of(
|
||||||
|
"badPipelineStartTime",
|
||||||
|
BAD_PIPELINE_START_TIME,
|
||||||
|
"badPipelineEndTime",
|
||||||
|
BAD_PIPELINE_END_TIME),
|
||||||
String.class,
|
String.class,
|
||||||
repoId -> VKey.createSql(Domain.class, repoId)))
|
repoId -> VKey.createSql(Domain.class, repoId)))
|
||||||
.apply(
|
.apply(
|
||||||
|
|
|
@ -16,21 +16,24 @@ package google.registry.tools.javascrap;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
import static google.registry.model.ImmutableObjectSubject.assertAboutImmutableObjects;
|
import static google.registry.model.ImmutableObjectSubject.assertAboutImmutableObjects;
|
||||||
import static google.registry.persistence.transaction.TransactionManagerFactory.jpaTm;
|
|
||||||
import static google.registry.testing.DatabaseHelper.createTld;
|
import static google.registry.testing.DatabaseHelper.createTld;
|
||||||
import static google.registry.testing.DatabaseHelper.loadAllOf;
|
import static google.registry.testing.DatabaseHelper.loadAllOf;
|
||||||
import static google.registry.testing.DatabaseHelper.newDomain;
|
import static google.registry.testing.DatabaseHelper.newContact;
|
||||||
import static google.registry.testing.DatabaseHelper.persistActiveHost;
|
import static google.registry.testing.DatabaseHelper.persistActiveHost;
|
||||||
|
import static google.registry.testing.DatabaseHelper.persistDomainWithDependentResources;
|
||||||
import static google.registry.testing.DatabaseHelper.persistNewRegistrar;
|
import static google.registry.testing.DatabaseHelper.persistNewRegistrar;
|
||||||
|
import static google.registry.testing.DatabaseHelper.persistResource;
|
||||||
import static google.registry.testing.DatabaseHelper.persistSimpleResource;
|
import static google.registry.testing.DatabaseHelper.persistSimpleResource;
|
||||||
|
|
||||||
import com.google.common.collect.Iterables;
|
|
||||||
import google.registry.beam.TestPipelineExtension;
|
import google.registry.beam.TestPipelineExtension;
|
||||||
import google.registry.model.domain.Domain;
|
import google.registry.model.domain.Domain;
|
||||||
import google.registry.model.domain.DomainHistory;
|
import google.registry.model.domain.DomainHistory;
|
||||||
import google.registry.model.reporting.HistoryEntry;
|
import google.registry.model.reporting.HistoryEntry;
|
||||||
|
import google.registry.model.reporting.HistoryEntryDao;
|
||||||
import google.registry.persistence.transaction.JpaTestExtensions;
|
import google.registry.persistence.transaction.JpaTestExtensions;
|
||||||
import google.registry.testing.DatastoreEntityExtension;
|
import google.registry.testing.DatastoreEntityExtension;
|
||||||
|
import google.registry.testing.FakeClock;
|
||||||
|
import org.joda.time.DateTime;
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.extension.RegisterExtension;
|
import org.junit.jupiter.api.extension.RegisterExtension;
|
||||||
|
@ -38,9 +41,11 @@ import org.junit.jupiter.api.extension.RegisterExtension;
|
||||||
/** Tests for {@link CreateSyntheticDomainHistoriesPipeline}. */
|
/** Tests for {@link CreateSyntheticDomainHistoriesPipeline}. */
|
||||||
public class CreateSyntheticDomainHistoriesPipelineTest {
|
public class CreateSyntheticDomainHistoriesPipelineTest {
|
||||||
|
|
||||||
|
private final FakeClock fakeClock = new FakeClock(DateTime.parse("2022-09-01T00:00:00.000Z"));
|
||||||
|
|
||||||
@RegisterExtension
|
@RegisterExtension
|
||||||
JpaTestExtensions.JpaIntegrationTestExtension jpaEextension =
|
JpaTestExtensions.JpaIntegrationTestExtension jpaEextension =
|
||||||
new JpaTestExtensions.Builder().buildIntegrationTestExtension();
|
new JpaTestExtensions.Builder().withClock(fakeClock).buildIntegrationTestExtension();
|
||||||
|
|
||||||
@RegisterExtension
|
@RegisterExtension
|
||||||
DatastoreEntityExtension datastoreEntityExtension =
|
DatastoreEntityExtension datastoreEntityExtension =
|
||||||
|
@ -55,24 +60,49 @@ public class CreateSyntheticDomainHistoriesPipelineTest {
|
||||||
persistNewRegistrar("TheRegistrar");
|
persistNewRegistrar("TheRegistrar");
|
||||||
persistNewRegistrar("NewRegistrar");
|
persistNewRegistrar("NewRegistrar");
|
||||||
createTld("tld");
|
createTld("tld");
|
||||||
|
domain =
|
||||||
|
persistDomainWithDependentResources(
|
||||||
|
"example",
|
||||||
|
"tld",
|
||||||
|
persistResource(newContact("contact1234")),
|
||||||
|
fakeClock.nowUtc(),
|
||||||
|
DateTime.parse("2022-09-01T00:00:00.000Z"),
|
||||||
|
DateTime.parse("2024-09-01T00:00:00.000Z"));
|
||||||
domain =
|
domain =
|
||||||
persistSimpleResource(
|
persistSimpleResource(
|
||||||
newDomain("example.tld")
|
domain
|
||||||
.asBuilder()
|
.asBuilder()
|
||||||
.setNameservers(persistActiveHost("external.com").createVKey())
|
.setNameservers(persistActiveHost("external.com").createVKey())
|
||||||
.build());
|
.build());
|
||||||
|
fakeClock.setTo(DateTime.parse("2022-09-20T00:00:00.000Z"));
|
||||||
|
// shouldn't create any history objects for this domain
|
||||||
|
persistDomainWithDependentResources(
|
||||||
|
"ignored-example",
|
||||||
|
"tld",
|
||||||
|
persistResource(newContact("contact12345")),
|
||||||
|
fakeClock.nowUtc(),
|
||||||
|
DateTime.parse("2022-09-20T00:00:00.000Z"),
|
||||||
|
DateTime.parse("2024-09-20T00:00:00.000Z"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testSuccess() {
|
void testSuccess() {
|
||||||
assertThat(jpaTm().transact(() -> jpaTm().loadAllOf(DomainHistory.class))).isEmpty();
|
assertThat(loadAllOf(DomainHistory.class)).hasSize(2);
|
||||||
CreateSyntheticDomainHistoriesPipeline.setup(pipeline, "NewRegistrar");
|
CreateSyntheticDomainHistoriesPipeline.setup(pipeline, "NewRegistrar");
|
||||||
pipeline.run().waitUntilFinish();
|
pipeline.run().waitUntilFinish();
|
||||||
DomainHistory domainHistory = Iterables.getOnlyElement(loadAllOf(DomainHistory.class));
|
DomainHistory syntheticHistory =
|
||||||
assertThat(domainHistory.getType()).isEqualTo(HistoryEntry.Type.SYNTHETIC);
|
HistoryEntryDao.loadHistoryObjectsForResource(domain.createVKey(), DomainHistory.class)
|
||||||
assertThat(domainHistory.getRegistrarId()).isEqualTo("NewRegistrar");
|
.get(1);
|
||||||
|
assertThat(syntheticHistory.getType()).isEqualTo(HistoryEntry.Type.SYNTHETIC);
|
||||||
|
assertThat(syntheticHistory.getRegistrarId()).isEqualTo("NewRegistrar");
|
||||||
assertAboutImmutableObjects()
|
assertAboutImmutableObjects()
|
||||||
.that(domainHistory.getDomainBase().get())
|
.that(syntheticHistory.getDomainBase().get())
|
||||||
.hasFieldsEqualTo(domain);
|
.isEqualExceptFields(domain, "updateTimestamp");
|
||||||
|
|
||||||
|
// shouldn't create any entries on re-run
|
||||||
|
pipeline.run().waitUntilFinish();
|
||||||
|
assertThat(HistoryEntryDao.loadHistoryObjectsForResource(domain.createVKey())).hasSize(2);
|
||||||
|
// three total histories, two CREATE and one SYNTHETIC
|
||||||
|
assertThat(loadAllOf(DomainHistory.class)).hasSize(3);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue