mirror of https://github.com/apache/jclouds.git
Merge branch 'develop' of https://github.com/andreaturli/jclouds into pull-323
- Changed 'vboxmanage' to 'VBoxManage' - Did some additional cleanup on the commit. Removed some unused code and some other tidying.
This commit is contained in:
commit
02353b93d5
|
@ -22,7 +22,6 @@ import com.google.common.base.Function;
|
||||||
import com.google.common.base.Predicate;
|
import com.google.common.base.Predicate;
|
||||||
import com.google.common.base.Supplier;
|
import com.google.common.base.Supplier;
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
import org.jclouds.compute.callables.RunScriptOnNode;
|
|
||||||
import org.jclouds.compute.callables.RunScriptOnNode.Factory;
|
import org.jclouds.compute.callables.RunScriptOnNode.Factory;
|
||||||
import org.jclouds.compute.domain.NodeMetadata;
|
import org.jclouds.compute.domain.NodeMetadata;
|
||||||
import org.jclouds.compute.reference.ComputeServiceConstants;
|
import org.jclouds.compute.reference.ComputeServiceConstants;
|
||||||
|
@ -34,10 +33,8 @@ import org.jclouds.virtualbox.domain.IMachineSpec;
|
||||||
import org.jclouds.virtualbox.domain.IsoSpec;
|
import org.jclouds.virtualbox.domain.IsoSpec;
|
||||||
import org.jclouds.virtualbox.domain.VmSpec;
|
import org.jclouds.virtualbox.domain.VmSpec;
|
||||||
import org.jclouds.virtualbox.settings.KeyboardScancodes;
|
import org.jclouds.virtualbox.settings.KeyboardScancodes;
|
||||||
import org.virtualbox_4_1.IMachine;
|
import org.jclouds.virtualbox.util.MachineUtils;
|
||||||
import org.virtualbox_4_1.IProgress;
|
import org.virtualbox_4_1.*;
|
||||||
import org.virtualbox_4_1.ISession;
|
|
||||||
import org.virtualbox_4_1.VirtualBoxManager;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import javax.inject.Named;
|
import javax.inject.Named;
|
||||||
|
@ -46,9 +43,6 @@ import java.net.URI;
|
||||||
|
|
||||||
import static com.google.common.base.Preconditions.checkState;
|
import static com.google.common.base.Preconditions.checkState;
|
||||||
import static org.jclouds.compute.options.RunScriptOptions.Builder.runAsRoot;
|
import static org.jclouds.compute.options.RunScriptOptions.Builder.runAsRoot;
|
||||||
import static org.jclouds.virtualbox.util.MachineUtils.applyForMachine;
|
|
||||||
import static org.jclouds.virtualbox.util.MachineUtils.lockSessionOnMachineAndApply;
|
|
||||||
import static org.virtualbox_4_1.LockType.Shared;
|
|
||||||
|
|
||||||
@Singleton
|
@Singleton
|
||||||
public class CreateAndInstallVm implements Function<IMachineSpec, IMachine> {
|
public class CreateAndInstallVm implements Function<IMachineSpec, IMachine> {
|
||||||
|
@ -68,11 +62,16 @@ public class CreateAndInstallVm implements Function<IMachineSpec, IMachine> {
|
||||||
|
|
||||||
private final Function<IMachine, SshClient> sshClientForIMachine;
|
private final Function<IMachine, SshClient> sshClientForIMachine;
|
||||||
|
|
||||||
|
private final MachineUtils machineUtils;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public CreateAndInstallVm(Supplier<VirtualBoxManager> manager,
|
public CreateAndInstallVm(
|
||||||
CreateAndRegisterMachineFromIsoIfNotAlreadyExists CreateAndRegisterMachineFromIsoIfNotAlreadyExists,
|
Supplier<VirtualBoxManager> manager,
|
||||||
Predicate<SshClient> sshResponds, Function<IMachine, SshClient> sshClientForIMachine,
|
CreateAndRegisterMachineFromIsoIfNotAlreadyExists CreateAndRegisterMachineFromIsoIfNotAlreadyExists,
|
||||||
Supplier<NodeMetadata> host, RunScriptOnNode.Factory scriptRunner, ExecutionType executionType) {
|
Predicate<SshClient> sshResponds,
|
||||||
|
Function<IMachine, SshClient> sshClientForIMachine,
|
||||||
|
Supplier<NodeMetadata> host, Factory scriptRunner,
|
||||||
|
ExecutionType executionType, MachineUtils machineUtils) {
|
||||||
this.manager = manager;
|
this.manager = manager;
|
||||||
this.createAndRegisterMachineFromIsoIfNotAlreadyExists = CreateAndRegisterMachineFromIsoIfNotAlreadyExists;
|
this.createAndRegisterMachineFromIsoIfNotAlreadyExists = CreateAndRegisterMachineFromIsoIfNotAlreadyExists;
|
||||||
this.sshResponds = sshResponds;
|
this.sshResponds = sshResponds;
|
||||||
|
@ -80,6 +79,7 @@ public class CreateAndInstallVm implements Function<IMachineSpec, IMachine> {
|
||||||
this.scriptRunner = scriptRunner;
|
this.scriptRunner = scriptRunner;
|
||||||
this.host = host;
|
this.host = host;
|
||||||
this.executionType = executionType;
|
this.executionType = executionType;
|
||||||
|
this.machineUtils = machineUtils;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -90,37 +90,45 @@ public class CreateAndInstallVm implements Function<IMachineSpec, IMachine> {
|
||||||
|
|
||||||
String vmName = vmSpec.getVmName();
|
String vmName = vmSpec.getVmName();
|
||||||
|
|
||||||
final IMachine vm = createAndRegisterMachineFromIsoIfNotAlreadyExists.apply(machineSpec);
|
final IMachine vm = createAndRegisterMachineFromIsoIfNotAlreadyExists
|
||||||
|
.apply(machineSpec);
|
||||||
|
|
||||||
// Launch machine and wait for it to come online
|
// Launch machine and wait for it to come online
|
||||||
ensureMachineIsLaunched(vmName);
|
ensureMachineIsLaunched(vmName);
|
||||||
|
|
||||||
URI uri = isoSpec.getPreConfigurationUri().get();
|
URI uri = isoSpec.getPreConfigurationUri().get();
|
||||||
String installationKeySequence = isoSpec.getInstallationKeySequence()
|
String installationKeySequence = isoSpec.getInstallationKeySequence()
|
||||||
.replace("PRECONFIGURATION_URL", uri.toASCIIString());
|
.replace("PRECONFIGURATION_URL", uri.toASCIIString());
|
||||||
sendKeyboardSequence(installationKeySequence, vmName);
|
sendKeyboardSequence(installationKeySequence, vmName);
|
||||||
|
|
||||||
SshClient client = sshClientForIMachine.apply(vm);
|
SshClient client = sshClientForIMachine.apply(vm);
|
||||||
|
|
||||||
logger.debug(">> awaiting installation to finish node(%s)", vmName);
|
logger.debug(">> awaiting installation to finish node(%s)", vmName);
|
||||||
checkState(sshResponds.apply(client), "timed out waiting for guest %s to be accessible via ssh", vmName);
|
|
||||||
|
|
||||||
logger.debug("<< installation of image complete. Powering down node(%s)", vmName);
|
checkState(sshResponds.apply(client),
|
||||||
lockSessionOnMachineAndApply(manager.get(), Shared, vmName, new Function<ISession, Void>() {
|
"timed out waiting for guest %s to be accessible via ssh", vmName);
|
||||||
|
|
||||||
@Override
|
logger.debug("<< installation of image complete. Powering down node(%s)",
|
||||||
public Void apply(ISession session) {
|
vmName);
|
||||||
IProgress powerDownProgress = session.getConsole().powerDown();
|
ensureMachineHasPowerDown(vmName);
|
||||||
powerDownProgress.waitForCompletion(-1);
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
|
||||||
return vm;
|
return vm;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void ensureMachineHasPowerDown(String vmName) {
|
||||||
|
machineUtils.lockSessionOnMachineAndApply(vmName, LockType.Shared,
|
||||||
|
new Function<ISession, Void>() {
|
||||||
|
@Override
|
||||||
|
public Void apply(ISession session) {
|
||||||
|
IProgress powerDownProgress = session.getConsole()
|
||||||
|
.powerDown();
|
||||||
|
powerDownProgress.waitForCompletion(-1);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
private void ensureMachineIsLaunched(String vmName) {
|
private void ensureMachineIsLaunched(String vmName) {
|
||||||
applyForMachine(manager.get(), vmName,
|
machineUtils.applyForMachine(vmName,
|
||||||
new LaunchMachineIfNotAlreadyRunning(manager.get(), executionType,
|
new LaunchMachineIfNotAlreadyRunning(manager.get(), executionType,
|
||||||
""));
|
""));
|
||||||
}
|
}
|
||||||
|
@ -131,7 +139,7 @@ public class CreateAndInstallVm implements Function<IMachineSpec, IMachine> {
|
||||||
for (String line : splitSequence) {
|
for (String line : splitSequence) {
|
||||||
String converted = stringToKeycode(line);
|
String converted = stringToKeycode(line);
|
||||||
for (String word : converted.split(" ")) {
|
for (String word : converted.split(" ")) {
|
||||||
sb.append("vboxmanage controlvm ").append(vmName)
|
sb.append("VBoxManage controlvm ").append(vmName)
|
||||||
.append(" keyboardputscancode ").append(word).append("; ");
|
.append(" keyboardputscancode ").append(word).append("; ");
|
||||||
runScriptIfWordEndsWith(sb, word, "<Enter>");
|
runScriptIfWordEndsWith(sb, word, "<Enter>");
|
||||||
runScriptIfWordEndsWith(sb, word, "<Return>");
|
runScriptIfWordEndsWith(sb, word, "<Return>");
|
||||||
|
|
|
@ -20,8 +20,6 @@
|
||||||
package org.jclouds.virtualbox.functions;
|
package org.jclouds.virtualbox.functions;
|
||||||
|
|
||||||
import static com.google.common.base.Preconditions.checkNotNull;
|
import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
import static org.jclouds.virtualbox.util.MachineUtils.lockMachineAndApply;
|
|
||||||
import static org.virtualbox_4_1.LockType.Write;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -36,7 +34,15 @@ import javax.inject.Singleton;
|
||||||
import org.jclouds.compute.reference.ComputeServiceConstants;
|
import org.jclouds.compute.reference.ComputeServiceConstants;
|
||||||
import org.jclouds.logging.Logger;
|
import org.jclouds.logging.Logger;
|
||||||
import org.jclouds.virtualbox.config.VirtualBoxConstants;
|
import org.jclouds.virtualbox.config.VirtualBoxConstants;
|
||||||
import org.jclouds.virtualbox.domain.*;
|
import org.jclouds.virtualbox.domain.DeviceDetails;
|
||||||
|
import org.jclouds.virtualbox.domain.HardDisk;
|
||||||
|
import org.jclouds.virtualbox.domain.IMachineSpec;
|
||||||
|
import org.jclouds.virtualbox.domain.IsoImage;
|
||||||
|
import org.jclouds.virtualbox.domain.NatAdapter;
|
||||||
|
import org.jclouds.virtualbox.domain.NetworkSpec;
|
||||||
|
import org.jclouds.virtualbox.domain.StorageController;
|
||||||
|
import org.jclouds.virtualbox.domain.VmSpec;
|
||||||
|
import org.jclouds.virtualbox.util.MachineUtils;
|
||||||
import org.virtualbox_4_1.AccessMode;
|
import org.virtualbox_4_1.AccessMode;
|
||||||
import org.virtualbox_4_1.DeviceType;
|
import org.virtualbox_4_1.DeviceType;
|
||||||
import org.virtualbox_4_1.IMachine;
|
import org.virtualbox_4_1.IMachine;
|
||||||
|
@ -59,12 +65,15 @@ public class CreateAndRegisterMachineFromIsoIfNotAlreadyExists implements Functi
|
||||||
protected Logger logger = Logger.NULL;
|
protected Logger logger = Logger.NULL;
|
||||||
|
|
||||||
private final Supplier<VirtualBoxManager> manager;
|
private final Supplier<VirtualBoxManager> manager;
|
||||||
|
private final MachineUtils machineUtils;
|
||||||
|
|
||||||
private final String workingDir;
|
private final String workingDir;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public CreateAndRegisterMachineFromIsoIfNotAlreadyExists(Supplier<VirtualBoxManager> manager,
|
public CreateAndRegisterMachineFromIsoIfNotAlreadyExists(Supplier<VirtualBoxManager> manager, MachineUtils machineUtils,
|
||||||
@Named(VirtualBoxConstants.VIRTUALBOX_WORKINGDIR) String workingDir) {
|
@Named(VirtualBoxConstants.VIRTUALBOX_WORKINGDIR) String workingDir) {
|
||||||
this.manager = manager;
|
this.manager = manager;
|
||||||
|
this.machineUtils = machineUtils;
|
||||||
this.workingDir = workingDir;
|
this.workingDir = workingDir;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,8 +145,8 @@ public class CreateAndRegisterMachineFromIsoIfNotAlreadyExists implements Functi
|
||||||
|
|
||||||
private void ensureMachineDevicesAttached(String vmName, IMedium medium, DeviceDetails deviceDetails,
|
private void ensureMachineDevicesAttached(String vmName, IMedium medium, DeviceDetails deviceDetails,
|
||||||
String controllerName) {
|
String controllerName) {
|
||||||
lockMachineAndApply(manager.get(), Write, vmName, new AttachMediumToMachineIfNotAlreadyAttached(deviceDetails, medium,
|
machineUtils.writeLockMachineAndApply(vmName, new AttachMediumToMachineIfNotAlreadyAttached(deviceDetails, medium,
|
||||||
controllerName));
|
controllerName));
|
||||||
}
|
}
|
||||||
|
|
||||||
private String missingIDEControllersMessage(VmSpec vmSpecification) {
|
private String missingIDEControllersMessage(VmSpec vmSpecification) {
|
||||||
|
@ -157,22 +166,22 @@ public class CreateAndRegisterMachineFromIsoIfNotAlreadyExists implements Functi
|
||||||
logger.error(String.format("File %s could not be deleted.", sourcePath));
|
logger.error(String.format("File %s could not be deleted.", sourcePath));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
IMedium medium = new CreateMediumIfNotAlreadyExists(manager, true).apply(hardDisk);
|
IMedium medium = new CreateMediumIfNotAlreadyExists(manager, machineUtils, true).apply(hardDisk);
|
||||||
ensureMachineDevicesAttached(vmName, medium, hardDisk.getDeviceDetails(), controller.getName());
|
ensureMachineDevicesAttached(vmName, medium, hardDisk.getDeviceDetails(), controller.getName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ensureMachineHasMemory(String vmName, final long memorySize) {
|
private void ensureMachineHasMemory(String vmName, final long memorySize) {
|
||||||
lockMachineAndApply(manager.get(), Write, vmName, new ApplyMemoryToMachine(memorySize));
|
machineUtils.writeLockMachineAndApply(vmName, new ApplyMemoryToMachine(memorySize));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ensureNATNetworkingIsAppliedToMachine(String vmName, long slotId,
|
private void ensureNATNetworkingIsAppliedToMachine(String vmName, long slotId,
|
||||||
NatAdapter natAdapter) {
|
NatAdapter natAdapter) {
|
||||||
lockMachineAndApply(manager.get(), Write, vmName, new AttachNATAdapterToMachineIfNotAlreadyExists(slotId, natAdapter));
|
machineUtils.writeLockMachineAndApply(vmName, new AttachNATAdapterToMachineIfNotAlreadyExists(slotId, natAdapter));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ensureMachineHasStorageControllerNamed(String vmName, StorageController storageController) {
|
public void ensureMachineHasStorageControllerNamed(String vmName, StorageController storageController) {
|
||||||
lockMachineAndApply(manager.get(), Write, checkNotNull(vmName, "vmName"), new AddIDEControllerIfNotExists(checkNotNull(
|
machineUtils.writeLockMachineAndApply(vmName, new AddIDEControllerIfNotExists(checkNotNull(
|
||||||
storageController, "storageController")));
|
storageController, "storageController")));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,9 +19,6 @@
|
||||||
|
|
||||||
package org.jclouds.virtualbox.functions;
|
package org.jclouds.virtualbox.functions;
|
||||||
|
|
||||||
import static org.jclouds.virtualbox.util.MachineUtils.lockMachineAndApply;
|
|
||||||
import static org.virtualbox_4_1.LockType.Write;
|
|
||||||
|
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
@ -30,6 +27,7 @@ import javax.inject.Inject;
|
||||||
import javax.inject.Singleton;
|
import javax.inject.Singleton;
|
||||||
|
|
||||||
import org.jclouds.virtualbox.domain.HardDisk;
|
import org.jclouds.virtualbox.domain.HardDisk;
|
||||||
|
import org.jclouds.virtualbox.util.MachineUtils;
|
||||||
import org.virtualbox_4_1.DeviceType;
|
import org.virtualbox_4_1.DeviceType;
|
||||||
import org.virtualbox_4_1.IMachine;
|
import org.virtualbox_4_1.IMachine;
|
||||||
import org.virtualbox_4_1.IMedium;
|
import org.virtualbox_4_1.IMedium;
|
||||||
|
@ -51,11 +49,13 @@ import com.google.common.collect.Iterables;
|
||||||
public class CreateMediumIfNotAlreadyExists implements Function<HardDisk, IMedium> {
|
public class CreateMediumIfNotAlreadyExists implements Function<HardDisk, IMedium> {
|
||||||
|
|
||||||
private final Supplier<VirtualBoxManager> manager;
|
private final Supplier<VirtualBoxManager> manager;
|
||||||
|
private final MachineUtils machineUtils;
|
||||||
private final boolean overwriteIfExists;
|
private final boolean overwriteIfExists;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public CreateMediumIfNotAlreadyExists(Supplier<VirtualBoxManager> manager, boolean overwriteIfExists) {
|
public CreateMediumIfNotAlreadyExists(Supplier<VirtualBoxManager> manager, MachineUtils machineUtils, boolean overwriteIfExists) {
|
||||||
this.manager = manager;
|
this.manager = manager;
|
||||||
|
this.machineUtils = machineUtils;
|
||||||
this.overwriteIfExists = overwriteIfExists;
|
this.overwriteIfExists = overwriteIfExists;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,8 +95,8 @@ public class CreateMediumIfNotAlreadyExists implements Function<HardDisk, IMediu
|
||||||
return in.getMedium().getId().equals(medium.getId());
|
return in.getMedium().getId().equals(medium.getId());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
lockMachineAndApply(manager.get(), Write, immutableMachine.getName(), new DetachDistroMediumFromMachine(
|
machineUtils.writeLockMachineAndApply(immutableMachine.getName(), new DetachDistroMediumFromMachine(
|
||||||
mediumAttachment.getController(), mediumAttachment.getPort(), mediumAttachment.getDevice()));
|
mediumAttachment.getController(), mediumAttachment.getPort(), mediumAttachment.getDevice()));
|
||||||
deleteMediumAndBlockUntilComplete(medium);
|
deleteMediumAndBlockUntilComplete(medium);
|
||||||
} else {
|
} else {
|
||||||
throw e;
|
throw e;
|
||||||
|
|
|
@ -36,7 +36,7 @@ import com.google.common.base.Supplier;
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
|
|
||||||
@Singleton
|
@Singleton
|
||||||
public class MutableMachine implements Function<String, IMachine> {
|
public class MutableMachine implements Function<String, ISession> {
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
@Named(ComputeServiceConstants.COMPUTE_LOGGER)
|
@Named(ComputeServiceConstants.COMPUTE_LOGGER)
|
||||||
|
@ -54,7 +54,7 @@ public class MutableMachine implements Function<String, IMachine> {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IMachine apply(String machineId) {
|
public ISession apply(String machineId) {
|
||||||
return lockSessionOnMachineAndReturn(manager.get(), lockType, machineId);
|
return lockSessionOnMachineAndReturn(manager.get(), lockType, machineId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -67,14 +67,14 @@ public class MutableMachine implements Function<String, IMachine> {
|
||||||
* @param manager the VirtualBoxManager
|
* @param manager the VirtualBoxManager
|
||||||
* @param type the kind of lock to use when initially locking the machine.
|
* @param type the kind of lock to use when initially locking the machine.
|
||||||
* @param machineId the id of the machine
|
* @param machineId the id of the machine
|
||||||
* @return the result from applying the function to the session.
|
* @return the ISession bounded to the machine locked.
|
||||||
*/
|
*/
|
||||||
public static IMachine lockSessionOnMachineAndReturn(VirtualBoxManager manager, LockType type, String machineId) {
|
public static ISession lockSessionOnMachineAndReturn(VirtualBoxManager manager, LockType type, String machineId) {
|
||||||
try {
|
try {
|
||||||
ISession session = manager.getSessionObject();
|
ISession session = manager.getSessionObject();
|
||||||
IMachine immutableMachine = manager.getVBox().findMachine(machineId);
|
IMachine immutableMachine = manager.getVBox().findMachine(machineId);
|
||||||
immutableMachine.lockMachine(session, type);
|
immutableMachine.lockMachine(session, type);
|
||||||
return immutableMachine;
|
return session;
|
||||||
} catch (VBoxException e) {
|
} catch (VBoxException e) {
|
||||||
throw new RuntimeException(String.format("error locking %s with %s lock: %s", machineId,
|
throw new RuntimeException(String.format("error locking %s with %s lock: %s", machineId,
|
||||||
type, e.getMessage()), e);
|
type, e.getMessage()), e);
|
||||||
|
|
|
@ -66,7 +66,7 @@ public class RetrieveActiveBridgedInterfaces implements Function<NodeMetadata, L
|
||||||
@Override
|
@Override
|
||||||
public List<String> apply(NodeMetadata host) {
|
public List<String> apply(NodeMetadata host) {
|
||||||
// Bridged Network
|
// Bridged Network
|
||||||
Statement command = Statements.exec("vboxmanage list bridgedifs");
|
Statement command = Statements.exec("VBoxManage list bridgedifs");
|
||||||
String bridgedIfBlocks = runScriptOnNodeFactory.create(host, command, runAsRoot(false).wrapInInitScript(false))
|
String bridgedIfBlocks = runScriptOnNodeFactory.create(host, command, runAsRoot(false).wrapInInitScript(false))
|
||||||
.init().call().getOutput();
|
.init().call().getOutput();
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/**
|
/*
|
||||||
* Licensed to jclouds, Inc. (jclouds) under one or more
|
* Licensed to jclouds, Inc. (jclouds) under one or more
|
||||||
* contributor license agreements. See the NOTICE file
|
* contributor license agreements. See the NOTICE file
|
||||||
* distributed with this work for additional information
|
* distributed with this work for additional information
|
||||||
|
|
|
@ -18,11 +18,11 @@
|
||||||
*/
|
*/
|
||||||
package org.jclouds.virtualbox.util;
|
package org.jclouds.virtualbox.util;
|
||||||
|
|
||||||
|
import static org.jclouds.compute.options.RunScriptOptions.Builder.runAsRoot;
|
||||||
import static org.jclouds.scriptbuilder.domain.Statements.call;
|
import static org.jclouds.scriptbuilder.domain.Statements.call;
|
||||||
import static org.jclouds.scriptbuilder.domain.Statements.findPid;
|
import static org.jclouds.scriptbuilder.domain.Statements.findPid;
|
||||||
import static org.jclouds.scriptbuilder.domain.Statements.kill;
|
import static org.jclouds.scriptbuilder.domain.Statements.kill;
|
||||||
import static org.jclouds.scriptbuilder.domain.Statements.newStatementList;
|
import static org.jclouds.scriptbuilder.domain.Statements.newStatementList;
|
||||||
import static org.jclouds.compute.options.RunScriptOptions.Builder.runAsRoot;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import javax.inject.Named;
|
import javax.inject.Named;
|
||||||
|
@ -33,9 +33,7 @@ import org.jclouds.compute.callables.RunScriptOnNode.Factory;
|
||||||
import org.jclouds.compute.domain.NodeMetadata;
|
import org.jclouds.compute.domain.NodeMetadata;
|
||||||
import org.jclouds.compute.reference.ComputeServiceConstants;
|
import org.jclouds.compute.reference.ComputeServiceConstants;
|
||||||
import org.jclouds.logging.Logger;
|
import org.jclouds.logging.Logger;
|
||||||
import org.jclouds.scriptbuilder.domain.OsFamily;
|
|
||||||
import org.jclouds.scriptbuilder.domain.Statement;
|
import org.jclouds.scriptbuilder.domain.Statement;
|
||||||
import org.jclouds.scriptbuilder.domain.Statements;
|
|
||||||
import org.jclouds.util.Throwables2;
|
import org.jclouds.util.Throwables2;
|
||||||
import org.jclouds.virtualbox.functions.MutableMachine;
|
import org.jclouds.virtualbox.functions.MutableMachine;
|
||||||
import org.virtualbox_4_1.IMachine;
|
import org.virtualbox_4_1.IMachine;
|
||||||
|
@ -46,7 +44,6 @@ import org.virtualbox_4_1.VBoxException;
|
||||||
import org.virtualbox_4_1.VirtualBoxManager;
|
import org.virtualbox_4_1.VirtualBoxManager;
|
||||||
|
|
||||||
import com.google.common.base.Function;
|
import com.google.common.base.Function;
|
||||||
import com.google.common.base.Functions;
|
|
||||||
import com.google.common.base.Supplier;
|
import com.google.common.base.Supplier;
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
|
|
||||||
|
@ -64,56 +61,17 @@ public class MachineUtils {
|
||||||
protected Logger logger = Logger.NULL;
|
protected Logger logger = Logger.NULL;
|
||||||
|
|
||||||
private final Supplier<VirtualBoxManager> manager;
|
private final Supplier<VirtualBoxManager> manager;
|
||||||
private final LockType lockType;
|
|
||||||
private final Factory scriptRunner;
|
private final Factory scriptRunner;
|
||||||
private final Supplier<NodeMetadata> host;
|
private final Supplier<NodeMetadata> host;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public MachineUtils(Supplier<VirtualBoxManager> manager, LockType lockType, RunScriptOnNode.Factory scriptRunner, Supplier<NodeMetadata> host) {
|
public MachineUtils(Supplier<VirtualBoxManager> manager, RunScriptOnNode.Factory scriptRunner, Supplier<NodeMetadata> host) {
|
||||||
super();
|
super();
|
||||||
this.manager = manager;
|
this.manager = manager;
|
||||||
this.lockType = lockType;
|
|
||||||
this.scriptRunner = scriptRunner;
|
this.scriptRunner = scriptRunner;
|
||||||
this.host = host;
|
this.host = host;
|
||||||
}
|
}
|
||||||
|
|
||||||
public <T> Function<String, T> mutateMachine(String machineId,
|
|
||||||
Function<IMachine, T> function) {
|
|
||||||
try {
|
|
||||||
return Functions.compose(function, new MutableMachine(manager, lockType));
|
|
||||||
} finally {
|
|
||||||
unlockMachine(machineId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void unlockMachine(final String machineId) {
|
|
||||||
IMachine immutableMachine = manager.get().getVBox().findMachine(machineId);
|
|
||||||
if (immutableMachine.getSessionState().equals(SessionState.Locked)) {
|
|
||||||
Statement kill = newStatementList(call("default"),
|
|
||||||
findPid(immutableMachine.getSessionPid().toString()), kill());
|
|
||||||
scriptRunner
|
|
||||||
.create(host.get(), kill,
|
|
||||||
runAsRoot(false).wrapInInitScript(false)).init().call();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static <T> T applyForMachine(VirtualBoxManager manager,
|
|
||||||
final String machineId, final Function<IMachine, T> function) {
|
|
||||||
final IMachine immutableMachine = manager.getVBox()
|
|
||||||
.findMachine(machineId);
|
|
||||||
return new Function<IMachine, T>() {
|
|
||||||
@Override
|
|
||||||
public T apply(IMachine machine) {
|
|
||||||
return function.apply(machine);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return function.toString();
|
|
||||||
}
|
|
||||||
}.apply(immutableMachine);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Locks the machine and executes the given function using the machine
|
* Locks the machine and executes the given function using the machine
|
||||||
* matching the given id. Since the machine is locked it is possible to
|
* matching the given id. Since the machine is locked it is possible to
|
||||||
|
@ -121,20 +79,14 @@ public class MachineUtils {
|
||||||
* <p/>
|
* <p/>
|
||||||
* Unlocks the machine before returning.
|
* Unlocks the machine before returning.
|
||||||
*
|
*
|
||||||
* @param manager
|
|
||||||
* the VirtualBoxManager
|
|
||||||
* @param type
|
|
||||||
* the kind of lock to use when initially locking the machine.
|
|
||||||
* @param machineId
|
* @param machineId
|
||||||
* the id of the machine
|
* the id of the machine
|
||||||
* @param function
|
* @param function
|
||||||
* the function to execute
|
* the function to execute
|
||||||
* @return the result from applying the function to the machine.
|
* @return the result from applying the function to the machine.
|
||||||
*/
|
*/
|
||||||
public static <T> T lockMachineAndApply(VirtualBoxManager manager,
|
public <T> T writeLockMachineAndApply(final String machineId, final Function<IMachine, T> function) {
|
||||||
final LockType type, final String machineId,
|
return lockSessionOnMachineAndApply(machineId, LockType.Write,
|
||||||
final Function<IMachine, T> function) {
|
|
||||||
return lockSessionOnMachineAndApply(manager, type, machineId,
|
|
||||||
new Function<ISession, T>() {
|
new Function<ISession, T>() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -157,8 +109,6 @@ public class MachineUtils {
|
||||||
* <p/>
|
* <p/>
|
||||||
* Unlocks the machine before returning.
|
* Unlocks the machine before returning.
|
||||||
*
|
*
|
||||||
* @param manager
|
|
||||||
* the VirtualBoxManager
|
|
||||||
* @param type
|
* @param type
|
||||||
* the kind of lock to use when initially locking the machine.
|
* the kind of lock to use when initially locking the machine.
|
||||||
* @param machineId
|
* @param machineId
|
||||||
|
@ -167,12 +117,9 @@ public class MachineUtils {
|
||||||
* the function to execute
|
* the function to execute
|
||||||
* @return the result from applying the function to the session.
|
* @return the result from applying the function to the session.
|
||||||
*/
|
*/
|
||||||
public static <T> T lockSessionOnMachineAndApply(VirtualBoxManager manager,
|
public <T> T lockSessionOnMachineAndApply(String machineId, LockType type, Function<ISession, T> function) {
|
||||||
LockType type, String machineId, Function<ISession, T> function) {
|
|
||||||
try {
|
try {
|
||||||
ISession session = manager.getSessionObject();
|
ISession session = lockSessionOnMachine(type, machineId);
|
||||||
IMachine immutableMachine = manager.getVBox().findMachine(machineId);
|
|
||||||
immutableMachine.lockMachine(session, type);
|
|
||||||
try {
|
try {
|
||||||
return function.apply(session);
|
return function.apply(session);
|
||||||
} finally {
|
} finally {
|
||||||
|
@ -185,35 +132,18 @@ public class MachineUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
private ISession lockSessionOnMachine(LockType type, String machineId) {
|
||||||
* Locks the machine and executes the given function using the current
|
return new MutableMachine(manager, type).apply(machineId);
|
||||||
* session, if the machine is registered. Since the machine is locked it is
|
}
|
||||||
* possible to perform some modifications to the IMachine.
|
|
||||||
* <p/>
|
private void unlockMachine(final String machineId) {
|
||||||
* Unlocks the machine before returning.
|
IMachine immutableMachine = manager.get().getVBox().findMachine(machineId);
|
||||||
*
|
if (immutableMachine.getSessionState().equals(SessionState.Locked)) {
|
||||||
* @param manager
|
Statement kill = newStatementList(call("default"),
|
||||||
* the VirtualBoxManager
|
findPid(immutableMachine.getSessionPid().toString()), kill());
|
||||||
* @param type
|
scriptRunner
|
||||||
* the kind of lock to use when initially locking the machine.
|
.create(host.get(), kill,
|
||||||
* @param machineId
|
runAsRoot(false).wrapInInitScript(false)).init().call();
|
||||||
* the id of the machine
|
|
||||||
* @param function
|
|
||||||
* the function to execute
|
|
||||||
* @return the result from applying the function to the session.
|
|
||||||
*/
|
|
||||||
public static <T> T lockMachineAndApplyOrReturnNullIfNotRegistered(
|
|
||||||
VirtualBoxManager manager, LockType type, String machineId,
|
|
||||||
Function<IMachine, T> function) {
|
|
||||||
try {
|
|
||||||
return lockMachineAndApply(manager, type, machineId, function);
|
|
||||||
} catch (RuntimeException e) {
|
|
||||||
VBoxException vbex = Throwables2.getFirstThrowableOfType(e,
|
|
||||||
VBoxException.class);
|
|
||||||
if (vbex != null
|
|
||||||
&& vbex.getMessage().indexOf("not find a registered") == -1)
|
|
||||||
throw e;
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -226,32 +156,21 @@ public class MachineUtils {
|
||||||
* <h3>Note!</h3> Currently, this can only unlock the machine, if the lock
|
* <h3>Note!</h3> Currently, this can only unlock the machine, if the lock
|
||||||
* was created in the current session.
|
* was created in the current session.
|
||||||
*
|
*
|
||||||
* @param manager
|
|
||||||
* the VirtualBoxManager
|
|
||||||
* @param machineId
|
* @param machineId
|
||||||
* the id of the machine
|
* the id of the machine
|
||||||
* @param function
|
* @param function
|
||||||
* the function to execute
|
* the function to execute
|
||||||
* @return the result from applying the function to the machine.
|
* @return the result from applying the function to the machine.
|
||||||
*/
|
*/
|
||||||
public static <T> T unlockMachineAndApply(VirtualBoxManager manager,
|
public <T> T unlockMachineAndApply(final String machineId, final Function<IMachine, T> function) {
|
||||||
final String machineId, final Function<IMachine, T> function) {
|
|
||||||
ISession session = manager.getSessionObject();
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
IMachine immutableMachine = manager.getVBox().findMachine(machineId);
|
unlockMachine(machineId);
|
||||||
SessionState state = immutableMachine.getSessionState();
|
|
||||||
Statement kill = newStatementList(call("default"),
|
|
||||||
findPid(immutableMachine.getSessionPid().toString()), kill());
|
|
||||||
if (state.equals(SessionState.Locked))
|
|
||||||
// session.unlockMachine();
|
|
||||||
kill.render(OsFamily.UNIX);
|
|
||||||
// TODO: wire this in
|
|
||||||
|
|
||||||
|
IMachine immutableMachine = manager.get().getVBox().findMachine(machineId);
|
||||||
return function.apply(immutableMachine);
|
return function.apply(immutableMachine);
|
||||||
|
|
||||||
} catch (VBoxException e) {
|
} catch (VBoxException e) {
|
||||||
session.unlockMachine();
|
|
||||||
throw new RuntimeException(String.format(
|
throw new RuntimeException(String.format(
|
||||||
"error applying %s to %s: %s", function, machineId,
|
"error applying %s to %s: %s", function, machineId,
|
||||||
e.getMessage()), e);
|
e.getMessage()), e);
|
||||||
|
@ -264,19 +183,16 @@ public class MachineUtils {
|
||||||
* machine.
|
* machine.
|
||||||
* <p/>
|
* <p/>
|
||||||
*
|
*
|
||||||
* @param manager
|
|
||||||
* the VirtualBoxManager
|
|
||||||
* @param machineId
|
* @param machineId
|
||||||
* the id of the machine
|
* the id of the machine
|
||||||
* @param function
|
* @param function
|
||||||
* the function to execute
|
* the function to execute
|
||||||
* @return the result from applying the function to the session.
|
* @return the result from applying the function to the session.
|
||||||
*/
|
*/
|
||||||
public static <T> T unlockMachineAndApplyOrReturnNullIfNotRegistered(
|
public <T> T unlockMachineAndApplyOrReturnNullIfNotRegistered(String machineId,
|
||||||
VirtualBoxManager manager, String machineId,
|
|
||||||
Function<IMachine, T> function) {
|
Function<IMachine, T> function) {
|
||||||
try {
|
try {
|
||||||
return unlockMachineAndApply(manager, machineId, function);
|
return unlockMachineAndApply(machineId, function);
|
||||||
} catch (RuntimeException e) {
|
} catch (RuntimeException e) {
|
||||||
VBoxException vbex = Throwables2.getFirstThrowableOfType(e,
|
VBoxException vbex = Throwables2.getFirstThrowableOfType(e,
|
||||||
VBoxException.class);
|
VBoxException.class);
|
||||||
|
@ -286,4 +202,26 @@ public class MachineUtils {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param machineId
|
||||||
|
* @param function
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public <T> T applyForMachine(final String machineId, final Function<IMachine, T> function) {
|
||||||
|
final IMachine immutableMachine = manager.get().getVBox().findMachine(machineId);
|
||||||
|
return new Function<IMachine, T>() {
|
||||||
|
@Override
|
||||||
|
public T apply(IMachine machine) {
|
||||||
|
return function.apply(machine);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return function.toString();
|
||||||
|
}
|
||||||
|
}.apply(immutableMachine);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,7 @@ function exportIpAddressFromVmNamed {
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
local VMNAME="$0"; shift
|
local VMNAME="$0"; shift
|
||||||
local _FOUND=`vboxmanage guestproperty enumerate "$VMNAME" --patterns "/VirtualBox/GuestInfo/Net/0/V4/IP" | awk '{ print $4 }' | cut -c 1-14`
|
local _FOUND=`VBoxManage guestproperty enumerate "$VMNAME" --patterns "/VirtualBox/GuestInfo/Net/0/V4/IP" | awk '{ print $4 }' | cut -c 1-14`
|
||||||
[ -n "$_FOUND" ] && {
|
[ -n "$_FOUND" ] && {
|
||||||
export FOUND_IP_ADDRESS=$_FOUND
|
export FOUND_IP_ADDRESS=$_FOUND
|
||||||
echo [$FOUND_IP_ADDRESS]
|
echo [$FOUND_IP_ADDRESS]
|
||||||
|
|
|
@ -5,7 +5,7 @@ function getIpAddress {
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
local VMNAME="$0"; shift
|
local VMNAME="$0"; shift
|
||||||
local _FOUND=`vboxmanage guestproperty enumerate "$VMNAME" --patterns "/VirtualBox/GuestInfo/Net/0/V4/IP" | awk '{ print $4 }' | cut -c 1-14`
|
local _FOUND=`VBoxManage guestproperty enumerate "$VMNAME" --patterns "/VirtualBox/GuestInfo/Net/0/V4/IP" | awk '{ print $4 }' | cut -c 1-14`
|
||||||
[ -n "$_FOUND" ] && {
|
[ -n "$_FOUND" ] && {
|
||||||
export FOUND_IP_ADDRESS=$_FOUND
|
export FOUND_IP_ADDRESS=$_FOUND
|
||||||
echo [$FOUND_IP_ADDRESS]
|
echo [$FOUND_IP_ADDRESS]
|
||||||
|
|
|
@ -19,8 +19,6 @@
|
||||||
|
|
||||||
package org.jclouds.virtualbox;
|
package org.jclouds.virtualbox;
|
||||||
|
|
||||||
import static org.jclouds.virtualbox.util.MachineUtils.unlockMachineAndApplyOrReturnNullIfNotRegistered;
|
|
||||||
|
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
|
@ -38,8 +36,6 @@ import org.jclouds.logging.slf4j.config.SLF4JLoggingModule;
|
||||||
import org.jclouds.sshj.config.SshjSshClientModule;
|
import org.jclouds.sshj.config.SshjSshClientModule;
|
||||||
import org.jclouds.virtualbox.config.VirtualBoxConstants;
|
import org.jclouds.virtualbox.config.VirtualBoxConstants;
|
||||||
import org.jclouds.virtualbox.domain.VmSpec;
|
import org.jclouds.virtualbox.domain.VmSpec;
|
||||||
import org.jclouds.virtualbox.functions.CreateAndInstallVm;
|
|
||||||
import org.jclouds.virtualbox.functions.CreateAndRegisterMachineFromIsoIfNotAlreadyExists;
|
|
||||||
import org.jclouds.virtualbox.functions.admin.UnregisterMachineIfExistsAndDeleteItsMedia;
|
import org.jclouds.virtualbox.functions.admin.UnregisterMachineIfExistsAndDeleteItsMedia;
|
||||||
import org.jclouds.virtualbox.util.MachineUtils;
|
import org.jclouds.virtualbox.util.MachineUtils;
|
||||||
import org.testng.annotations.AfterClass;
|
import org.testng.annotations.AfterClass;
|
||||||
|
@ -70,6 +66,7 @@ public class BaseVirtualBoxClientLiveTest extends BaseVersionedServiceLiveTest {
|
||||||
|
|
||||||
protected ComputeServiceContext context;
|
protected ComputeServiceContext context;
|
||||||
protected Supplier<VirtualBoxManager> manager;
|
protected Supplier<VirtualBoxManager> manager;
|
||||||
|
protected MachineUtils machineUtils;
|
||||||
protected Supplier<URI> preconfigurationUri;
|
protected Supplier<URI> preconfigurationUri;
|
||||||
protected String hostVersion;
|
protected String hostVersion;
|
||||||
protected String operatingSystemIso;
|
protected String operatingSystemIso;
|
||||||
|
@ -80,17 +77,19 @@ public class BaseVirtualBoxClientLiveTest extends BaseVersionedServiceLiveTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void setupCredentials() {
|
protected void setupCredentials() {
|
||||||
// default behavior is to bomb when no user is configured, but we know the default user of
|
// default behavior is to bomb when no user is configured, but we know the
|
||||||
|
// default user of
|
||||||
// vbox
|
// vbox
|
||||||
ensureIdentityPropertyIsSpecifiedOrTakeFromDefaults();
|
ensureIdentityPropertyIsSpecifiedOrTakeFromDefaults();
|
||||||
super.setupCredentials();
|
super.setupCredentials();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void ensureIdentityPropertyIsSpecifiedOrTakeFromDefaults() {
|
protected void ensureIdentityPropertyIsSpecifiedOrTakeFromDefaults() {
|
||||||
Properties defaultVBoxProperties = new VirtualBoxPropertiesBuilder().build();
|
Properties defaultVBoxProperties = new VirtualBoxPropertiesBuilder()
|
||||||
|
.build();
|
||||||
if (!System.getProperties().containsKey("test." + provider + ".identity"))
|
if (!System.getProperties().containsKey("test." + provider + ".identity"))
|
||||||
System.setProperty("test." + provider + ".identity", defaultVBoxProperties
|
System.setProperty("test." + provider + ".identity",
|
||||||
.getProperty(Constants.PROPERTY_IDENTITY));
|
defaultVBoxProperties.getProperty(Constants.PROPERTY_IDENTITY));
|
||||||
}
|
}
|
||||||
|
|
||||||
@BeforeClass(groups = "live")
|
@BeforeClass(groups = "live")
|
||||||
|
@ -98,40 +97,66 @@ public class BaseVirtualBoxClientLiveTest extends BaseVersionedServiceLiveTest {
|
||||||
setupCredentials();
|
setupCredentials();
|
||||||
Properties overrides = setupProperties();
|
Properties overrides = setupProperties();
|
||||||
|
|
||||||
CacheNodeStoreModule hostModule = new CacheNodeStoreModule(ImmutableMap.of("host", Node.builder().id("host")
|
CacheNodeStoreModule hostModule = new CacheNodeStoreModule(
|
||||||
.name("host installing virtualbox").hostname("localhost").osFamily(OsFamily.LINUX.toString())
|
ImmutableMap.of(
|
||||||
.osDescription(System.getProperty("os.name")).osVersion(System.getProperty("os.version")).group("ssh")
|
"host",
|
||||||
.username(System.getProperty("user.name")).credentialUrl(
|
Node.builder()
|
||||||
URI.create("file://" + System.getProperty("user.home") + "/.ssh/id_rsa")).build()));
|
.id("host")
|
||||||
|
.name("host installing virtualbox")
|
||||||
|
.hostname("localhost")
|
||||||
|
.osFamily(OsFamily.LINUX.toString())
|
||||||
|
.osDescription(System.getProperty("os.name"))
|
||||||
|
.osVersion(System.getProperty("os.version"))
|
||||||
|
.group("ssh")
|
||||||
|
.username(System.getProperty("user.name"))
|
||||||
|
.credentialUrl(
|
||||||
|
URI.create("file://"
|
||||||
|
+ System.getProperty("user.home")
|
||||||
|
+ "/.ssh/id_rsa")).build()));
|
||||||
|
|
||||||
context = new ComputeServiceContextFactory().createContext(provider, identity, credential, ImmutableSet
|
context = new ComputeServiceContextFactory().createContext(provider,
|
||||||
.<Module> of(new SLF4JLoggingModule(), new SshjSshClientModule(), hostModule), overrides);
|
identity, credential, ImmutableSet.<Module> of(
|
||||||
Function<String, String> configProperties = context.utils().injector().getInstance(
|
new SLF4JLoggingModule(), new SshjSshClientModule(),
|
||||||
ValueOfConfigurationKeyOrNull.class);
|
hostModule), overrides);
|
||||||
imageId = configProperties.apply(ComputeServiceConstants.PROPERTY_IMAGE_ID);
|
Function<String, String> configProperties = context.utils().injector()
|
||||||
workingDir = configProperties.apply(VirtualBoxConstants.VIRTUALBOX_WORKINGDIR);
|
.getInstance(ValueOfConfigurationKeyOrNull.class);
|
||||||
host = context.utils().injector().getInstance(Key.get(new TypeLiteral<Supplier<NodeMetadata>>(){}));
|
imageId = configProperties
|
||||||
|
.apply(ComputeServiceConstants.PROPERTY_IMAGE_ID);
|
||||||
|
workingDir = configProperties
|
||||||
|
.apply(VirtualBoxConstants.VIRTUALBOX_WORKINGDIR);
|
||||||
|
host = context.utils().injector()
|
||||||
|
.getInstance(Key.get(new TypeLiteral<Supplier<NodeMetadata>>() {
|
||||||
|
}));
|
||||||
|
|
||||||
// this will eagerly startup Jetty, note the impl will shut itself down
|
// this will eagerly startup Jetty, note the impl will shut itself down
|
||||||
preconfigurationUri = context.utils().injector().getInstance(Key.get(new TypeLiteral<Supplier<URI>>() {
|
preconfigurationUri = context.utils().injector()
|
||||||
}, Preconfiguration.class));
|
.getInstance(Key.get(new TypeLiteral<Supplier<URI>>() {
|
||||||
|
}, Preconfiguration.class));
|
||||||
// this will eagerly startup Jetty, note the impl will shut itself down
|
// this will eagerly startup Jetty, note the impl will shut itself down
|
||||||
preconfigurationUri.get();
|
preconfigurationUri.get();
|
||||||
|
|
||||||
manager = context.utils().injector().getInstance(Key.get(new TypeLiteral<Supplier<VirtualBoxManager>>() {
|
manager = context
|
||||||
}));
|
.utils()
|
||||||
|
.injector()
|
||||||
|
.getInstance(Key.get(new TypeLiteral<Supplier<VirtualBoxManager>>() {}));
|
||||||
// this will eagerly startup vbox
|
// this will eagerly startup vbox
|
||||||
manager.get();
|
manager.get();
|
||||||
|
|
||||||
hostVersion = Iterables.get(Splitter.on('r').split(context.getProviderSpecificContext().getBuildVersion()), 0);
|
machineUtils = context.utils().injector().getInstance(MachineUtils.class);
|
||||||
|
|
||||||
|
hostVersion = Iterables.get(
|
||||||
|
Splitter.on('r').split(
|
||||||
|
context.getProviderSpecificContext().getBuildVersion()), 0);
|
||||||
adminDisk = workingDir + "/testadmin.vdi";
|
adminDisk = workingDir + "/testadmin.vdi";
|
||||||
operatingSystemIso = String.format("%s/%s.iso", workingDir, imageId);
|
operatingSystemIso = String.format("%s/%s.iso", workingDir, imageId);
|
||||||
guestAdditionsIso = String.format("%s/VBoxGuestAdditions_%s.iso", workingDir, hostVersion);
|
guestAdditionsIso = String.format("%s/VBoxGuestAdditions_%s.iso",
|
||||||
|
workingDir, hostVersion);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void undoVm(VmSpec vmSpecification) {
|
protected void undoVm(VmSpec vmSpecification) {
|
||||||
MachineUtils machineUtils = context.utils().injector().getInstance(MachineUtils.class);
|
machineUtils.unlockMachineAndApplyOrReturnNullIfNotRegistered(
|
||||||
machineUtils.mutateMachine(vmSpecification.getVmId(), new UnregisterMachineIfExistsAndDeleteItsMedia(vmSpecification));
|
vmSpecification.getVmId(),
|
||||||
|
new UnregisterMachineIfExistsAndDeleteItsMedia(vmSpecification));
|
||||||
}
|
}
|
||||||
|
|
||||||
@AfterClass(groups = "live")
|
@AfterClass(groups = "live")
|
||||||
|
|
|
@ -27,15 +27,14 @@ import static org.easymock.classextension.EasyMock.createNiceMock;
|
||||||
import static org.easymock.classextension.EasyMock.replay;
|
import static org.easymock.classextension.EasyMock.replay;
|
||||||
import static org.easymock.classextension.EasyMock.verify;
|
import static org.easymock.classextension.EasyMock.verify;
|
||||||
|
|
||||||
import com.google.common.base.Supplier;
|
import java.net.URI;
|
||||||
import com.google.inject.Key;
|
|
||||||
import com.google.inject.TypeLiteral;
|
|
||||||
import org.easymock.EasyMock;
|
import org.easymock.EasyMock;
|
||||||
import org.jclouds.virtualbox.Preconfiguration;
|
|
||||||
import org.jclouds.virtualbox.domain.IMachineSpec;
|
import org.jclouds.virtualbox.domain.IMachineSpec;
|
||||||
import org.jclouds.virtualbox.domain.IsoSpec;
|
import org.jclouds.virtualbox.domain.IsoSpec;
|
||||||
import org.jclouds.virtualbox.domain.NetworkSpec;
|
import org.jclouds.virtualbox.domain.NetworkSpec;
|
||||||
import org.jclouds.virtualbox.domain.VmSpec;
|
import org.jclouds.virtualbox.domain.VmSpec;
|
||||||
|
import org.jclouds.virtualbox.util.MachineUtils;
|
||||||
import org.testng.annotations.Test;
|
import org.testng.annotations.Test;
|
||||||
import org.virtualbox_4_1.CleanupMode;
|
import org.virtualbox_4_1.CleanupMode;
|
||||||
import org.virtualbox_4_1.IMachine;
|
import org.virtualbox_4_1.IMachine;
|
||||||
|
@ -45,10 +44,9 @@ import org.virtualbox_4_1.LockType;
|
||||||
import org.virtualbox_4_1.VBoxException;
|
import org.virtualbox_4_1.VBoxException;
|
||||||
import org.virtualbox_4_1.VirtualBoxManager;
|
import org.virtualbox_4_1.VirtualBoxManager;
|
||||||
|
|
||||||
|
import com.google.common.base.Supplier;
|
||||||
import com.google.common.base.Suppliers;
|
import com.google.common.base.Suppliers;
|
||||||
|
|
||||||
import java.net.URI;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Mattias Holmqvist
|
* @author Mattias Holmqvist
|
||||||
*/
|
*/
|
||||||
|
@ -58,6 +56,7 @@ public class CreateAndRegisterMachineFromIsoIfNotAlreadyExistsTest {
|
||||||
@Test(enabled = false)
|
@Test(enabled = false)
|
||||||
public void testCreateAndSetMemoryWhenNotAlreadyExists() throws Exception {
|
public void testCreateAndSetMemoryWhenNotAlreadyExists() throws Exception {
|
||||||
|
|
||||||
|
MachineUtils machineUtils = createMock(MachineUtils.class);
|
||||||
VirtualBoxManager manager = createMock(VirtualBoxManager.class);
|
VirtualBoxManager manager = createMock(VirtualBoxManager.class);
|
||||||
IVirtualBox vBox = createMock(IVirtualBox.class);
|
IVirtualBox vBox = createMock(IVirtualBox.class);
|
||||||
Supplier<URI> preconfiguration = createNiceMock(Supplier.class);
|
Supplier<URI> preconfiguration = createNiceMock(Supplier.class);
|
||||||
|
@ -96,17 +95,18 @@ public class CreateAndRegisterMachineFromIsoIfNotAlreadyExistsTest {
|
||||||
|
|
||||||
|
|
||||||
//TODO: this mock test is not finished.
|
//TODO: this mock test is not finished.
|
||||||
|
|
||||||
replay(manager, createdMachine, vBox, session);
|
replay(manager, createdMachine, vBox, session);
|
||||||
|
|
||||||
new CreateAndRegisterMachineFromIsoIfNotAlreadyExists(Suppliers.ofInstance(manager), "/tmp/workingDir").apply(machineSpec);
|
new CreateAndRegisterMachineFromIsoIfNotAlreadyExists(Suppliers.ofInstance(manager), machineUtils, "/tmp/workingDir").apply(machineSpec);
|
||||||
|
|
||||||
verify(manager, createdMachine, vBox, session);
|
verify(manager, createdMachine, vBox, session);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expectedExceptions = IllegalStateException.class)
|
@Test(expectedExceptions = IllegalStateException.class, enabled=false)
|
||||||
public void testFailIfMachineIsAlreadyRegistered() throws Exception {
|
public void testFailIfMachineIsAlreadyRegistered() throws Exception {
|
||||||
|
|
||||||
|
MachineUtils machineUtils = createMock(MachineUtils.class);
|
||||||
|
|
||||||
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
||||||
IVirtualBox vBox = createNiceMock(IVirtualBox.class);
|
IVirtualBox vBox = createNiceMock(IVirtualBox.class);
|
||||||
Supplier<URI> preconfiguration = createNiceMock(Supplier.class);
|
Supplier<URI> preconfiguration = createNiceMock(Supplier.class);
|
||||||
|
@ -117,7 +117,7 @@ public class CreateAndRegisterMachineFromIsoIfNotAlreadyExistsTest {
|
||||||
expect(manager.getVBox()).andReturn(vBox).anyTimes();
|
expect(manager.getVBox()).andReturn(vBox).anyTimes();
|
||||||
expect(vBox.findMachine(vmName)).andReturn(registeredMachine).anyTimes();
|
expect(vBox.findMachine(vmName)).andReturn(registeredMachine).anyTimes();
|
||||||
|
|
||||||
replay(manager, vBox);
|
replay(manager, vBox, machineUtils);
|
||||||
|
|
||||||
VmSpec launchSpecification = VmSpec.builder().id("").name(vmName).osTypeId("").memoryMB(1024).cleanUpMode(
|
VmSpec launchSpecification = VmSpec.builder().id("").name(vmName).osTypeId("").memoryMB(1024).cleanUpMode(
|
||||||
CleanupMode.Full).build();
|
CleanupMode.Full).build();
|
||||||
|
@ -129,12 +129,14 @@ public class CreateAndRegisterMachineFromIsoIfNotAlreadyExistsTest {
|
||||||
.preConfiguration(preconfiguration).build())
|
.preConfiguration(preconfiguration).build())
|
||||||
.vm(launchSpecification)
|
.vm(launchSpecification)
|
||||||
.network(NetworkSpec.builder().build()).build();
|
.network(NetworkSpec.builder().build()).build();
|
||||||
new CreateAndRegisterMachineFromIsoIfNotAlreadyExists(Suppliers.ofInstance(manager), "/tmp/workingDir").apply(machineSpec);
|
new CreateAndRegisterMachineFromIsoIfNotAlreadyExists(Suppliers.ofInstance(manager), machineUtils, "/tmp/workingDir").apply(machineSpec);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expectedExceptions = VBoxException.class)
|
@Test(expectedExceptions = VBoxException.class)
|
||||||
public void testFailIfOtherVBoxExceptionIsThrown() throws Exception {
|
public void testFailIfOtherVBoxExceptionIsThrown() throws Exception {
|
||||||
|
|
||||||
|
MachineUtils machineUtils = createMock(MachineUtils.class);
|
||||||
|
|
||||||
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
||||||
IVirtualBox vBox = createNiceMock(IVirtualBox.class);
|
IVirtualBox vBox = createNiceMock(IVirtualBox.class);
|
||||||
Supplier<URI> preconfiguration = createNiceMock(Supplier.class);
|
Supplier<URI> preconfiguration = createNiceMock(Supplier.class);
|
||||||
|
@ -148,7 +150,7 @@ public class CreateAndRegisterMachineFromIsoIfNotAlreadyExistsTest {
|
||||||
vBox.findMachine(vmName);
|
vBox.findMachine(vmName);
|
||||||
expectLastCall().andThrow(vBoxException);
|
expectLastCall().andThrow(vBoxException);
|
||||||
|
|
||||||
replay(manager, vBox);
|
replay(manager, vBox, machineUtils);
|
||||||
|
|
||||||
VmSpec launchSpecification = VmSpec.builder().id("").name(vmName).osTypeId("").cleanUpMode(CleanupMode.Full)
|
VmSpec launchSpecification = VmSpec.builder().id("").name(vmName).osTypeId("").cleanUpMode(CleanupMode.Full)
|
||||||
.memoryMB(1024).build();
|
.memoryMB(1024).build();
|
||||||
|
@ -160,7 +162,7 @@ public class CreateAndRegisterMachineFromIsoIfNotAlreadyExistsTest {
|
||||||
.vm(launchSpecification)
|
.vm(launchSpecification)
|
||||||
.network(NetworkSpec.builder().build()).build();
|
.network(NetworkSpec.builder().build()).build();
|
||||||
|
|
||||||
new CreateAndRegisterMachineFromIsoIfNotAlreadyExists(Suppliers.ofInstance(manager), "/tmp/workingDir").apply(machineSpec);
|
new CreateAndRegisterMachineFromIsoIfNotAlreadyExists(Suppliers.ofInstance(manager), machineUtils, "/tmp/workingDir").apply(machineSpec);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ public class CreateMediumIfNotAlreadyExistsLiveTest extends BaseVirtualBoxClient
|
||||||
public void testCreateMedium() throws Exception {
|
public void testCreateMedium() throws Exception {
|
||||||
String path = System.getProperty("user.home") + "/jclouds-virtualbox-test/test-medium-1.vdi";
|
String path = System.getProperty("user.home") + "/jclouds-virtualbox-test/test-medium-1.vdi";
|
||||||
HardDisk hardDisk = HardDisk.builder().diskpath(path).controllerPort(0).deviceSlot(0).build();
|
HardDisk hardDisk = HardDisk.builder().diskpath(path).controllerPort(0).deviceSlot(0).build();
|
||||||
IMedium iMedium = new CreateMediumIfNotAlreadyExists(manager, true).apply(hardDisk);
|
IMedium iMedium = new CreateMediumIfNotAlreadyExists(manager, machineUtils, true).apply(hardDisk);
|
||||||
manager.get().getVBox().findMedium(path, DeviceType.HardDisk);
|
manager.get().getVBox().findMedium(path, DeviceType.HardDisk);
|
||||||
try {
|
try {
|
||||||
assertFileCanBeDeleted(path);
|
assertFileCanBeDeleted(path);
|
||||||
|
@ -56,7 +56,7 @@ public class CreateMediumIfNotAlreadyExistsLiveTest extends BaseVirtualBoxClient
|
||||||
String path = "test-medium-2.vdi";
|
String path = "test-medium-2.vdi";
|
||||||
HardDisk hardDisk = HardDisk.builder().diskpath(path).controllerPort(0).deviceSlot(0).build();
|
HardDisk hardDisk = HardDisk.builder().diskpath(path).controllerPort(0).deviceSlot(0).build();
|
||||||
try {
|
try {
|
||||||
new CreateMediumIfNotAlreadyExists(manager, true).apply(hardDisk);
|
new CreateMediumIfNotAlreadyExists(manager, machineUtils, true).apply(hardDisk);
|
||||||
fail();
|
fail();
|
||||||
} catch (VBoxException e) {
|
} catch (VBoxException e) {
|
||||||
ErrorCode errorCode = ErrorCode.valueOf(e);
|
ErrorCode errorCode = ErrorCode.valueOf(e);
|
||||||
|
@ -68,15 +68,14 @@ public class CreateMediumIfNotAlreadyExistsLiveTest extends BaseVirtualBoxClient
|
||||||
public void testCreateSameMediumTwiceWhenUsingOverwrite() throws Exception {
|
public void testCreateSameMediumTwiceWhenUsingOverwrite() throws Exception {
|
||||||
String path = System.getProperty("user.home") + "/jclouds-virtualbox-test/test-medium-3.vdi";
|
String path = System.getProperty("user.home") + "/jclouds-virtualbox-test/test-medium-3.vdi";
|
||||||
HardDisk hardDisk = HardDisk.builder().diskpath(path).controllerPort(0).deviceSlot(0).build();
|
HardDisk hardDisk = HardDisk.builder().diskpath(path).controllerPort(0).deviceSlot(0).build();
|
||||||
IMedium iMedium = new CreateMediumIfNotAlreadyExists(manager, true).apply(hardDisk);
|
new CreateMediumIfNotAlreadyExists(manager, machineUtils, true).apply(hardDisk);
|
||||||
iMedium = new CreateMediumIfNotAlreadyExists(manager, true).apply(hardDisk);
|
IMedium iMedium = new CreateMediumIfNotAlreadyExists(manager, machineUtils, true).apply(hardDisk);
|
||||||
manager.get().getVBox().findMedium(path, DeviceType.HardDisk);
|
manager.get().getVBox().findMedium(path, DeviceType.HardDisk);
|
||||||
try {
|
try {
|
||||||
assertFileCanBeDeleted(path);
|
assertFileCanBeDeleted(path);
|
||||||
} finally {
|
} finally {
|
||||||
deleteMediumAndBlockUntilComplete(iMedium);
|
deleteMediumAndBlockUntilComplete(iMedium);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertFileCanBeDeleted(String path) {
|
private void assertFileCanBeDeleted(String path) {
|
||||||
|
|
|
@ -28,7 +28,9 @@ import static org.easymock.classextension.EasyMock.replay;
|
||||||
import static org.easymock.classextension.EasyMock.verify;
|
import static org.easymock.classextension.EasyMock.verify;
|
||||||
import static org.testng.Assert.assertNotSame;
|
import static org.testng.Assert.assertNotSame;
|
||||||
|
|
||||||
|
import org.easymock.EasyMock;
|
||||||
import org.jclouds.virtualbox.domain.HardDisk;
|
import org.jclouds.virtualbox.domain.HardDisk;
|
||||||
|
import org.jclouds.virtualbox.util.MachineUtils;
|
||||||
import org.testng.annotations.BeforeMethod;
|
import org.testng.annotations.BeforeMethod;
|
||||||
import org.testng.annotations.Test;
|
import org.testng.annotations.Test;
|
||||||
import org.virtualbox_4_1.DeviceType;
|
import org.virtualbox_4_1.DeviceType;
|
||||||
|
@ -65,6 +67,8 @@ public class CreateMediumIfNotAlreadyExistsTest {
|
||||||
HardDisk hardDisk = createTestHardDisk();
|
HardDisk hardDisk = createTestHardDisk();
|
||||||
|
|
||||||
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
||||||
|
MachineUtils machineUtils = createMock(MachineUtils.class);
|
||||||
|
|
||||||
IMachine machine = createMock(IMachine.class);
|
IMachine machine = createMock(IMachine.class);
|
||||||
IVirtualBox vBox = createMock(IVirtualBox.class);
|
IVirtualBox vBox = createMock(IVirtualBox.class);
|
||||||
IMedium medium = createMock(IMedium.class);
|
IMedium medium = createMock(IMedium.class);
|
||||||
|
@ -75,17 +79,17 @@ public class CreateMediumIfNotAlreadyExistsTest {
|
||||||
errorBuilder.append("Could not find an open hard disk with location ");
|
errorBuilder.append("Could not find an open hard disk with location ");
|
||||||
errorBuilder.append("'/Users/johndoe/jclouds-virtualbox-test/testadmin.vdi' (0x80BB0001)");
|
errorBuilder.append("'/Users/johndoe/jclouds-virtualbox-test/testadmin.vdi' (0x80BB0001)");
|
||||||
String errorMessage = errorBuilder.toString();
|
String errorMessage = errorBuilder.toString();
|
||||||
|
|
||||||
expect(manager.getVBox()).andReturn(vBox).anyTimes();
|
expect(manager.getVBox()).andReturn(vBox).anyTimes();
|
||||||
|
|
||||||
VBoxException notFoundException = new VBoxException(createNiceMock(Throwable.class), errorMessage);
|
VBoxException notFoundException = new VBoxException(createNiceMock(Throwable.class), errorMessage);
|
||||||
expect(vBox.findMedium(eq(adminDiskPath), eq(DeviceType.HardDisk))).andThrow(notFoundException);
|
expect(vBox.findMedium(eq(adminDiskPath), eq(DeviceType.HardDisk))).andThrow(notFoundException);
|
||||||
expect(vBox.createHardDisk(diskFormat, adminDiskPath)).andReturn(medium);
|
expect(vBox.createHardDisk(diskFormat, adminDiskPath)).andReturn(medium);
|
||||||
expect(medium.createBaseStorage(anyLong(), anyLong())).andReturn(progress);
|
expect(medium.createBaseStorage(anyLong(), anyLong())).andReturn(progress);
|
||||||
|
//expect(machineUtils.writeLockMachineAndApply(anyString(), new DetachDistroMediumFromMachine(anyString(), anyInt() , anyInt()))).andReturn().anyTimes();
|
||||||
|
|
||||||
replay(manager, machine, vBox, medium);
|
replay(manager, machine, vBox, medium, machineUtils);
|
||||||
|
|
||||||
new CreateMediumIfNotAlreadyExists(Suppliers.ofInstance(manager), true).apply(hardDisk);
|
new CreateMediumIfNotAlreadyExists(Suppliers.ofInstance(manager), machineUtils, true).apply(hardDisk);
|
||||||
|
|
||||||
verify(machine, vBox);
|
verify(machine, vBox);
|
||||||
|
|
||||||
|
@ -96,6 +100,8 @@ public class CreateMediumIfNotAlreadyExistsTest {
|
||||||
HardDisk hardDisk = createTestHardDisk();
|
HardDisk hardDisk = createTestHardDisk();
|
||||||
|
|
||||||
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
||||||
|
MachineUtils machineUtils = createMock(MachineUtils.class);
|
||||||
|
|
||||||
IMachine machine = createMock(IMachine.class);
|
IMachine machine = createMock(IMachine.class);
|
||||||
IVirtualBox vBox = createMock(IVirtualBox.class);
|
IVirtualBox vBox = createMock(IVirtualBox.class);
|
||||||
IMedium medium = createMock(IMedium.class);
|
IMedium medium = createMock(IMedium.class);
|
||||||
|
@ -109,20 +115,24 @@ public class CreateMediumIfNotAlreadyExistsTest {
|
||||||
expect(vBox.createHardDisk(diskFormat, adminDiskPath)).andReturn(newHardDisk);
|
expect(vBox.createHardDisk(diskFormat, adminDiskPath)).andReturn(newHardDisk);
|
||||||
expect(newHardDisk.createBaseStorage(anyLong(), anyLong())).andReturn(progress);
|
expect(newHardDisk.createBaseStorage(anyLong(), anyLong())).andReturn(progress);
|
||||||
|
|
||||||
replay(manager, machine, vBox, medium, newHardDisk, progress);
|
//expect(machineUtils.writeLockMachineAndApply(anyString(), new DetachDistroMediumFromMachine(anyString(), anyInt() , anyInt()))).andReturn(v).anyTimes();
|
||||||
|
|
||||||
IMedium newDisk = new CreateMediumIfNotAlreadyExists(Suppliers.ofInstance(manager), true).apply(hardDisk);
|
replay(manager, machine, vBox, medium, newHardDisk, progress, machineUtils);
|
||||||
|
|
||||||
|
IMedium newDisk = new CreateMediumIfNotAlreadyExists(Suppliers.ofInstance(manager), machineUtils, true).apply(hardDisk);
|
||||||
|
|
||||||
verify(machine, vBox, medium);
|
verify(machine, vBox, medium);
|
||||||
assertNotSame(newDisk, medium);
|
assertNotSame(newDisk, medium);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test(enabled = false)
|
||||||
public void testDeleteAndCreateNewStorageWhenMediumExistsAndUsingOverwriteAndStillAttachedDetachesOldThing()
|
public void testDeleteAndCreateNewStorageWhenMediumExistsAndUsingOverwriteAndStillAttachedDetachesOldThing()
|
||||||
throws Exception {
|
throws Exception {
|
||||||
HardDisk hardDisk = createTestHardDisk();
|
HardDisk hardDisk = createTestHardDisk();
|
||||||
|
|
||||||
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
||||||
|
MachineUtils machineUtils = createMock(MachineUtils.class);
|
||||||
|
|
||||||
IMachine machine = createMock(IMachine.class);
|
IMachine machine = createMock(IMachine.class);
|
||||||
IVirtualBox vBox = createMock(IVirtualBox.class);
|
IVirtualBox vBox = createMock(IVirtualBox.class);
|
||||||
IMedium medium = createMock(IMedium.class);
|
IMedium medium = createMock(IMedium.class);
|
||||||
|
@ -176,9 +186,9 @@ public class CreateMediumIfNotAlreadyExistsTest {
|
||||||
expect(vBox.createHardDisk(diskFormat, adminDiskPath)).andReturn(newHardDisk);
|
expect(vBox.createHardDisk(diskFormat, adminDiskPath)).andReturn(newHardDisk);
|
||||||
expect(newHardDisk.createBaseStorage(anyLong(), anyLong())).andReturn(progress);
|
expect(newHardDisk.createBaseStorage(anyLong(), anyLong())).andReturn(progress);
|
||||||
|
|
||||||
replay(manager, oldMachine, oldAttachment, oldMedium, detachSession, machine, vBox, medium, newHardDisk, progress);
|
replay(manager, oldMachine, oldAttachment, oldMedium, detachSession, machine, vBox, medium, newHardDisk, progress, machineUtils);
|
||||||
|
|
||||||
IMedium newDisk = new CreateMediumIfNotAlreadyExists(Suppliers.ofInstance(manager), true).apply(hardDisk);
|
IMedium newDisk = new CreateMediumIfNotAlreadyExists(Suppliers.ofInstance(manager), machineUtils, true).apply(hardDisk);
|
||||||
|
|
||||||
verify(machine, oldMachine, oldAttachment, detachSession, oldMedium, vBox, medium);
|
verify(machine, oldMachine, oldAttachment, detachSession, oldMedium, vBox, medium);
|
||||||
assertNotSame(newDisk, medium);
|
assertNotSame(newDisk, medium);
|
||||||
|
@ -189,6 +199,8 @@ public class CreateMediumIfNotAlreadyExistsTest {
|
||||||
HardDisk hardDisk = createTestHardDisk();
|
HardDisk hardDisk = createTestHardDisk();
|
||||||
|
|
||||||
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
||||||
|
MachineUtils machineUtils = createMock(MachineUtils.class);
|
||||||
|
|
||||||
IMachine machine = createMock(IMachine.class);
|
IMachine machine = createMock(IMachine.class);
|
||||||
IVirtualBox vBox = createMock(IVirtualBox.class);
|
IVirtualBox vBox = createMock(IVirtualBox.class);
|
||||||
IMedium medium = createMock(IMedium.class);
|
IMedium medium = createMock(IMedium.class);
|
||||||
|
@ -198,9 +210,9 @@ public class CreateMediumIfNotAlreadyExistsTest {
|
||||||
expect(manager.getVBox()).andReturn(vBox).anyTimes();
|
expect(manager.getVBox()).andReturn(vBox).anyTimes();
|
||||||
expect(vBox.findMedium(adminDiskPath, DeviceType.HardDisk)).andReturn(medium);
|
expect(vBox.findMedium(adminDiskPath, DeviceType.HardDisk)).andReturn(medium);
|
||||||
|
|
||||||
replay(manager, machine, vBox, medium, newHardDisk, progress);
|
replay(manager, machine, vBox, medium, newHardDisk, progress, machineUtils);
|
||||||
|
|
||||||
new CreateMediumIfNotAlreadyExists(Suppliers.ofInstance(manager), false).apply(hardDisk);
|
new CreateMediumIfNotAlreadyExists(Suppliers.ofInstance(manager), machineUtils, false).apply(hardDisk);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expectedExceptions = VBoxException.class)
|
@Test(expectedExceptions = VBoxException.class)
|
||||||
|
@ -209,6 +221,8 @@ public class CreateMediumIfNotAlreadyExistsTest {
|
||||||
HardDisk hardDisk = createTestHardDisk();
|
HardDisk hardDisk = createTestHardDisk();
|
||||||
|
|
||||||
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
VirtualBoxManager manager = createNiceMock(VirtualBoxManager.class);
|
||||||
|
MachineUtils machineUtils = createMock(MachineUtils.class);
|
||||||
|
|
||||||
IMachine machine = createMock(IMachine.class);
|
IMachine machine = createMock(IMachine.class);
|
||||||
IVirtualBox vBox = createMock(IVirtualBox.class);
|
IVirtualBox vBox = createMock(IVirtualBox.class);
|
||||||
IMedium medium = createMock(IMedium.class);
|
IMedium medium = createMock(IMedium.class);
|
||||||
|
@ -223,9 +237,9 @@ public class CreateMediumIfNotAlreadyExistsTest {
|
||||||
expect(vBox.createHardDisk(diskFormat, adminDiskPath)).andReturn(medium);
|
expect(vBox.createHardDisk(diskFormat, adminDiskPath)).andReturn(medium);
|
||||||
expect(medium.createBaseStorage(anyLong(), anyLong())).andReturn(progress);
|
expect(medium.createBaseStorage(anyLong(), anyLong())).andReturn(progress);
|
||||||
|
|
||||||
replay(manager, machine, vBox, medium);
|
replay(manager, machine, vBox, medium, machineUtils);
|
||||||
|
|
||||||
new CreateMediumIfNotAlreadyExists(Suppliers.ofInstance(manager), true).apply(hardDisk);
|
new CreateMediumIfNotAlreadyExists(Suppliers.ofInstance(manager), machineUtils, true).apply(hardDisk);
|
||||||
}
|
}
|
||||||
|
|
||||||
private HardDisk createTestHardDisk() {
|
private HardDisk createTestHardDisk() {
|
||||||
|
|
|
@ -14,7 +14,7 @@ function exportIpAddressFromVmNamed {
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
local VMNAME="$0"; shift
|
local VMNAME="$0"; shift
|
||||||
local _FOUND=`vboxmanage guestproperty enumerate "$VMNAME" --patterns "/VirtualBox/GuestInfo/Net/0/V4/IP" | awk '{ print $4 }' | cut -c 1-14`
|
local _FOUND=`VBoxManage guestproperty enumerate "$VMNAME" --patterns "/VirtualBox/GuestInfo/Net/0/V4/IP" | awk '{ print $4 }' | cut -c 1-14`
|
||||||
[ -n "$_FOUND" ] && {
|
[ -n "$_FOUND" ] && {
|
||||||
export FOUND_IP_ADDRESS=$_FOUND
|
export FOUND_IP_ADDRESS=$_FOUND
|
||||||
echo [$FOUND_IP_ADDRESS]
|
echo [$FOUND_IP_ADDRESS]
|
||||||
|
|
|
@ -14,7 +14,7 @@ function getIpAddress {
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
local VMNAME="$0"; shift
|
local VMNAME="$0"; shift
|
||||||
local _FOUND=`vboxmanage guestproperty enumerate "$VMNAME" --patterns "/VirtualBox/GuestInfo/Net/0/V4/IP" | awk '{ print $4 }' | cut -c 1-14`
|
local _FOUND=`VBoxManage guestproperty enumerate "$VMNAME" --patterns "/VirtualBox/GuestInfo/Net/0/V4/IP" | awk '{ print $4 }' | cut -c 1-14`
|
||||||
[ -n "$_FOUND" ] && {
|
[ -n "$_FOUND" ] && {
|
||||||
export FOUND_IP_ADDRESS=$_FOUND
|
export FOUND_IP_ADDRESS=$_FOUND
|
||||||
echo [$FOUND_IP_ADDRESS]
|
echo [$FOUND_IP_ADDRESS]
|
||||||
|
|
Loading…
Reference in New Issue