Skip to content

Commit

Permalink
Byon dsl config - fix tests failures
Browse files Browse the repository at this point in the history
  • Loading branch information
ivanayov committed Aug 7, 2017
1 parent 58847c1 commit 946c0de
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,7 @@ public void testWindowsMachinesNoExternalIPProvider() throws Exception {
waitForApplicationTasks(app);
Asserts.shouldHaveFailedPreviously();
} catch (Exception e) {
Asserts.expectedFailureOfType(e, NullPointerException.class);
Asserts.expectedFailureContains(e, "Must specify exactly one of 'ssh' or 'winrm' for machine");
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
import java.util.Map;
import java.util.Set;

import com.google.common.base.Preconditions;
import com.google.common.net.HostAndPort;
import org.apache.brooklyn.api.location.Location;
import org.apache.brooklyn.api.location.LocationSpec;
Expand Down Expand Up @@ -384,7 +385,10 @@ protected void updateMachineConfig(T machine, Map<?, ?> flags) {
// For backwards compatibility, where peristed state did not have this.
origConfigs = Maps.newLinkedHashMap();
}
parseMachineConfig((AbstractLocation) machine);
if (((AbstractLocation) machine).config().getBag().getAllConfig().get("provider") != null &&
((AbstractLocation) machine).config().getBag().getAllConfig().get("provider").equals("byon")) {
parseMachineConfig((AbstractLocation) machine);
}
Map<String, Object> strFlags = ConfigBag.newInstance(flags).getAllConfig();
Map<String, Object> origConfig = ((ConfigurationSupportInternal)machine.config()).getLocalBag().getAllConfig();
origConfigs.put(machine, origConfig);
Expand All @@ -399,12 +403,14 @@ private void parseMachineConfig(AbstractLocation machine) {
String winrm = machine.config().get(ConfigKeys.newStringConfigKey("winrm"));
machine.config().removeKey(ConfigKeys.newStringConfigKey("winrm"));

Map<Integer, String> tcpPortMappings = (Map<Integer, String>) machine.config().get(ConfigKeys.newConfigKey(Map.class, "tcpPortMappings"));

if (ssh == null && winrm == null) {
throw new IllegalArgumentException("Must specify exactly one of 'ssh' or 'winrm' for machine: "+machine);
if (ssh ==null && winrm == null && machine.config().get(ConfigKeys.newStringConfigKey("address")) != null) {
return;
}

Preconditions.checkArgument(ssh != null || winrm != null, "Must specify exactly one of 'ssh' or 'winrm' for machine: " + machine);

Map<Integer, String> tcpPortMappings = (Map<Integer, String>) machine.config().get(ConfigKeys.newConfigKey(Map.class, "tcpPortMappings"));

UserAndHostAndPort userAndHostAndPort;
String host;
int port;
Expand Down

0 comments on commit 946c0de

Please sign in to comment.