google-nomulus/javatests/google/registry/ui/server/registrar/OteStatusActionTest.java
mcilwain 580302898d Delete end-date sunrise, landrush, and sunrush phases
This also deletes the associated commands and domain application specific
entities.

We haven't used any of these TLD phases since early 2015 and have no
intent to do so in the future, so it makes sense to delete them now so we
don't have to carry them through the Registry 3.0 migration.

Note that, while there are data model changes, there should be no required
data migrations. The fields and entities being removed will simply remain
as orphans. I confirmed that the removed types (such as the SUNRUSH_ADD
GracePeriodType) are no longer used in production data, and left types
that are still used, e.g. BillingEvent.Flag.LANDRUSH or
HistoryEntry.Type.ALLOCATE.

-------------
Created by MOE: https://github.com/google/moe
MOE_MIGRATED_REVID=228752843
2019-01-10 16:23:35 -05:00

149 lines
6.2 KiB
Java

// Copyright 2019 The Nomulus Authors. All Rights Reserved.
//
// 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 google.registry.ui.server.registrar;
import static com.google.common.collect.ImmutableList.toImmutableList;
import static com.google.common.collect.ImmutableSetMultimap.toImmutableSetMultimap;
import static com.google.common.truth.Truth.assertThat;
import static google.registry.testing.DatastoreHelper.persistNewRegistrar;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSetMultimap;
import com.google.common.collect.Iterables;
import google.registry.model.OteAccountBuilder;
import google.registry.model.OteStats.StatType;
import google.registry.model.OteStatsTestHelper;
import google.registry.model.registrar.Registrar.Type;
import google.registry.request.auth.AuthenticatedRegistrarAccessor;
import google.registry.request.auth.AuthenticatedRegistrarAccessor.Role;
import google.registry.testing.AppEngineRule;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
/** Unit tests for {@link OteStatusAction} */
@RunWith(JUnit4.class)
public final class OteStatusActionTest {
private static final String CLIENT_ID = "blobio-1";
private static final String BASE_CLIENT_ID = "blobio";
private final OteStatusAction action = new OteStatusAction();
@Rule public final AppEngineRule appEngine = AppEngineRule.builder().withDatastore().build();
@Before
public void init() throws Exception {
OteStatsTestHelper.setupHistoryEntries();
persistNewRegistrar(CLIENT_ID, "SomeRegistrar", Type.OTE, null);
ImmutableSetMultimap<String, Role> authValues =
OteAccountBuilder.createClientIdToTldMap("blobio").keySet().stream()
.collect(toImmutableSetMultimap(Function.identity(), ignored -> Role.OWNER));
action.registrarAccessor = AuthenticatedRegistrarAccessor.createForTesting(authValues);
}
@Test
@SuppressWarnings("unchecked")
public void testSuccess_finishedOte() {
Map<String, ?> actionResult = action.handleJsonRequest(ImmutableMap.of("clientId", CLIENT_ID));
assertThat(actionResult).containsEntry("status", "SUCCESS");
assertThat(actionResult).containsEntry("message", "OT&E check completed successfully");
Map<String, ?> results =
Iterables.getOnlyElement((List<Map<String, ?>>) actionResult.get("results"));
assertThat(results).containsEntry("clientId", BASE_CLIENT_ID);
assertThat(results).containsEntry("completed", true);
assertThat(getFailingResultDetails(results)).isEmpty();
}
@Test
@SuppressWarnings("unchecked")
public void testSuccess_unfinishedOte() {
OteStatsTestHelper.deleteHostDeleteHistoryEntry();
Map<String, ?> actionResult = action.handleJsonRequest(ImmutableMap.of("clientId", CLIENT_ID));
assertThat(actionResult).containsEntry("status", "SUCCESS");
assertThat(actionResult).containsEntry("message", "OT&E check completed successfully");
Map<String, ?> results =
Iterables.getOnlyElement((List<Map<String, ?>>) actionResult.get("results"));
assertThat(results).containsEntry("clientId", BASE_CLIENT_ID);
assertThat(results).containsEntry("completed", false);
assertThat(getFailingResultDetails(results))
.containsExactly(
ImmutableMap.of(
"description", StatType.HOST_DELETES.getDescription(),
"requirement", StatType.HOST_DELETES.getRequirement(),
"timesPerformed", 0,
"completed", false));
}
@Test
public void testFailure_malformedInput() {
assertThat(action.handleJsonRequest(null))
.containsExactlyEntriesIn(errorResultWithMessage("Malformed JSON"));
assertThat(action.handleJsonRequest(ImmutableMap.of()))
.containsExactlyEntriesIn(errorResultWithMessage("Missing key for OT&E client: clientId"));
}
@Test
public void testFailure_noRegistrar() {
assertThat(action.handleJsonRequest(ImmutableMap.of("clientId", "nonexistent-id-3")))
.containsExactlyEntriesIn(
errorResultWithMessage("TestUserId doesn't have access to registrar nonexistent-id-3"));
}
@Test
public void testFailure_notAuthorized() {
action.registrarAccessor =
AuthenticatedRegistrarAccessor.createForTesting(ImmutableSetMultimap.of());
assertThat(action.handleJsonRequest(ImmutableMap.of("clientId", CLIENT_ID)))
.containsExactlyEntriesIn(
errorResultWithMessage("TestUserId doesn't have access to registrar blobio-1"));
}
@Test
public void testFailure_malformedRegistrarName() {
assertThat(action.handleJsonRequest(ImmutableMap.of("clientId", "bad-client-id")))
.containsExactlyEntriesIn(
errorResultWithMessage(
"ID bad-client-id is not one of the OT&E client IDs for base bad-client"));
}
@Test
public void testFailure_nonOteRegistrar() {
persistNewRegistrar(CLIENT_ID, "SomeRegistrar", Type.REAL, 1L);
assertThat(action.handleJsonRequest(ImmutableMap.of("clientId", CLIENT_ID)))
.containsExactlyEntriesIn(
errorResultWithMessage("Registrar with ID blobio-1 is not an OT&E registrar"));
}
@SuppressWarnings("unchecked")
private List<Map<?, ?>> getFailingResultDetails(Map<String, ?> results) {
return ((List<Map<?, ?>>) results.get("details"))
.stream()
.filter(result -> !Boolean.TRUE.equals(result.get("completed")))
.collect(toImmutableList());
}
private ImmutableMap<String, ?> errorResultWithMessage(String message) {
return ImmutableMap.of("status", "ERROR", "message", message, "results", ImmutableList.of());
}
}