blob: e1ebc1941001aaa45c62e9a818624639d1577226 [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.ambari.server.controller.internal;
import java.util.Collections;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import junit.framework.Assert;
import org.apache.ambari.server.controller.spi.Request;
import org.apache.ambari.server.controller.spi.Resource;
import org.apache.ambari.server.controller.utilities.PropertyHelper;
import org.junit.Test;
/**
*
*/
public class RequestImplTest {
private static final Set<String> propertyIds = new HashSet<>();
static {
propertyIds.add(PropertyHelper.getPropertyId("c1", "p1"));
propertyIds.add(PropertyHelper.getPropertyId("c1", "p2"));
propertyIds.add(PropertyHelper.getPropertyId("c2", "p3"));
propertyIds.add(PropertyHelper.getPropertyId("c3", "p4"));
}
@Test
public void testGetPropertyIds() {
Request request = PropertyHelper.getReadRequest(propertyIds);
Assert.assertEquals(propertyIds, request.getPropertyIds());
}
@Test
public void testValidPropertyIds() {
Request request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.HostComponent));
Set<String> validPropertyIds = request.getPropertyIds();
//HostComponent resource properties
Assert.assertFalse(validPropertyIds.contains("HostRoles/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("params/run_smoke_test"));
Assert.assertTrue(validPropertyIds.contains("HostRoles/actual_configs"));
Assert.assertTrue(validPropertyIds.contains("HostRoles/desired_stack_id"));
Assert.assertTrue(validPropertyIds.contains("HostRoles/stack_id"));
Assert.assertTrue(validPropertyIds.contains("HostRoles/desired_state"));
Assert.assertTrue(validPropertyIds.contains("HostRoles/state"));
Assert.assertTrue(validPropertyIds.contains("HostRoles/component_name"));
Assert.assertTrue(validPropertyIds.contains("HostRoles/host_name"));
Assert.assertTrue(validPropertyIds.contains("HostRoles/cluster_name"));
Assert.assertTrue(validPropertyIds.contains("HostRoles/role_id"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.Cluster));
validPropertyIds = request.getPropertyIds();
//Cluster resource properties
Assert.assertFalse(validPropertyIds.contains("Clusters/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("Clusters/cluster_id"));
Assert.assertTrue(validPropertyIds.contains("Clusters/cluster_name"));
Assert.assertTrue(validPropertyIds.contains("Clusters/version"));
Assert.assertTrue(validPropertyIds.contains("Clusters/state"));
Assert.assertTrue(validPropertyIds.contains("Clusters/desired_configs"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.Service));
validPropertyIds = request.getPropertyIds();
//Service resource properties
Assert.assertFalse(validPropertyIds.contains("ServiceInfo/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("ServiceInfo/service_name"));
Assert.assertTrue(validPropertyIds.contains("ServiceInfo/cluster_name"));
Assert.assertTrue(validPropertyIds.contains("ServiceInfo/state"));
Assert.assertTrue(validPropertyIds.contains("Services/description"));
Assert.assertTrue(validPropertyIds.contains("Services/display_name"));
Assert.assertTrue(validPropertyIds.contains("Services/attributes"));
Assert.assertTrue(validPropertyIds.contains("params/run_smoke_test"));
Assert.assertTrue(validPropertyIds.contains("params/reconfigure_client"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.Host));
validPropertyIds = request.getPropertyIds();
//Host resource properties
Assert.assertFalse(validPropertyIds.contains("Hosts/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("Hosts/cluster_name"));
Assert.assertTrue(validPropertyIds.contains("Hosts/host_name"));
Assert.assertTrue(validPropertyIds.contains("Hosts/ip"));
Assert.assertTrue(validPropertyIds.contains("Hosts/attributes"));
Assert.assertTrue(validPropertyIds.contains("Hosts/total_mem"));
Assert.assertTrue(validPropertyIds.contains("Hosts/cpu_count"));
Assert.assertTrue(validPropertyIds.contains("Hosts/ph_cpu_count"));
Assert.assertTrue(validPropertyIds.contains("Hosts/os_arch"));
Assert.assertTrue(validPropertyIds.contains("Hosts/os_type"));
Assert.assertTrue(validPropertyIds.contains("Hosts/rack_info"));
Assert.assertTrue(validPropertyIds.contains("Hosts/last_heartbeat_time"));
Assert.assertTrue(validPropertyIds.contains("Hosts/last_agent_env"));
Assert.assertTrue(validPropertyIds.contains("Hosts/last_registration_time"));
Assert.assertTrue(validPropertyIds.contains("Hosts/disk_info"));
Assert.assertTrue(validPropertyIds.contains("Hosts/host_status"));
Assert.assertTrue(validPropertyIds.contains("Hosts/host_health_report"));
Assert.assertTrue(validPropertyIds.contains("Hosts/public_host_name"));
Assert.assertTrue(validPropertyIds.contains("Hosts/host_state"));
Assert.assertTrue(validPropertyIds.contains("Hosts/desired_configs"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.Component));
validPropertyIds = request.getPropertyIds();
//Component resource properties
Assert.assertFalse(validPropertyIds.contains("ServiceComponentInfo/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("ServiceComponentInfo/service_name"));
Assert.assertTrue(validPropertyIds.contains("ServiceComponentInfo/component_name"));
Assert.assertTrue(validPropertyIds.contains("ServiceComponentInfo/cluster_name"));
Assert.assertTrue(validPropertyIds.contains("ServiceComponentInfo/state"));
Assert.assertTrue(validPropertyIds.contains("ServiceComponents/display_name"));
Assert.assertTrue(validPropertyIds.contains("ServiceComponents/description"));
Assert.assertTrue(validPropertyIds.contains("params/run_smoke_test"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.Action));
validPropertyIds = request.getPropertyIds();
//Action resource properties
Assert.assertFalse(validPropertyIds.contains("Action/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("Actions/action_name"));
Assert.assertTrue(validPropertyIds.contains("Actions/action_type"));
Assert.assertTrue(validPropertyIds.contains("Actions/inputs"));
Assert.assertTrue(validPropertyIds.contains("Actions/target_service"));
Assert.assertTrue(validPropertyIds.contains("Actions/target_component"));
Assert.assertTrue(validPropertyIds.contains("Actions/description"));
Assert.assertTrue(validPropertyIds.contains("Actions/target_type"));
Assert.assertTrue(validPropertyIds.contains("Actions/default_timeout"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.Request));
validPropertyIds = request.getPropertyIds();
//Request resource properties
Assert.assertFalse(validPropertyIds.contains("Requests/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("Requests/id"));
Assert.assertTrue(validPropertyIds.contains("Requests/cluster_name"));
Assert.assertTrue(validPropertyIds.contains("Requests/request_status"));
Assert.assertTrue(validPropertyIds.contains("Requests/request_context"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.Task));
validPropertyIds = request.getPropertyIds();
//Task resource properties
Assert.assertFalse(validPropertyIds.contains("Task/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("Tasks/id"));
Assert.assertTrue(validPropertyIds.contains("Tasks/request_id"));
Assert.assertTrue(validPropertyIds.contains("Tasks/cluster_name"));
Assert.assertTrue(validPropertyIds.contains("Tasks/stage_id"));
Assert.assertTrue(validPropertyIds.contains("Tasks/host_name"));
Assert.assertTrue(validPropertyIds.contains("Tasks/command"));
Assert.assertTrue(validPropertyIds.contains("Tasks/role"));
Assert.assertTrue(validPropertyIds.contains("Tasks/status"));
Assert.assertTrue(validPropertyIds.contains("Tasks/exit_code"));
Assert.assertTrue(validPropertyIds.contains("Tasks/stderr"));
Assert.assertTrue(validPropertyIds.contains("Tasks/stdout"));
Assert.assertTrue(validPropertyIds.contains("Tasks/start_time"));
Assert.assertTrue(validPropertyIds.contains("Tasks/attempt_cnt"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.User));
validPropertyIds = request.getPropertyIds();
//User resource properties
Assert.assertFalse(validPropertyIds.contains("Users/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("Users/user_name"));
Assert.assertTrue(validPropertyIds.contains("Users/password"));
Assert.assertTrue(validPropertyIds.contains("Users/old_password"));
Assert.assertTrue(validPropertyIds.contains("Users/ldap_user"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.Stack));
validPropertyIds = request.getPropertyIds();
//Stack resource properties
Assert.assertFalse(validPropertyIds.contains("Stacks/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("Stacks/stack_name"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.StackVersion));
validPropertyIds = request.getPropertyIds();
//StackVersion resource properties
Assert.assertFalse(validPropertyIds.contains("Versions/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("Versions/stack_name"));
Assert.assertTrue(validPropertyIds.contains("Versions/stack_version"));
Assert.assertTrue(validPropertyIds.contains("Versions/min_upgrade_version"));
request = PropertyHelper.getReadRequest(OperatingSystemResourceProvider.propertyIds);
validPropertyIds = request.getPropertyIds();
//OperatingSystem resource properties
Assert.assertFalse(validPropertyIds.contains("OperatingSystems/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("OperatingSystems/stack_name"));
Assert.assertTrue(validPropertyIds.contains("OperatingSystems/stack_version"));
Assert.assertTrue(validPropertyIds.contains("OperatingSystems/os_type"));
request = PropertyHelper.getReadRequest(RepositoryResourceProvider.propertyIds);
validPropertyIds = request.getPropertyIds();
//Repository resource properties
Assert.assertFalse(validPropertyIds.contains("Repositories/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("Repositories/stack_name"));
Assert.assertTrue(validPropertyIds.contains("Repositories/stack_version"));
Assert.assertTrue(validPropertyIds.contains("Repositories/os_type"));
Assert.assertTrue(validPropertyIds.contains("Repositories/base_url"));
Assert.assertTrue(validPropertyIds.contains("Repositories/repo_id"));
Assert.assertTrue(validPropertyIds.contains("Repositories/repo_name"));
Assert.assertTrue(validPropertyIds.contains("Repositories/mirrors_list"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.StackService));
validPropertyIds = request.getPropertyIds();
//Repository resource properties
Assert.assertFalse(validPropertyIds.contains("StackServices/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("StackServices/stack_name"));
Assert.assertTrue(validPropertyIds.contains("StackServices/stack_version"));
Assert.assertTrue(validPropertyIds.contains("StackServices/service_name"));
Assert.assertTrue(validPropertyIds.contains("StackServices/user_name"));
Assert.assertTrue(validPropertyIds.contains("StackServices/comments"));
Assert.assertTrue(validPropertyIds.contains("StackServices/service_version"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.StackConfiguration));
validPropertyIds = request.getPropertyIds();
//StackConfigurations resource properties
Assert.assertFalse(validPropertyIds.contains("StackConfigurations/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("StackConfigurations/stack_name"));
Assert.assertTrue(validPropertyIds.contains("StackConfigurations/stack_version"));
Assert.assertTrue(validPropertyIds.contains("StackConfigurations/service_name"));
Assert.assertTrue(validPropertyIds.contains("StackConfigurations/property_name"));
Assert.assertTrue(validPropertyIds.contains("StackConfigurations/property_description"));
Assert.assertTrue(validPropertyIds.contains("StackConfigurations/property_value"));
request = PropertyHelper.getReadRequest(PropertyHelper.getPropertyIds(Resource.Type.StackServiceComponent));
validPropertyIds = request.getPropertyIds();
//StackServiceComponent resource properties
Assert.assertFalse(validPropertyIds.contains("StackServiceComponents/unsupported_property_id"));
Assert.assertTrue(validPropertyIds.contains("StackServiceComponents/stack_version"));
Assert.assertTrue(validPropertyIds.contains("StackServiceComponents/stack_name"));
Assert.assertTrue(validPropertyIds.contains("StackServiceComponents/service_name"));
Assert.assertTrue(validPropertyIds.contains("StackServiceComponents/component_name"));
Assert.assertTrue(validPropertyIds.contains("StackServiceComponents/component_category"));
Assert.assertTrue(validPropertyIds.contains("StackServiceComponents/is_master"));
Assert.assertTrue(validPropertyIds.contains("StackServiceComponents/is_client"));
}
@Test
public void testDryRunRequest() {
Request dryRunRequest = PropertyHelper.getCreateRequest(Collections.<Map<String,Object>>emptySet(), Collections.singletonMap(Request.DIRECTIVE_DRY_RUN, "true"));
Request nonDryRunReqest1 = PropertyHelper.getCreateRequest(Collections.<Map<String,Object>>emptySet(), Collections.singletonMap(Request.DIRECTIVE_DRY_RUN, "false"));
Request nonDryRunReqest2 = PropertyHelper.getCreateRequest(Collections.<Map<String,Object>>emptySet(), Collections.<String, String>emptyMap());
Assert.assertTrue(dryRunRequest.isDryRunRequest());
Assert.assertFalse(nonDryRunReqest1.isDryRunRequest());
Assert.assertFalse(nonDryRunReqest2.isDryRunRequest());
}
}