use of com.sequenceiq.cloudbreak.api.endpoint.v4.stacks.request.tags.upgrade.UpgradeV4Request in project cloudbreak by hortonworks.
the class UpgradeConverterTest method testConvertRequestWhenInternal.
@Test
public void testConvertRequestWhenInternal() {
// GIVEN
DistroXUpgradeV1Request source = new DistroXUpgradeV1Request();
// WHEN
UpgradeV4Request result = underTest.convert(source, new InternalUpgradeSettings(true, true, true));
// THEN
assertTrue(result.getInternalUpgradeSettings().isSkipValidations());
}
use of com.sequenceiq.cloudbreak.api.endpoint.v4.stacks.request.tags.upgrade.UpgradeV4Request in project cloudbreak by hortonworks.
the class DistroXUpgradeAvailabilityServiceTest method testCheckForUpgradeWhenDataHubUpgradeIsDisabledAnNoMaintenanceUpgradeCandidatesAreAvaiable.
@Test
@DisplayName("this test simulates that a Data Hub runtime upgrade entitlement is disabled" + " and all the image candidates are filtered for maintenance upgrade so empty response should be returned")
public void testCheckForUpgradeWhenDataHubUpgradeIsDisabledAnNoMaintenanceUpgradeCandidatesAreAvaiable() {
Cluster datalakeCluster = TestUtil.cluster();
datalakeCluster.setRangerRazEnabled(false);
UpgradeV4Request request = new UpgradeV4Request();
UpgradeV4Response response = new UpgradeV4Response();
ImageInfoV4Response current = createImageResponse(1L, "7.1.0");
ImageInfoV4Response image1 = createImageResponse(2L, "7.2.0");
ImageInfoV4Response image2 = createImageResponse(8L, "7.3.0");
ImageInfoV4Response image3 = createImageResponse(6L, "7.4.0");
response.setUpgradeCandidates(List.of(image1, image2, image3));
response.setCurrent(current);
when(clusterService.getClusterByStackResourceCrn(any())).thenReturn(datalakeCluster);
when(stackService.getByNameOrCrnInWorkspace(CLUSTER, WORKSPACE_ID)).thenReturn(stack);
when(stackUpgradeOperations.checkForClusterUpgrade(ACCOUNT_ID, stack, WORKSPACE_ID, request)).thenReturn(response);
when(entitlementService.datahubRuntimeUpgradeEnabled(ACCOUNT_ID)).thenReturn(false);
UpgradeV4Response result = underTest.checkForUpgrade(CLUSTER, WORKSPACE_ID, request, USER_CRN);
String expectedMessage = "No image is available for maintenance upgrade, CDP version: 7.1.0";
assertEquals(0, result.getUpgradeCandidates().size());
assertEquals(expectedMessage, result.getReason());
}
use of com.sequenceiq.cloudbreak.api.endpoint.v4.stacks.request.tags.upgrade.UpgradeV4Request in project cloudbreak by hortonworks.
the class DistroXUpgradeAvailabilityServiceTest method testReturnLatestOnlyForDryRun.
@Test
public void testReturnLatestOnlyForDryRun() {
UpgradeV4Request request = new UpgradeV4Request();
request.setDryRun(Boolean.TRUE);
UpgradeV4Response response = new UpgradeV4Response();
ImageInfoV4Response image1 = new ImageInfoV4Response();
image1.setCreated(1L);
ImageInfoV4Response image2 = new ImageInfoV4Response();
image2.setCreated(8L);
ImageInfoV4Response image3 = new ImageInfoV4Response();
image3.setCreated(5L);
response.setUpgradeCandidates(List.of(image1, image2, image3));
when(stackService.getByNameOrCrnInWorkspace(CLUSTER, WORKSPACE_ID)).thenReturn(stack);
when(stackUpgradeOperations.checkForClusterUpgrade(ACCOUNT_ID, stack, WORKSPACE_ID, request)).thenReturn(response);
UpgradeV4Response result = underTest.checkForUpgrade(CLUSTER, WORKSPACE_ID, request, USER_CRN);
assertEquals(1, result.getUpgradeCandidates().size());
assertEquals(8L, result.getUpgradeCandidates().get(0).getCreated());
}
use of com.sequenceiq.cloudbreak.api.endpoint.v4.stacks.request.tags.upgrade.UpgradeV4Request in project cloudbreak by hortonworks.
the class DistroXUpgradeAvailabilityServiceTest method testReturnAllCandidates.
@Test
public void testReturnAllCandidates() {
UpgradeV4Request request = new UpgradeV4Request();
UpgradeV4Response response = new UpgradeV4Response();
response.setUpgradeCandidates(List.of(mock(ImageInfoV4Response.class), mock(ImageInfoV4Response.class)));
when(stackService.getByNameOrCrnInWorkspace(CLUSTER, WORKSPACE_ID)).thenReturn(stack);
when(stackUpgradeOperations.checkForClusterUpgrade(ACCOUNT_ID, stack, WORKSPACE_ID, request)).thenReturn(response);
UpgradeV4Response result = underTest.checkForUpgrade(CLUSTER, WORKSPACE_ID, request, USER_CRN);
assertEquals(response.getUpgradeCandidates(), result.getUpgradeCandidates());
}
use of com.sequenceiq.cloudbreak.api.endpoint.v4.stacks.request.tags.upgrade.UpgradeV4Request in project cloudbreak by hortonworks.
the class DistroXUpgradeAvailabilityServiceTest method testOnlyReturnCandidatesWithDatalakeVersion.
@Test
public void testOnlyReturnCandidatesWithDatalakeVersion() {
UpgradeV4Request request = new UpgradeV4Request();
request.setShowAvailableImages(UpgradeShowAvailableImages.LATEST_ONLY);
UpgradeV4Response response = new UpgradeV4Response();
ImageInfoV4Response image1 = createImageResponse(2L, "A");
ImageInfoV4Response image2 = createImageResponse(8L, "A");
ImageInfoV4Response image3 = createImageResponse(6L, "A");
ImageInfoV4Response image4 = createImageResponse(1L, "B");
ImageInfoV4Response image5 = createImageResponse(4L, "B");
ImageInfoV4Response image6 = createImageResponse(3L, "B");
ImageInfoV4Response image7 = createImageResponse(9L, "C");
ImageInfoV4Response image8 = createImageResponse(8L, "C");
ImageInfoV4Response image9 = createImageResponse(6L, "C");
response.setUpgradeCandidates(List.of(image1, image2, image3, image4, image5, image6, image7, image8, image9));
StackView stackView = new StackView();
ClusterView clusterView = new ClusterView();
clusterView.setId(1L);
ReflectionTestUtils.setField(stackView, "cluster", clusterView);
when(stackService.getByNameOrCrnInWorkspace(CLUSTER, WORKSPACE_ID)).thenReturn(stack);
when(stackUpgradeOperations.checkForClusterUpgrade(ACCOUNT_ID, stack, WORKSPACE_ID, request)).thenReturn(response);
when(stackViewService.findDatalakeViewByEnvironmentCrn(stack.getEnvironmentCrn())).thenReturn(Optional.of(stackView));
when(runtimeVersionService.getRuntimeVersion(eq(clusterView.getId()))).thenReturn(Optional.of("C"));
when(entitlementService.datahubRuntimeUpgradeEnabled(ACCOUNT_ID)).thenReturn(true);
UpgradeV4Response result = underTest.checkForUpgrade(CLUSTER, WORKSPACE_ID, request, USER_CRN);
assertEquals(1, result.getUpgradeCandidates().size());
assertTrue(result.getUpgradeCandidates().stream().anyMatch(img -> img.getCreated() == 9L && "C".equals(img.getComponentVersions().getCdp())));
}
Aggregations