| /** |
| * 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 |
| * <p> |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * <p> |
| * 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 org.apache.ambari.server.controller.predicate.EqualsPredicate; |
| import org.apache.ambari.server.controller.spi.Resource; |
| import org.apache.ambari.server.controller.utilities.PropertyHelper; |
| import org.apache.ambari.server.orm.dao.RemoteAmbariClusterDAO; |
| import org.apache.ambari.server.orm.entities.RemoteAmbariClusterEntity; |
| import org.apache.ambari.server.orm.entities.RemoteAmbariClusterServiceEntity; |
| import org.apache.ambari.server.security.TestAuthenticationFactory; |
| import org.apache.ambari.server.view.RemoteAmbariClusterRegistry; |
| import org.easymock.Capture; |
| import org.junit.After; |
| import org.junit.Test; |
| import org.springframework.security.core.Authentication; |
| import org.springframework.security.core.context.SecurityContextHolder; |
| |
| import java.lang.reflect.Field; |
| import java.lang.reflect.Modifier; |
| import java.util.ArrayList; |
| import java.util.HashMap; |
| import java.util.HashSet; |
| import java.util.List; |
| import java.util.Map; |
| import java.util.Set; |
| |
| import static org.easymock.EasyMock.capture; |
| import static org.easymock.EasyMock.createMock; |
| import static org.easymock.EasyMock.createNiceMock; |
| import static org.easymock.EasyMock.eq; |
| import static org.easymock.EasyMock.expect; |
| import static org.easymock.EasyMock.newCapture; |
| import static org.easymock.EasyMock.replay; |
| import static org.easymock.EasyMock.verify; |
| import static org.junit.Assert.assertEquals; |
| |
| public class RemoteClusterResourceProviderTest { |
| |
| @After |
| public void clearAuthentication() { |
| SecurityContextHolder.getContext().setAuthentication(null); |
| } |
| |
| @Test |
| public void testToResource() throws Exception { |
| RemoteClusterResourceProvider provider = new RemoteClusterResourceProvider(); |
| Set<String> propertyIds = new HashSet<String>(); |
| propertyIds.add(RemoteClusterResourceProvider.CLUSTER_NAME_PROPERTY_ID); |
| propertyIds.add(RemoteClusterResourceProvider.CLUSTER_URL_PROPERTY_ID); |
| propertyIds.add(RemoteClusterResourceProvider.USERNAME_PROPERTY_ID); |
| propertyIds.add(RemoteClusterResourceProvider.PASSWORD_PROPERTY_ID); |
| propertyIds.add(RemoteClusterResourceProvider.SERVICES_PROPERTY_ID); |
| |
| RemoteAmbariClusterServiceEntity service1 = createNiceMock(RemoteAmbariClusterServiceEntity.class); |
| expect(service1.getServiceName()).andReturn("service1").once(); |
| |
| RemoteAmbariClusterServiceEntity service2 = createNiceMock(RemoteAmbariClusterServiceEntity.class); |
| expect(service2.getServiceName()).andReturn("service2").once(); |
| |
| List<RemoteAmbariClusterServiceEntity> serviceList = new ArrayList<RemoteAmbariClusterServiceEntity>(); |
| serviceList.add(service1); |
| serviceList.add(service2); |
| |
| RemoteAmbariClusterEntity entity = createNiceMock(RemoteAmbariClusterEntity.class); |
| expect(entity.getName()).andReturn("test").once(); |
| expect(entity.getUrl()).andReturn("url").once(); |
| expect(entity.getUsername()).andReturn("user").once(); |
| expect(entity.getServices()).andReturn(serviceList).once(); |
| |
| replay(service1, service2, entity); |
| |
| List<String> services = new ArrayList<String>(); |
| services.add("service1"); |
| services.add("service2"); |
| |
| Resource resource = provider.toResource(propertyIds, entity); |
| assertEquals(resource.getPropertyValue(RemoteClusterResourceProvider.CLUSTER_NAME_PROPERTY_ID), "test"); |
| assertEquals(resource.getPropertyValue(RemoteClusterResourceProvider.CLUSTER_URL_PROPERTY_ID), "url"); |
| assertEquals(resource.getPropertyValue(RemoteClusterResourceProvider.USERNAME_PROPERTY_ID), "user"); |
| assertEquals(resource.getPropertyValue(RemoteClusterResourceProvider.SERVICES_PROPERTY_ID), services); |
| verify(service1, service2, entity); |
| } |
| |
| @Test |
| public void testCreateResourcesAsAdministrator() throws Exception { |
| testCreateResources(TestAuthenticationFactory.createAdministrator()); |
| } |
| |
| static void setField(Field field, Object newValue) throws Exception { |
| field.setAccessible(true); |
| |
| Field modifiersField = Field.class.getDeclaredField("modifiers"); |
| modifiersField.setAccessible(true); |
| modifiersField.setInt(field, field.getModifiers() & ~Modifier.FINAL); |
| field.set(null, newValue); |
| } |
| |
| private void testCreateResources(Authentication authentication) throws Exception { |
| |
| RemoteClusterResourceProvider provider = new RemoteClusterResourceProvider(); |
| |
| RemoteAmbariClusterDAO clusterDAO = createMock(RemoteAmbariClusterDAO.class); |
| setField(RemoteClusterResourceProvider.class.getDeclaredField("remoteAmbariClusterDAO"), clusterDAO); |
| |
| RemoteAmbariClusterRegistry clusterRegistry = createMock(RemoteAmbariClusterRegistry.class); |
| setField(RemoteClusterResourceProvider.class.getDeclaredField("remoteAmbariClusterRegistry"), clusterRegistry); |
| |
| Set<Map<String, Object>> properties = new HashSet<>(); |
| Map<String, Object> propertyMap = new HashMap<>(); |
| propertyMap.put(RemoteClusterResourceProvider.CLUSTER_NAME_PROPERTY_ID, "test"); |
| propertyMap.put(RemoteClusterResourceProvider.CLUSTER_URL_PROPERTY_ID, "url"); |
| propertyMap.put(RemoteClusterResourceProvider.USERNAME_PROPERTY_ID, "username"); |
| propertyMap.put(RemoteClusterResourceProvider.PASSWORD_PROPERTY_ID, "password"); |
| |
| RemoteAmbariClusterServiceEntity service1 = createNiceMock(RemoteAmbariClusterServiceEntity.class); |
| expect(service1.getServiceName()).andReturn("service1").once(); |
| |
| RemoteAmbariClusterServiceEntity service2 = createNiceMock(RemoteAmbariClusterServiceEntity.class); |
| expect(service2.getServiceName()).andReturn("service2").once(); |
| |
| List<RemoteAmbariClusterServiceEntity> serviceList = new ArrayList<RemoteAmbariClusterServiceEntity>(); |
| serviceList.add(service1); |
| serviceList.add(service2); |
| |
| expect(clusterDAO.findByName("test")).andReturn(null).anyTimes(); |
| Capture<RemoteAmbariClusterEntity> clusterEntityCapture = newCapture(); |
| |
| clusterRegistry.saveOrUpdate(capture(clusterEntityCapture),eq(false)); |
| |
| replay(clusterRegistry, clusterDAO, service1, service2); |
| |
| properties.add(propertyMap); |
| |
| SecurityContextHolder.getContext().setAuthentication(authentication); |
| |
| provider.createResources(PropertyHelper.getCreateRequest(properties, null)); |
| |
| RemoteAmbariClusterEntity clusterEntity = clusterEntityCapture.getValue(); |
| assertEquals(clusterEntity.getName(), "test"); |
| assertEquals(clusterEntity.getPassword(), "password"); |
| assertEquals(clusterEntity.getUrl(), "url"); |
| assertEquals(clusterEntity.getUsername(), "username"); |
| |
| } |
| |
| @Test |
| public void testDeleteResources() throws Exception { |
| RemoteClusterResourceProvider provider = new RemoteClusterResourceProvider(); |
| RemoteAmbariClusterDAO clusterDAO = createNiceMock(RemoteAmbariClusterDAO.class); |
| RemoteAmbariClusterEntity clusterEntity = new RemoteAmbariClusterEntity(); |
| |
| setField(RemoteClusterResourceProvider.class.getDeclaredField("remoteAmbariClusterDAO"), clusterDAO); |
| |
| EqualsPredicate equalsPredicate = new EqualsPredicate(RemoteClusterResourceProvider.CLUSTER_NAME_PROPERTY_ID,"test"); |
| |
| RemoteAmbariClusterRegistry clusterRegistry = createMock(RemoteAmbariClusterRegistry.class); |
| setField(RemoteClusterResourceProvider.class.getDeclaredField("remoteAmbariClusterRegistry"), clusterRegistry); |
| |
| Set<Map<String, Object>> properties = new HashSet<>(); |
| Map<String, Object> propertyMap = new HashMap<>(); |
| propertyMap.put(RemoteClusterResourceProvider.CLUSTER_NAME_PROPERTY_ID,"test"); |
| |
| expect(clusterDAO.findByName("test")).andReturn(clusterEntity); |
| clusterRegistry.delete(clusterEntity); |
| |
| replay(clusterDAO); |
| |
| properties.add(propertyMap); |
| |
| SecurityContextHolder.getContext().setAuthentication(TestAuthenticationFactory.createAdministrator()); |
| |
| provider.deleteResources(PropertyHelper.getCreateRequest(properties, null),equalsPredicate); |
| |
| } |
| |
| } |