// 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 com.cloud.network.firewall; import static org.mockito.Matchers.any; import static org.mockito.Matchers.anyBoolean; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; import java.util.ArrayList; import java.util.List; import javax.inject.Inject; import junit.framework.Assert; import org.apache.log4j.Logger; import org.junit.Ignore; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import com.cloud.exception.ResourceUnavailableException; import com.cloud.network.IpAddressManager; import com.cloud.network.Network; import com.cloud.network.NetworkManager; import com.cloud.network.NetworkRuleApplier; import com.cloud.network.element.FirewallServiceProvider; import com.cloud.network.element.VirtualRouterElement; import com.cloud.network.element.VpcVirtualRouterElement; import com.cloud.network.rules.FirewallManager; import com.cloud.network.rules.FirewallRule; import com.cloud.network.rules.FirewallRule.Purpose; import com.cloud.network.rules.FirewallRuleVO; import com.cloud.utils.component.ComponentContext; @Ignore("Requires database to be set up") @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations="classpath:/testContext.xml") //@ComponentSetup(managerName="management-server", setupXml="network-mgr-component.xml") public class FirewallManagerTest { private static final Logger s_logger = Logger.getLogger(FirewallManagerTest.class); // @Before // public void setUp() { // Logger daoLogger = Logger.getLogger(GenericDaoBase.class); // Logger cloudLogger = Logger.getLogger("com.cloud"); // // componentlogger.setLevel(Level.WARN); // daoLogger.setLevel(Level.ERROR); // cloudLogger.setLevel(Level.ERROR); // s_logger.setLevel(Level.INFO); // super.setUp(); // } @Test public void testInjected() { // FirewallManagerImpl firewallMgr = (FirewallManagerImpl)ComponentLocator.getCurrentLocator().getManager(FirewallManager.class); // Assert.assertTrue(firewallMgr._firewallElements.enumeration().hasMoreElements()); // Assert.assertTrue(firewallMgr._pfElements.enumeration().hasMoreElements()); // Assert.assertTrue(firewallMgr._staticNatElements.enumeration().hasMoreElements()); // Assert.assertTrue(firewallMgr._networkAclElements.enumeration().hasMoreElements()); // Assert.assertNotNull(firewallMgr._networkModel); // // Assert.assertNotNull(firewallMgr._firewallElements.get("VirtualRouter")); // Assert.assertNotNull(firewallMgr._firewallElements.get("VpcVirtualRouter")); // Assert.assertNotNull(firewallMgr._pfElements.get("VirtualRouter")); // Assert.assertNotNull(firewallMgr._pfElements.get("VpcVirtualRouter")); // Assert.assertNotNull(firewallMgr._staticNatElements.get("VirtualRouter")); // Assert.assertNotNull(firewallMgr._staticNatElements.get("VpcVirtualRouter")); // Assert.assertNotNull(firewallMgr._networkAclElements.get("VpcVirtualRouter")); // Assert.assertNull(firewallMgr._networkAclElements.get("VirtualRouter")); // // // Assert.assertTrue(firewallMgr._firewallElements.get("VirtualRouter") instanceof FirewallServiceProvider); // Assert.assertTrue(firewallMgr._pfElements.get("VirtualRouter") instanceof PortForwardingServiceProvider); // Assert.assertTrue(firewallMgr._staticNatElements.get("VirtualRouter") instanceof StaticNatServiceProvider); // Assert.assertTrue(firewallMgr._networkAclElements.get("VpcVirtualRouter") instanceof NetworkACLServiceProvider); s_logger.info("Done testing injection of service elements into firewall manager"); } @Inject FirewallManager _firewallMgr; @Test public void testApplyRules() { List ruleList = new ArrayList(); FirewallRuleVO rule = new FirewallRuleVO("rule1", 1, 80, "TCP", 1, 2, 1, FirewallRule.Purpose.Firewall, null, null, null, null); ruleList.add(rule); FirewallManagerImpl firewallMgr = (FirewallManagerImpl)_firewallMgr; NetworkManager netMgr = mock(NetworkManager.class); IpAddressManager addrMgr = mock(IpAddressManager.class); firewallMgr._networkMgr = netMgr; try { firewallMgr.applyRules(ruleList, false, false); verify(addrMgr) .applyRules(any(List.class), any(FirewallRule.Purpose.class), any(NetworkRuleApplier.class), anyBoolean()); } catch (ResourceUnavailableException e) { Assert.fail("Unreachable code"); } } @Test public void testApplyFWRules() { List ruleList = new ArrayList(); FirewallRuleVO rule = new FirewallRuleVO("rule1", 1, 80, "TCP", 1, 2, 1, FirewallRule.Purpose.Firewall, null, null, null, null); ruleList.add(rule); FirewallManagerImpl firewallMgr = (FirewallManagerImpl)_firewallMgr; VirtualRouterElement virtualRouter = mock(VirtualRouterElement.class); VpcVirtualRouterElement vpcVirtualRouter = mock(VpcVirtualRouterElement.class); List fwElements = new ArrayList(); fwElements.add(ComponentContext.inject(VirtualRouterElement.class)); fwElements.add(ComponentContext.inject(VpcVirtualRouterElement.class)); firewallMgr._firewallElements = fwElements; try { when( virtualRouter.applyFWRules(any(Network.class), any(List.class)) ).thenReturn(false); when( vpcVirtualRouter.applyFWRules(any(Network.class), any(List.class)) ).thenReturn(true); //Network network, Purpose purpose, List rules firewallMgr.applyRules(mock(Network.class), Purpose.Firewall, ruleList); verify(vpcVirtualRouter).applyFWRules(any(Network.class), any(List.class)); verify(virtualRouter).applyFWRules(any(Network.class), any(List.class)); } catch (ResourceUnavailableException e) { Assert.fail("Unreachable code"); } } }