String blueprintName = "test-blueprint";
String stackName = "test";
String stackVersion = "1.23";
String clusterName = "c1";
BlueprintDAO blueprintDAO = createStrictMock(BlueprintDAO.class);
AmbariMetaInfo metaInfo = createMock(AmbariMetaInfo.class);
AmbariManagementController managementController = createStrictMock(AmbariManagementController.class);
Request request = createNiceMock(Request.class);
RequestStatusResponse response = createNiceMock(RequestStatusResponse.class);
BlueprintEntity blueprint = createNiceMock(BlueprintEntity.class);
StackServiceResponse stackServiceResponse1 = createNiceMock(StackServiceResponse.class);
StackServiceResponse stackServiceResponse2 = createNiceMock(StackServiceResponse.class);
Capture<Set<StackServiceRequest>> stackServiceRequestCapture = new Capture<Set<StackServiceRequest>>();
StackServiceComponentResponse stackServiceComponentResponse1 = createNiceMock(StackServiceComponentResponse.class);
StackServiceComponentResponse stackServiceComponentResponse2 = createNiceMock(StackServiceComponentResponse.class);
StackServiceComponentResponse stackServiceComponentResponse3 = createNiceMock(StackServiceComponentResponse.class);
StackServiceComponentResponse stackServiceComponentResponse4 = createNiceMock(StackServiceComponentResponse.class);
Capture<Set<StackServiceComponentRequest>> serviceComponentRequestCapture1 = new Capture<Set<StackServiceComponentRequest>>();
Capture<Set<StackServiceComponentRequest>> serviceComponentRequestCapture2 = new Capture<Set<StackServiceComponentRequest>>();
StackConfigurationResponse stackConfigurationResponse1 = createNiceMock(StackConfigurationResponse.class);
StackConfigurationResponse stackConfigurationResponse2 = createNiceMock(StackConfigurationResponse.class);
StackConfigurationResponse stackConfigurationResponse3 = createNiceMock(StackConfigurationResponse.class);
StackConfigurationResponse stackConfigurationResponse4 = createNiceMock(StackConfigurationResponse.class);
StackConfigurationResponse stackConfigurationResponse5 = createNiceMock(StackConfigurationResponse.class);
Capture<Set<StackConfigurationRequest>> serviceConfigurationRequestCapture1 = new Capture<Set<StackConfigurationRequest>>();
Capture<Set<StackConfigurationRequest>> serviceConfigurationRequestCapture2 = new Capture<Set<StackConfigurationRequest>>();
BlueprintConfigEntity blueprintConfig = createNiceMock(BlueprintConfigEntity.class);
BlueprintConfigEntity blueprintConfig2 = createNiceMock(BlueprintConfigEntity.class);
HostGroupEntity hostGroup = createNiceMock(HostGroupEntity.class);
HostGroupComponentEntity hostGroupComponent1 = createNiceMock(HostGroupComponentEntity.class);
HostGroupComponentEntity hostGroupComponent2 = createNiceMock(HostGroupComponentEntity.class);
HostGroupComponentEntity hostGroupComponent3 = createNiceMock(HostGroupComponentEntity.class);
HostGroupComponentEntity hostGroupComponent4 = createNiceMock(HostGroupComponentEntity.class);
HostGroupConfigEntity hostGroupConfig = createNiceMock(HostGroupConfigEntity.class);
ServiceResourceProvider serviceResourceProvider = createStrictMock(ServiceResourceProvider.class);
ResourceProvider componentResourceProvider = createStrictMock(ResourceProvider.class);
ResourceProvider hostResourceProvider = createStrictMock(ResourceProvider.class);
ResourceProvider hostComponentResourceProvider = createStrictMock(ResourceProvider.class);
ConfigGroupResourceProvider configGroupResourceProvider = createStrictMock(ConfigGroupResourceProvider.class);
PersistKeyValueImpl persistKeyValue = createNiceMock(PersistKeyValueImpl.class);
Capture<ClusterRequest> createClusterRequestCapture = new Capture<ClusterRequest>();
Capture<Set<ClusterRequest>> updateClusterRequestCapture = new Capture<Set<ClusterRequest>>();
Capture<Map<String, String>> updateClusterPropertyMapCapture = new Capture<Map<String, String>>();
Capture<Set<ClusterRequest>> updateClusterRequestCapture2 = new Capture<Set<ClusterRequest>>();
Capture<Map<String, String>> updateClusterPropertyMapCapture2 = new Capture<Map<String, String>>();
Capture<Set<ClusterRequest>> updateClusterRequestCapture3 = new Capture<Set<ClusterRequest>>();
Capture<Map<String, String>> updateClusterPropertyMapCapture3 = new Capture<Map<String, String>>();
Capture<Set<ClusterRequest>> updateClusterRequestCapture4 = new Capture<Set<ClusterRequest>>();
Capture<Map<String, String>> updateClusterPropertyMapCapture4 = new Capture<Map<String, String>>();
Capture<Request> serviceRequestCapture = new Capture<Request>();
Capture<Request> componentRequestCapture = new Capture<Request>();
Capture<Request> componentRequestCapture2 = new Capture<Request>();
Capture<Request> hostRequestCapture = new Capture<Request>();
Capture<Request> hostComponentRequestCapture = new Capture<Request>();
Capture<Set<ConfigGroupRequest>> configGroupRequestCapture = new Capture<Set<ConfigGroupRequest>>();
Set<StackServiceResponse> stackServiceResponses = new LinkedHashSet<StackServiceResponse>();
stackServiceResponses.add(stackServiceResponse1);
stackServiceResponses.add(stackServiceResponse2);
// service1 has 3 components
Set<StackServiceComponentResponse> stackServiceComponentResponses1 = new LinkedHashSet<StackServiceComponentResponse>();
stackServiceComponentResponses1.add(stackServiceComponentResponse1);
stackServiceComponentResponses1.add(stackServiceComponentResponse2);
stackServiceComponentResponses1.add(stackServiceComponentResponse4);
// service2 has 1 components
Set<StackServiceComponentResponse> stackServiceComponentResponses2 = new LinkedHashSet<StackServiceComponentResponse>();
stackServiceComponentResponses2.add(stackServiceComponentResponse3);
// service1 has 2 config
Set<StackConfigurationResponse> stackConfigurationResponses1 = new LinkedHashSet<StackConfigurationResponse>();
stackConfigurationResponses1.add(stackConfigurationResponse1);
stackConfigurationResponses1.add(stackConfigurationResponse5);
// service2 has 3 config
Set<StackConfigurationResponse> stackConfigurationResponses2 = new LinkedHashSet<StackConfigurationResponse>();
stackConfigurationResponses2.add(stackConfigurationResponse2);
stackConfigurationResponses2.add(stackConfigurationResponse3);
stackConfigurationResponses2.add(stackConfigurationResponse4);
Collection<HostGroupComponentEntity> hostGroupComponents = new LinkedHashSet<HostGroupComponentEntity>();
hostGroupComponents.add(hostGroupComponent1);
hostGroupComponents.add(hostGroupComponent2);
hostGroupComponents.add(hostGroupComponent3);
hostGroupComponents.add(hostGroupComponent4);
// request properties
Set<Map<String, Object>> propertySet = new LinkedHashSet<Map<String, Object>>();
Map<String, Object> properties = new LinkedHashMap<String, Object>();
properties.put(ClusterResourceProvider.CLUSTER_NAME_PROPERTY_ID, clusterName);
properties.put(ClusterResourceProvider.BLUEPRINT_PROPERTY_ID, blueprintName);
propertySet.add(properties);
Collection<Map<String, Object>> hostGroups = new ArrayList<Map<String, Object>>();
Map<String, Object> hostGroupProperties = new HashMap<String, Object>();
hostGroups.add(hostGroupProperties);
hostGroupProperties.put("name", "group1");
Collection<Map<String, String>> hostGroupHosts = new ArrayList<Map<String, String>>();
hostGroupProperties.put("hosts", hostGroupHosts);
Map<String, String> hostGroupHostProperties = new HashMap<String, String>();
hostGroupHostProperties.put("fqdn", "host.domain");
hostGroupHosts.add(hostGroupHostProperties);
properties.put("host_groups", hostGroups);
Map<String, String> mapGroupConfigProperties = new HashMap<String, String>();
mapGroupConfigProperties.put("myGroupProp", "awesomeValue");
// blueprint core-site cluster configuration properties
Map<String, String> blueprintCoreConfigProperties = new HashMap<String, String>();
blueprintCoreConfigProperties.put("property1", "value2");
blueprintCoreConfigProperties.put("new.property", "new.property.value");
Map<String, String> blueprintGlobalConfigProperties = new HashMap<String, String>();
blueprintGlobalConfigProperties.put("hive_database", "New MySQL Database");
Collection<BlueprintConfigEntity> configurations = new HashSet<BlueprintConfigEntity>();
configurations.add(blueprintConfig);
configurations.add(blueprintConfig2);
// expectations
expect(request.getProperties()).andReturn(propertySet).anyTimes();
expect(blueprintDAO.findByName(blueprintName)).andReturn(blueprint);
expect(blueprint.getStackName()).andReturn(stackName);
expect(blueprint.getStackVersion()).andReturn(stackVersion);
expect(blueprint.getConfigurations()).andReturn(configurations);
expect(blueprint.validateConfigurations(metaInfo, PropertyInfo.PropertyType.PASSWORD)).andReturn(
Collections.<String, Map<String, Collection<String>>>emptyMap());