use of org.ovirt.engine.core.common.queries.QueryParametersBase in project ovirt-engine by oVirt.
the class OperationProcessorTest method testOnOperationAvailableSingle_failure_with_retry.
@Test
public void testOnOperationAvailableSingle_failure_with_retry() {
QueryParametersBase testParameter = new QueryParametersBase();
VdcOperation<QueryType, QueryParametersBase> testOperation = new VdcOperation<>(QueryType.Search, testParameter, mockCallback1);
when(mockOperationManager.pollOperation()).thenReturn((VdcOperation) testOperation).thenReturn(null);
testProcessor.processAvailableOperations(mockOperationManager);
verify(mockProvider).transmitOperationList(operationListCaptor.capture());
// $NON-NLS-1$
Exception testException = new Exception("This is an exception");
operationListCaptor.getValue().get(0).getCallback().onFailure(operationListCaptor.getValue().get(0), testException);
// Verify that the original callback is never called.
verify(mockCallback1, never()).onFailure(operationListCaptor.getValue().get(0), testException);
// Verify that the operation is put back in the queue.
verify(mockOperationManager).addOperation(operationListCaptor.getValue().get(0));
// Verify that the callback on the operation is no longer the original.
assertFalse(// $NON-NLS-1$
"callbacks should not match", operationListCaptor.getValue().get(0).getCallback().equals(mockCallback1));
}
use of org.ovirt.engine.core.common.queries.QueryParametersBase in project ovirt-engine by oVirt.
the class OperationProcessorTest method testOnOperationAvailableMultiple_same_success.
@Test
public void testOnOperationAvailableMultiple_same_success() {
QueryParametersBase testParameter = new QueryParametersBase();
List<VdcOperation<?, ?>> testOperation1List = new ArrayList<>();
VdcOperation<QueryType, QueryParametersBase> testOperation1 = new VdcOperation<>(QueryType.Search, testParameter, mockCallbackList1);
testOperation1List.add(testOperation1);
VdcOperation<QueryType, QueryParametersBase> testOperation2 = new VdcOperation<>(QueryType.GetDirectoryGroupById, testParameter, mockCallbackList2);
when(mockOperationManager.pollOperation()).thenReturn((VdcOperation) testOperation1).thenReturn((VdcOperation) testOperation1).thenReturn((VdcOperation) testOperation2).thenReturn(null);
testProcessor.processAvailableOperations(mockOperationManager);
verify(mockProvider).transmitOperationList(operationListCaptor.capture());
// Check to make sure it inserted its own callback.
assertFalse(// $NON-NLS-1$
"The callbacks should NOT match", operationListCaptor.getValue().get(0).getCallback().equals(mockCallbackList1));
assertFalse(// $NON-NLS-1$
"The callbacks should NOT match", operationListCaptor.getValue().get(1).getCallback().equals(mockCallbackList2));
// There should be only be two items in the list.
// $NON-NLS-1$
assertEquals("There should be two items", 2, operationListCaptor.getValue().size());
List<ActionReturnValue> resultList1 = new ArrayList<>();
List<ActionReturnValue> resultList2 = new ArrayList<>();
ActionReturnValue result1 = new ActionReturnValue();
ActionReturnValue result2 = new ActionReturnValue();
resultList1.add(result1);
resultList2.add(result2);
List<VdcOperation> captured1List = new ArrayList<>();
captured1List.add(operationListCaptor.getValue().get(0));
List<VdcOperation> captured2List = new ArrayList<>();
captured2List.add(operationListCaptor.getValue().get(1));
operationListCaptor.getValue().get(0).getCallback().onSuccess(captured1List, resultList1);
verify(mockCallbackList1).onSuccess(testOperation1List, resultList1);
operationListCaptor.getValue().get(1).getCallback().onSuccess(captured2List, resultList2);
}
use of org.ovirt.engine.core.common.queries.QueryParametersBase in project ovirt-engine by oVirt.
the class OperationProcessorTest method testOnOperationAvailableMultipleQuery_failure.
@Test
public void testOnOperationAvailableMultipleQuery_failure() {
QueryParametersBase testParameter = new QueryParametersBase();
VdcOperation testOperation1 = new VdcOperation(QueryType.GetDirectoryGroupById, testParameter, mockCallback1);
VdcOperation testOperation2 = new VdcOperation(QueryType.Search, testParameter, mockCallback2);
when(mockOperationManager.pollOperation()).thenReturn(testOperation1).thenReturn(testOperation2).thenReturn(null);
testProcessor.processAvailableOperations(mockOperationManager);
verify(mockProvider).transmitOperationList(operationListCaptor.capture());
assertFalse("The callbacks should not match", // $NON-NLS-1$
operationListCaptor.getValue().get(0).getCallback().equals(mockCallback1));
assertFalse("The callbacks should not match", // $NON-NLS-1$
operationListCaptor.getValue().get(1).getCallback().equals(mockCallback2));
// $NON-NLS-1$
Exception testException = new Exception("this is an exception");
operationListCaptor.getValue().get(0).getCallback().onFailure(operationListCaptor.getValue().get(0), testException);
operationListCaptor.getValue().get(1).getCallback().onFailure(operationListCaptor.getValue().get(1), testException);
verify(mockCallback1, never()).onFailure(testOperation1, testException);
verify(mockCallback2, never()).onFailure(testOperation2, testException);
verify(mockOperationManager).addOperation(testOperation1);
}
use of org.ovirt.engine.core.common.queries.QueryParametersBase in project ovirt-engine by oVirt.
the class ClusterModel method init.
public void init(final boolean isEdit) {
setIsEdit(isEdit);
setName(new EntityModel<>());
setDescription(new EntityModel<>());
setComment(new EntityModel<>());
setEnableTrustedService(new EntityModel<>(false));
setEnableHaReservation(new EntityModel<>(false));
setEnableOptionalReason(new EntityModel<>(false));
setMigrationPolicies(new ListModel<>());
getMigrationPolicies().getSelectedItemChangedEvent().addListener(this);
getEnableOptionalReason().setIsAvailable(ApplicationModeHelper.isModeSupported(ApplicationMode.VirtOnly));
setEnableHostMaintenanceReason(new EntityModel<>(false));
setAllowClusterWithVirtGlusterEnabled(true);
setGlusterTunedProfile(new ListModel<>());
AsyncDataProvider.getInstance().getAllowClusterWithVirtGlusterEnabled(new AsyncQuery<>(this::setAllowClusterWithVirtGlusterEnabled));
setEnableOvirtService(new EntityModel<>());
setEnableGlusterService(new EntityModel<>());
setAdditionalClusterFeatures(new ListModel<>());
List<List<AdditionalFeature>> additionalFeatures = new ArrayList<>();
additionalFeatures.add(Collections.emptyList());
getAdditionalClusterFeatures().setItems(additionalFeatures, null);
setSpiceProxyEnabled(new EntityModel<>());
getSpiceProxyEnabled().setEntity(false);
getSpiceProxyEnabled().getEntityChangedEvent().addListener(this);
setSpiceProxy(new EntityModel<>());
getSpiceProxy().setIsChangeable(false);
setFencingEnabledModel(new EntityModel<>());
getFencingEnabledModel().setEntity(true);
getFencingEnabledModel().getEntityChangedEvent().addListener((ev, sender, args) -> updateFencingPolicyContent(getVersion() == null ? null : getVersion().getSelectedItem()));
setSkipFencingIfSDActiveEnabled(new EntityModel<>());
getSkipFencingIfSDActiveEnabled().setEntity(true);
setSkipFencingIfGlusterBricksUp(new EntityModel<>());
getSkipFencingIfGlusterBricksUp().setEntity(false);
getSkipFencingIfGlusterBricksUp().setIsAvailable(false);
setSkipFencingIfGlusterQuorumNotMet(new EntityModel<>());
getSkipFencingIfGlusterQuorumNotMet().setEntity(false);
getSkipFencingIfGlusterQuorumNotMet().setIsAvailable(false);
setSkipFencingIfConnectivityBrokenEnabled(new EntityModel<>());
getSkipFencingIfConnectivityBrokenEnabled().setEntity(true);
setEnableOvirtService(new EntityModel<>());
setEnableGlusterService(new EntityModel<>());
setSerialNumberPolicy(new SerialNumberPolicyModel());
setAutoConverge(new ListModel<>());
getAutoConverge().setItems(Arrays.asList(null, true, false));
setMigrateCompressed(new ListModel<>());
getMigrateCompressed().setItems(Arrays.asList(null, true, false));
getEnableOvirtService().getEntityChangedEvent().addListener((ev, sender, args) -> {
refreshAdditionalClusterFeaturesList();
if (!getAllowClusterWithVirtGlusterEnabled() && getEnableOvirtService().getEntity()) {
getEnableGlusterService().setEntity(Boolean.FALSE);
}
updateGlusterFencingPolicyAvailability();
getEnableGlusterService().setIsChangeable(true);
getEnableTrustedService().setEntity(false);
if (getEnableOvirtService().getEntity() != null && getEnableOvirtService().getEntity()) {
if (getEnableGlusterService().getEntity() != null && !getEnableGlusterService().getEntity()) {
getEnableTrustedService().setIsChangeable(true);
} else {
getEnableTrustedService().setIsChangeable(false);
}
} else {
getEnableTrustedService().setIsChangeable(false);
}
});
getEnableOvirtService().setEntity(ApplicationModeHelper.isModeSupported(ApplicationMode.VirtOnly));
getEnableOvirtService().setIsAvailable(ApplicationModeHelper.getUiMode() != ApplicationMode.VirtOnly && ApplicationModeHelper.isModeSupported(ApplicationMode.VirtOnly));
setRngHwrngSourceRequired(new EntityModel<>());
getRngHwrngSourceRequired().setIsAvailable(ApplicationModeHelper.isModeSupported(ApplicationMode.VirtOnly));
initImportCluster();
getEnableGlusterService().getEntityChangedEvent().addListener((ev, sender, args) -> {
refreshAdditionalClusterFeaturesList();
if (!getAllowClusterWithVirtGlusterEnabled() && getEnableGlusterService().getEntity()) {
getEnableOvirtService().setEntity(Boolean.FALSE);
}
if (!isEdit && getEnableGlusterService().getEntity() != null && getEnableGlusterService().getEntity()) {
getIsImportGlusterConfiguration().setIsAvailable(true);
getGlusterHostAddress().setIsAvailable(true);
getGlusterHostFingerprint().setIsAvailable(true);
getGlusterHostPassword().setIsAvailable(true);
} else {
getIsImportGlusterConfiguration().setIsAvailable(false);
getIsImportGlusterConfiguration().setEntity(false);
getGlusterHostAddress().setIsAvailable(false);
getGlusterHostFingerprint().setIsAvailable(false);
getGlusterHostPassword().setIsAvailable(false);
}
if (getEnableGlusterService().getEntity() != null && getEnableGlusterService().getEntity()) {
getEnableTrustedService().setEntity(false);
getEnableTrustedService().setIsChangeable(false);
} else {
if (getEnableOvirtService().getEntity() != null && getEnableOvirtService().getEntity()) {
getEnableTrustedService().setIsChangeable(true);
} else {
getEnableTrustedService().setIsChangeable(false);
}
}
getGlusterTunedProfile().setIsAvailable(getEnableGlusterService().getEntity());
updateGlusterFencingPolicyAvailability();
if (getEnableGlusterService().getEntity()) {
initTunedProfiles();
}
});
getEnableTrustedService().getEntityChangedEvent().addListener((ev, sender, args) -> {
if (getEnableTrustedService().getEntity() != null && getEnableTrustedService().getEntity()) {
getEnableGlusterService().setEntity(false);
getEnableGlusterService().setIsChangeable(false);
} else {
getEnableGlusterService().setIsChangeable(true);
}
});
getEnableGlusterService().setEntity(ApplicationModeHelper.getUiMode() == ApplicationMode.GlusterOnly);
getEnableGlusterService().setIsAvailable(ApplicationModeHelper.getUiMode() != ApplicationMode.GlusterOnly && ApplicationModeHelper.isModeSupported(ApplicationMode.GlusterOnly));
getGlusterTunedProfile().setIsAvailable(getEnableGlusterService().getEntity());
setOptimizationNone(new EntityModel<>());
setOptimizationForServer(new EntityModel<>());
setOptimizationForDesktop(new EntityModel<>());
setOptimizationCustom(new EntityModel<>());
EntityModel<Boolean> tempVar = new EntityModel<>();
tempVar.setEntity(false);
setOptimizationNone_IsSelected(tempVar);
getOptimizationNone_IsSelected().getEntityChangedEvent().addListener(this);
EntityModel<Boolean> tempVar2 = new EntityModel<>();
tempVar2.setEntity(false);
setOptimizationForServer_IsSelected(tempVar2);
getOptimizationForServer_IsSelected().getEntityChangedEvent().addListener(this);
EntityModel<Boolean> tempVar3 = new EntityModel<>();
tempVar3.setEntity(false);
setOptimizationForDesktop_IsSelected(tempVar3);
getOptimizationForDesktop_IsSelected().getEntityChangedEvent().addListener(this);
EntityModel<Boolean> tempVar4 = new EntityModel<>();
tempVar4.setEntity(false);
tempVar4.setIsAvailable(false);
setOptimizationCustom_IsSelected(tempVar4);
getOptimizationCustom_IsSelected().getEntityChangedEvent().addListener(this);
EntityModel<Boolean> tempVar5 = new EntityModel<>();
tempVar5.setEntity(false);
setMigrateOnErrorOption_YES(tempVar5);
getMigrateOnErrorOption_YES().getEntityChangedEvent().addListener(this);
EntityModel<Boolean> tempVar6 = new EntityModel<>();
tempVar6.setEntity(false);
setMigrateOnErrorOption_NO(tempVar6);
getMigrateOnErrorOption_NO().getEntityChangedEvent().addListener(this);
EntityModel<Boolean> tempVar7 = new EntityModel<>();
tempVar7.setEntity(false);
setMigrateOnErrorOption_HA_ONLY(tempVar7);
getMigrateOnErrorOption_HA_ONLY().getEntityChangedEvent().addListener(this);
// KSM feature
setEnableKsm(new EntityModel<>());
getEnableKsm().setEntity(false);
getKsmPolicyForNumaSelection().setIsChangeable(false);
getEnableKsm().getEntityChangedEvent().addListener((ev, sender, args) -> {
if (getEnableKsm().getEntity() == null) {
return;
}
if (getEnableKsm().getEntity()) {
getKsmPolicyForNumaSelection().setIsChangeable(true);
}
if (!getEnableKsm().getEntity()) {
getKsmPolicyForNumaSelection().setIsChangeable(false);
}
});
setEnableBallooning(new EntityModel<>());
getEnableBallooning().setEntity(false);
// Optimization methods:
// default value =100;
setDefaultMemoryOvercommit(AsyncDataProvider.getInstance().getClusterDefaultMemoryOverCommit());
setCountThreadsAsCores(new EntityModel<>(AsyncDataProvider.getInstance().getClusterDefaultCountThreadsAsCores()));
setVersionSupportsCpuThreads(new EntityModel<>(true));
setOptimizeForUtilization(new EntityModel<>());
setOptimizeForSpeed(new EntityModel<>());
getOptimizeForUtilization().setEntity(true);
getOptimizeForSpeed().setEntity(false);
getOptimizeForUtilization().getEntityChangedEvent().addListener(this);
getOptimizeForSpeed().getEntityChangedEvent().addListener(this);
setGuarantyResources(new EntityModel<>());
setAllowOverbooking(new EntityModel<>());
getGuarantyResources().setEntity(true);
getAllowOverbooking().setEntity(false);
getAllowOverbooking().getEntityChangedEvent().addListener(this);
getGuarantyResources().getEntityChangedEvent().addListener(this);
boolean overbookingSupported = AsyncDataProvider.getInstance().getScheudulingAllowOverbookingSupported();
getAllowOverbooking().setIsAvailable(overbookingSupported);
if (overbookingSupported) {
getOptimizeForSpeed().getEntityChangedEvent().addListener((ev, sender, args) -> {
Boolean entity = getOptimizeForSpeed().getEntity();
if (entity) {
getGuarantyResources().setEntity(true);
}
getAllowOverbooking().setIsChangeable(!entity);
});
getAllowOverbooking().getEntityChangedEvent().addListener((ev, sender, args) -> {
Boolean entity = getAllowOverbooking().getEntity();
if (entity) {
getOptimizeForUtilization().setEntity(true);
}
getOptimizeForSpeed().setIsChangeable(!entity);
});
}
setHostsWithBrokenConnectivityThreshold(new ListModel<>());
getHostsWithBrokenConnectivityThreshold().setIsAvailable(true);
getHostsWithBrokenConnectivityThreshold().getSelectedItemChangedEvent().addListener(this);
initHostsWithBrokenConnectivityThreshold();
AsyncDataProvider.getInstance().getClusterDesktopMemoryOverCommit(new AsyncQuery<>(result -> {
setDesktopOverCommit(result);
AsyncDataProvider.getInstance().getClusterServerMemoryOverCommit(new AsyncQuery<>(r -> {
setServerOverCommit(r);
// temp is used for conversion purposes
EntityModel temp;
temp = getOptimizationNone();
temp.setEntity(getDefaultMemoryOvercommit());
// res1, res2 is used for conversion purposes.
boolean res1 = getDesktopOverCommit() != getDefaultMemoryOvercommit();
boolean res2 = getServerOverCommit() != getDefaultMemoryOvercommit();
temp = getOptimizationNone_IsSelected();
setIsSelected(res1 && res2);
temp.setEntity(getIsSelected());
temp = getOptimizationForServer();
temp.setEntity(getServerOverCommit());
temp = getOptimizationForServer_IsSelected();
temp.setEntity(getServerOverCommit() == getDefaultMemoryOvercommit());
temp = getOptimizationForDesktop();
temp.setEntity(getDesktopOverCommit());
temp = getOptimizationForDesktop_IsSelected();
temp.setEntity(getDesktopOverCommit() == getDefaultMemoryOvercommit());
temp = getOptimizationCustom();
temp.setIsAvailable(false);
temp.setIsChangeable(false);
if (getIsEdit()) {
postInit();
}
}));
}));
setDataCenter(new ListModel<>());
getDataCenter().getSelectedItemChangedEvent().addListener(this);
getDataCenter().setIsAvailable(ApplicationModeHelper.getUiMode() != ApplicationMode.GlusterOnly);
setArchitecture(new ListModel<>());
getArchitecture().setIsAvailable(ApplicationModeHelper.isModeSupported(ApplicationMode.VirtOnly));
setManagementNetwork(new ListModel<>());
if (isEdit && !isClusterDetached()) {
getManagementNetwork().setChangeProhibitionReason(ConstantsManager.getInstance().getConstants().prohibitManagementNetworkChangeInEditClusterInfoMessage());
getManagementNetwork().setIsChangeable(false);
}
setCPU(new FilteredListModel<>());
getCPU().setIsAvailable(ApplicationModeHelper.getUiMode() != ApplicationMode.GlusterOnly);
getCPU().getSelectedItemChangedEvent().addListener(this);
setVersion(new ListModel<>());
getVersion().getSelectedItemChangedEvent().addListener(this);
setMigrateOnErrorOption(MigrateOnErrorOptions.YES);
setFirewallType(new ListModel<>());
initFirewallType();
setDefaultNetworkProvider(new ListModel<>());
initDefaultNetworkProvider();
setSwitchType(new ListModel<>());
initSwitchType();
getRngHwrngSourceRequired().setEntity(false);
setValidTab(TabName.GENERAL_TAB, true);
setMigrationTabAvailable(true);
setClusterPolicy(new ListModel<>());
setCustomPropertySheet(new KeyValueModel());
getClusterPolicy().getSelectedItemChangedEvent().addListener(this);
Frontend.getInstance().runQuery(QueryType.GetAllPolicyUnits, new QueryParametersBase(), new AsyncQuery<QueryReturnValue>(returnValue -> {
ArrayList<PolicyUnit> policyUnits = returnValue.getReturnValue();
policyUnitMap = new LinkedHashMap<>();
for (PolicyUnit policyUnit : policyUnits) {
policyUnitMap.put(policyUnit.getId(), policyUnit);
}
Frontend.getInstance().runQuery(QueryType.GetClusterPolicies, new QueryParametersBase(), new AsyncQuery<QueryReturnValue>(retVal -> {
ArrayList<ClusterPolicy> list = retVal.getReturnValue();
getClusterPolicy().setItems(list);
ClusterPolicy defaultClusterPolicy = null;
ClusterPolicy selectedClusterPolicy = null;
for (ClusterPolicy clusterPolicy : list) {
if (getIsEdit() && getEntity() != null && clusterPolicy.getId().equals(getEntity().getClusterPolicyId())) {
selectedClusterPolicy = clusterPolicy;
}
if (clusterPolicy.isDefaultPolicy()) {
defaultClusterPolicy = clusterPolicy;
}
}
if (selectedClusterPolicy != null) {
getClusterPolicy().setSelectedItem(selectedClusterPolicy);
} else {
getClusterPolicy().setSelectedItem(defaultClusterPolicy);
}
clusterPolicyChanged();
}));
}));
setCustomMigrationNetworkBandwidth(new EntityModel<>());
setMigrationBandwidthLimitType(new ListModel<>());
}
use of org.ovirt.engine.core.common.queries.QueryParametersBase in project ovirt-engine by oVirt.
the class BookmarkListModel method syncSearch.
@Override
protected void syncSearch() {
super.syncSearch();
Frontend.getInstance().runQuery(QueryType.GetAllBookmarks, new QueryParametersBase(), new AsyncQuery<>((AsyncCallback<QueryReturnValue>) returnValue -> {
List<Bookmark> resultList = returnValue.getReturnValue();
if (resultList != null) {
Collections.sort(resultList, COMPARATOR);
}
setIsBookmarkInitiated(true);
setItems(resultList);
setIsBookmarkInitiated(false);
}));
}
Aggregations