/* * 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.brooklyn.entity.salt; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.testng.annotations.BeforeMethod; import org.apache.brooklyn.core.test.BrooklynAppLiveTestSupport; import org.apache.brooklyn.api.location.Location; import org.apache.brooklyn.api.location.MachineProvisioningLocation; import org.apache.brooklyn.api.mgmt.ManagementContext; import org.apache.brooklyn.location.ssh.SshMachineLocation; public class SaltLiveTestSupport extends BrooklynAppLiveTestSupport { private static final Logger log = LoggerFactory.getLogger(SaltLiveTestSupport.class); protected MachineProvisioningLocation<? extends SshMachineLocation> targetLocation; @Override @BeforeMethod(alwaysRun=true) public void setUp() throws Exception { super.setUp(); targetLocation = createLocation(); } protected MachineProvisioningLocation<? extends SshMachineLocation> createLocation() { return createLocation(mgmt); } /** * Convenience for setting up a pre-built or fixed IP machine. * <p> * Useful if you are unable to set up Salt on localhost, * and for ensuring tests against Salt always use the same * configured location. */ @SuppressWarnings("unchecked") public static MachineProvisioningLocation<? extends SshMachineLocation> createLocation(ManagementContext mgmt) { Location bestLocation = mgmt.getLocationRegistry().resolveIfPossible("named:SaltTests"); if (bestLocation==null) { log.info("using AWS for salt tests because named:SaltTests does not exist"); bestLocation = mgmt.getLocationRegistry().resolveIfPossible("jclouds:aws-ec2:us-east-1"); } if (bestLocation==null) { throw new IllegalStateException("Need a location called named:SaltTests or AWS configured for these tests"); } return (MachineProvisioningLocation<? extends SshMachineLocation>)bestLocation; } }