issue 384: kickstart admin node on macosx -> complete

This commit is contained in:
andreaturli 2011-09-11 00:34:31 +01:00
parent 1c6c85fa51
commit 97f93ef779
2 changed files with 142 additions and 85 deletions

View File

@ -99,8 +99,7 @@ public class VirtualboxAdministrationKickstartLiveTest {
protected String diskFormat; protected String diskFormat;
protected String workingDir; protected String workingDir;
protected String originalDisk; protected String adminDisk;
protected String clonedDisk;
protected String guestAdditionsDvd; protected String guestAdditionsDvd;
private URI gaIsoUrl; private URI gaIsoUrl;
@ -158,11 +157,7 @@ public class VirtualboxAdministrationKickstartLiveTest {
+ File.separator + File.separator
+ System.getProperty("test." + provider + ".workingDir", + System.getProperty("test." + provider + ".workingDir",
"jclouds-virtualbox-test"); "jclouds-virtualbox-test");
if (new File(workingDir).mkdir()) if (new File(workingDir).mkdir());
;
// gaIsoName = System.getProperty("test." + provider + ".gaIsoName",
// "VBoxGuestAdditions_" + majorVersion + "-update-" + minorVersion +
// ".iso");
gaIsoName = System.getProperty("test." + provider + ".gaIsoName", gaIsoName = System.getProperty("test." + provider + ".gaIsoName",
"VBoxGuestAdditions_" + majorVersion + ".iso"); "VBoxGuestAdditions_" + majorVersion + ".iso");
gaIsoUrl = URI.create(System.getProperty("test." + provider gaIsoUrl = URI.create(System.getProperty("test." + provider
@ -177,13 +172,8 @@ public class VirtualboxAdministrationKickstartLiveTest {
"http://releases.ubuntu.com/11.04/ubuntu-11.04-server-i386.iso")); "http://releases.ubuntu.com/11.04/ubuntu-11.04-server-i386.iso"));
vboxDmg = URI.create(System.getProperty("test." + provider + ".vboxDmg","http://download.virtualbox.org/virtualbox/4.1.2/VirtualBox-4.1.2-73507-OSX.dmg")); vboxDmg = URI.create(System.getProperty("test." + provider + ".vboxDmg","http://download.virtualbox.org/virtualbox/4.1.2/VirtualBox-4.1.2-73507-OSX.dmg"));
vboxVersionName = System.getProperty("test" + provider + ".vboxVersionName", "VirtualBox-4.1.2-73507-OSX.dmg"); vboxVersionName = System.getProperty("test" + provider + ".vboxVersionName", "VirtualBox-4.1.2-73507-OSX.dmg");
originalDisk = workingDir
+ File.separator adminDisk = workingDir
+ "VDI"
+ File.separator
+ System.getProperty("test." + provider + ".originalDisk",
"centos-5.2-x86.vdi");
clonedDisk = workingDir
+ File.separator + File.separator
+ System.getProperty("test." + provider + ".clonedDisk", + System.getProperty("test." + provider + ".clonedDisk",
"disk.vdi"); "disk.vdi");
@ -372,8 +362,8 @@ public class VirtualboxAdministrationKickstartLiveTest {
@Test(dependsOnMethods = "testAttachIsoDvd") @Test(dependsOnMethods = "testAttachIsoDvd")
public void testCreateAndAttachHardDisk() throws InterruptedException { public void testCreateAndAttachHardDisk() throws InterruptedException {
IMedium hd = null; IMedium hd = null;
if (!new File(clonedDisk).exists()) { if (!new File(adminDisk).exists()) {
hd = manager.getVBox().createHardDisk(diskFormat, clonedDisk); hd = manager.getVBox().createHardDisk(diskFormat, adminDisk);
long size = 4L * 1024L * 1024L * 1024L - 4L; long size = 4L * 1024L * 1024L * 1024L - 4L;
IProgress progress = hd.createBaseStorage(new Long(size), new Long( IProgress progress = hd.createBaseStorage(new Long(size), new Long(
MediumVariant.STANDARD.ordinal())); MediumVariant.STANDARD.ordinal()));

View File

@ -19,6 +19,8 @@
package org.jclouds.virtualbox.experiment; package org.jclouds.virtualbox.experiment;
import static com.google.common.base.Preconditions.checkNotNull; import static com.google.common.base.Preconditions.checkNotNull;
import static org.jclouds.compute.options.RunScriptOptions.Builder.runAsRoot;
import static org.jclouds.compute.options.RunScriptOptions.Builder.wrapInInitScript;
import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertEquals;
import java.io.BufferedReader; import java.io.BufferedReader;
@ -26,12 +28,16 @@ import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.net.MalformedURLException; import java.net.MalformedURLException;
import java.net.URI;
import java.rmi.RemoteException; import java.rmi.RemoteException;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import org.jclouds.compute.ComputeServiceContext;
import org.jclouds.compute.domain.ExecResponse; import org.jclouds.compute.domain.ExecResponse;
import org.jclouds.compute.options.RunScriptOptions;
import org.jclouds.domain.Credentials; import org.jclouds.domain.Credentials;
import org.jclouds.encryption.bouncycastle.config.BouncyCastleCryptoModule; import org.jclouds.encryption.bouncycastle.config.BouncyCastleCryptoModule;
import org.jclouds.logging.Logger;
import org.jclouds.logging.slf4j.config.SLF4JLoggingModule; import org.jclouds.logging.slf4j.config.SLF4JLoggingModule;
import org.jclouds.net.IPSocket; import org.jclouds.net.IPSocket;
import org.jclouds.predicates.InetSocketAddressConnect; import org.jclouds.predicates.InetSocketAddressConnect;
@ -40,6 +46,7 @@ import org.jclouds.ssh.SshClient;
import org.jclouds.sshj.config.SshjSshClientModule; import org.jclouds.sshj.config.SshjSshClientModule;
import org.testng.annotations.AfterMethod; import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeClass; import org.testng.annotations.BeforeClass;
import org.testng.annotations.BeforeGroups;
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.AccessMode; import org.virtualbox_4_1.AccessMode;
@ -51,12 +58,17 @@ import org.virtualbox_4_1.ISession;
import org.virtualbox_4_1.LockType; import org.virtualbox_4_1.LockType;
import org.virtualbox_4_1.MachineState; import org.virtualbox_4_1.MachineState;
import org.virtualbox_4_1.MediumType; import org.virtualbox_4_1.MediumType;
import org.virtualbox_4_1.NetworkAdapterType;
import org.virtualbox_4_1.NetworkAttachmentType;
import org.virtualbox_4_1.SessionState; import org.virtualbox_4_1.SessionState;
import org.virtualbox_4_1.StorageBus; import org.virtualbox_4_1.StorageBus;
import org.virtualbox_4_1.VirtualBoxManager; import org.virtualbox_4_1.VirtualBoxManager;
import org.virtualbox_4_1.jaxws.MediumState; import org.virtualbox_4_1.jaxws.MediumState;
import org.virtualbox_4_1.jaxws.MediumVariant;
import com.google.common.base.Predicate; import com.google.common.base.Predicate;
import com.google.common.base.Splitter;
import com.google.common.collect.Iterables;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector; import com.google.inject.Injector;
@ -66,11 +78,11 @@ public class VirtualboxLiveTest {
protected String provider = "virtualbox"; protected String provider = "virtualbox";
protected String identity; protected String identity;
protected String credential; protected String credential;
protected String endpoint; protected URI endpoint;
protected String apiversion; protected String apiversion;
protected String vmName; protected String vmName;
VirtualBoxManager manager = VirtualBoxManager.createInstance(null); VirtualBoxManager manager = VirtualBoxManager.createInstance("");
protected Injector injector; protected Injector injector;
protected Predicate<IPSocket> socketTester; protected Predicate<IPSocket> socketTester;
@ -92,7 +104,6 @@ public class VirtualboxLiveTest {
// file will be overwritten. // file will be overwritten.
protected String workingDir; protected String workingDir;
protected String originalDiskPath;
protected String clonedDiskPath; protected String clonedDiskPath;
// Create disk If the @a format attribute is empty or null then the default // Create disk If the @a format attribute is empty or null then the default
@ -100,8 +111,35 @@ public class VirtualboxLiveTest {
String format = "vdi"; String format = "vdi";
protected int numberOfVirtualMachine; protected int numberOfVirtualMachine;
protected String originalDisk;
private String originalDiskPath;
private String clonedDisk;
private IMedium clonedHd;
private ComputeServiceContext context;
private String hostId = "host";
private String guestId = "guest";
private String majorVersion;
private String minorVersion;
private String apiVersion;
protected Logger logger() {
return context.utils().loggerFactory().getLogger("jclouds.compute");
}
protected void setupCredentials() {
identity = System.getProperty("test." + provider + ".identity",
"administrator");
credential = System.getProperty("test." + provider + ".credential",
"12345");
endpoint = URI.create(System.getProperty("test." + provider
+ ".endpoint", "http://localhost:18083/"));
apiVersion = System.getProperty("test." + provider + ".apiversion",
"4.1.2r73507");
majorVersion = Iterables.get(Splitter.on('r').split(apiVersion), 0);
minorVersion = Iterables.get(Splitter.on('r').split(apiVersion), 1);
}
@BeforeClass
protected void setupConfigurationProperties() { protected void setupConfigurationProperties() {
// VBOX // VBOX
settingsFile = null; // Fully qualified path where the settings file settingsFile = null; // Fully qualified path where the settings file
@ -119,38 +157,44 @@ public class VirtualboxLiveTest {
// be overwritten. // be overwritten.
// OS specific information // OS specific information
vmName = checkNotNull(System.getProperty("test." + provider + ".vmname")); vmName = checkNotNull(System.getProperty("test." + provider + ".vmname", "jclouds-virtualbox-node"));
osUsername = System.getProperty("test." + provider + ".osusername", "root"); osUsername = System.getProperty("test." + provider + ".osusername", "toor");
osPassword = System.getProperty("test." + provider + ".ospassword", "toortoor"); osPassword = System.getProperty("test." + provider + ".ospassword", "password");
controller = System.getProperty("test." + provider + ".controller", "IDE Controller"); controller = System.getProperty("test." + provider + ".controller", "IDE Controller");
diskFormat = System.getProperty("test." + provider + ".diskformat", ""); diskFormat = System.getProperty("test." + provider + ".diskformat", "");
workingDir = checkNotNull(System.getProperty("test." + provider + ".workingDir")); workingDir = System.getProperty("user.home")
+ File.separator
+ System.getProperty("test." + provider + ".workingDir",
"jclouds-virtualbox-test");
originalDiskPath = workingDir + File.separator originalDisk = System.getProperty("test." + provider + ".originalDisk", "admin.vdi");
+ checkNotNull(System.getProperty("test." + provider + ".originalDisk")); originalDiskPath = workingDir
+ File.separator + originalDisk;
clonedDisk = System.getProperty("test." + provider + ".clonedDisk", "clone.vdi");
clonedDiskPath = workingDir + File.separator + clonedDisk;
numberOfVirtualMachine = Integer.parseInt(checkNotNull(System.getProperty("test." + provider numberOfVirtualMachine = Integer.parseInt(checkNotNull(System.getProperty("test." + provider
+ ".numberOfVirtualMachine"))); + ".numberOfVirtualMachine", "2")));
} }
@BeforeClass
protected void setupCredentials() throws RemoteException, MalformedURLException {
identity = System.getProperty("test." + provider + ".identity", "administrator");
credential = System.getProperty("test." + provider + ".credential", "12345");
endpoint = System.getProperty("test." + provider + ".endpoint", "http://localhost:18083/");
apiversion = System.getProperty("test." + provider + ".apiversion");
injector = Guice.createInjector(new SshjSshClientModule(), new SLF4JLoggingModule(), @BeforeGroups(groups = "live")
new BouncyCastleCryptoModule()); protected void setupClient() throws Exception {
sshFactory = injector.getInstance(SshClient.Factory.class); context = TestUtils.computeServiceForLocalhost();
socketTester = new RetryablePredicate<IPSocket>(new InetSocketAddressConnect(), 180, 1, TimeUnit.SECONDS); socketTester = new RetryablePredicate<IPSocket>(
injector.injectMembers(socketTester); new InetSocketAddressConnect(), 130, 10, TimeUnit.SECONDS);
setupCredentials();
setupConfigurationProperties();
if (!new InetSocketAddressConnect().apply(new IPSocket(endpoint.getHost(), endpoint.getPort())))
startupVboxWebServer();
} }
@BeforeMethod @BeforeMethod
protected void setupManager() throws RemoteException, MalformedURLException { protected void setupManager() throws RemoteException, MalformedURLException {
manager.connect(endpoint, identity, credential); manager.connect(endpoint.toASCIIString(), identity, credential);
} }
@AfterMethod @AfterMethod
@ -160,14 +204,28 @@ public class VirtualboxLiveTest {
} }
@Test @Test
public void testCloneHardDisk() {
IMedium hd = manager.getVBox().openMedium(originalDiskPath, DeviceType.HardDisk, AccessMode.ReadWrite, forceOverwrite);
if (!new File(clonedDiskPath).exists()) {
clonedHd = manager.getVBox().createHardDisk(diskFormat, clonedDiskPath);
IProgress cloning = hd.cloneTo(clonedHd, new Long(
MediumVariant.STANDARD.ordinal()), null);
cloning.waitForCompletion(-1);
} else
clonedHd = manager.getVBox().openMedium(clonedDiskPath, DeviceType.HardDisk, AccessMode.ReadWrite, forceOverwrite);
assertEquals(clonedHd.getId().equals(""), false);
}
@Test(dependsOnMethods = "testCloneHardDisk")
public void testStartVirtualMachines() { public void testStartVirtualMachines() {
IMedium clonedHd = cloneDisk(MediumType.MultiAttach); //IMedium clonedHd = cloneDisk(MediumType.MultiAttach);
for (int i = 1; i < numberOfVirtualMachine + 1; i++) { for (int i = 1; i < numberOfVirtualMachine + 1; i++) {
createVirtualMachine(i, clonedHd); createVirtualMachine(i);
} }
} }
private void createVirtualMachine(int i, IMedium clonedHd) { private void createVirtualMachine(int i) {
String instanceName = vmName + "_" + i; String instanceName = vmName + "_" + i;
@ -178,11 +236,6 @@ public class VirtualboxLiveTest {
IMachine machine = manager.getVBox().findMachine(instanceName); IMachine machine = manager.getVBox().findMachine(instanceName);
machine.lockMachine(session, LockType.Write); machine.lockMachine(session, LockType.Write);
IMachine mutable = session.getMachine(); IMachine mutable = session.getMachine();
// disk
mutable.addStorageController(controller, StorageBus.IDE);
mutable.attachDevice(controller, 0, 0, DeviceType.HardDisk, clonedHd);
// network // network
String hostInterface = null; String hostInterface = null;
String command = "vboxmanage list bridgedifs"; String command = "vboxmanage list bridgedifs";
@ -211,47 +264,25 @@ public class VirtualboxLiveTest {
// mutable.getNetworkAdapter(new Long(0)).attachToBridgedInterface(); // mutable.getNetworkAdapter(new Long(0)).attachToBridgedInterface();
// mutable.getNetworkAdapter(new // mutable.getNetworkAdapter(new
// Long(0)).setHostInterface(hostInterface.trim()); // Long(0)).setHostInterface(hostInterface.trim());
mutable.getNetworkAdapter(new Long(0)).setAttachmentType(
NetworkAttachmentType.Bridged);
mutable.getNetworkAdapter(new Long(0)).setBridgedInterface(hostInterface.trim());
mutable.getNetworkAdapter(new Long(0)).setEnabled(true); mutable.getNetworkAdapter(new Long(0)).setEnabled(true);
mutable.saveSettings();
mutable.saveSettings(); // disk
mutable.addStorageController(controller, StorageBus.IDE);
mutable.saveSettings();
IMedium distroMedium = manager.getVBox().openMedium(
clonedDiskPath, DeviceType.HardDisk,
AccessMode.ReadWrite, forceOverwrite);
mutable.attachDevice(controller, 0, 0, DeviceType.HardDisk, distroMedium);
mutable.saveSettings();
session.unlockMachine(); session.unlockMachine();
} }
/**
* @param instanceName
* @return
*/
private IMedium cloneDisk(MediumType mediumType) {
String clonedDisk = System.getProperty("test." + provider + ".clonedDisk");
String instanceClonedDisk = clonedDisk.split("\\.")[0] + "." + clonedDisk.split("\\.")[1];
clonedDiskPath = workingDir + File.separator + instanceClonedDisk;
// use template disk in multiattach mode
IMedium clonedHd = manager.getVBox().openMedium(originalDiskPath, DeviceType.HardDisk, AccessMode.ReadOnly,
forceOverwrite);
System.out.println("cloned HD state: " + clonedHd.getState());
/*
* An image in multiattach mode can be attached to more than one virtual
* machine at the same time, even if these machines are running
* simultaneously. For each virtual machine to which such an image is
* attached, a differencing image is created. As a result, data that is
* written to such a virtual disk by one machine is not seen by the other
* machines to which the image is attached; each machine creates its own
* write history of the multiattach image.
*/
while (clonedHd.getState().equals(MediumState.NOT_CREATED)) {
try {
Thread.sleep(1500);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
clonedHd.setType(mediumType);
return clonedHd;
}
private void launchVMProcess(IMachine machine, ISession session) { private void launchVMProcess(IMachine machine, ISession session) {
IProgress prog = machine.launchVMProcess(session, "gui", ""); IProgress prog = machine.launchVMProcess(session, "gui", "");
@ -281,7 +312,7 @@ public class VirtualboxLiveTest {
String instanceName = vmName + "_" + i; String instanceName = vmName + "_" + i;
IMachine machine = manager.getVBox().findMachine(instanceName); IMachine machine = manager.getVBox().findMachine(instanceName);
System.out.println("\nLaunch VM named " + machine.getName() + " ..."); System.out.println("\nLaunching VM named " + machine.getName() + " ...");
launchVMProcess(machine, manager.getSessionObject()); launchVMProcess(machine, manager.getSessionObject());
while (ipAddress == null || ipAddress.equals("")) { while (ipAddress == null || ipAddress.equals("")) {
@ -326,4 +357,40 @@ public class VirtualboxLiveTest {
} }
} }
} }
protected ExecResponse runScriptOnNode(String nodeId, String command,
RunScriptOptions options) {
ExecResponse toReturn = context.getComputeService().runScriptOnNode(
nodeId, command, options);
assert toReturn.getExitCode() == 0 : toReturn;
return toReturn;
}
protected ExecResponse runScriptOnNode(String nodeId, String command) {
return runScriptOnNode(nodeId, command, wrapInInitScript(false));
}
protected boolean isOSX(String id) {
return context.getComputeService().getNodeMetadata(hostId)
.getOperatingSystem().getDescription().equals("Mac OS X");
}
void startupVboxWebServer() {
logger().debug("disabling password access");
runScriptOnNode(hostId, "VBoxManage setproperty websrvauthlibrary null", runAsRoot(false).wrapInInitScript(false));
logger().debug("starting vboxwebsrv");
String vboxwebsrv = "vboxwebsrv -t 10000 -v -b";
if (isOSX(hostId))
vboxwebsrv = "cd /Applications/VirtualBox.app/Contents/MacOS/ && "
+ vboxwebsrv;
runScriptOnNode(
hostId,
vboxwebsrv,
runAsRoot(false).wrapInInitScript(false)
.blockOnPort(endpoint.getPort(), 10)
.blockOnComplete(false)
.nameTask("vboxwebsrv"));
}
} }