adding virtualbox issue 384 - sshj

This commit is contained in:
andreaturli 2011-07-25 22:08:12 +01:00
parent 4070a7d689
commit 5a2053a3d0
4 changed files with 52 additions and 56 deletions

View File

@ -80,7 +80,7 @@
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.jclouds.driver</groupId> <groupId>org.jclouds.driver</groupId>
<artifactId>jclouds-jsch</artifactId> <artifactId>jclouds-sshj</artifactId>
<version>${project.version}</version> <version>${project.version}</version>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>

View File

@ -1,12 +1,12 @@
package org.jclouds.virtualbox.experiment; package org.jclouds.virtualbox.experiment;
import static com.google.common.base.Throwables.propagate; import static com.google.common.base.Throwables.propagate;
import static com.google.common.io.ByteStreams.copy;
import static com.google.common.io.Closeables.closeQuietly;
import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertEquals;
import java.io.BufferedReader; import java.io.BufferedReader;
import java.io.File; import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.InputStreamReader; import java.io.InputStreamReader;
@ -18,26 +18,26 @@ import java.net.URL;
import java.rmi.RemoteException; import java.rmi.RemoteException;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import javax.servlet.ServletException; import org.eclipse.jetty.server.Handler;
import javax.servlet.http.HttpServletRequest; import org.eclipse.jetty.server.Server;
import javax.servlet.http.HttpServletResponse; import org.eclipse.jetty.server.handler.DefaultHandler;
import org.eclipse.jetty.server.handler.HandlerList;
import org.eclipse.jetty.server.handler.ResourceHandler;
import org.eclipse.jetty.util.log.Log;
import org.jclouds.compute.domain.ExecResponse; import org.jclouds.compute.domain.ExecResponse;
import org.jclouds.crypto.CryptoStreams;
import org.jclouds.domain.Credentials; import org.jclouds.domain.Credentials;
import org.jclouds.logging.log4j.config.Log4JLoggingModule; import org.jclouds.logging.log4j.config.Log4JLoggingModule;
import org.jclouds.net.IPSocket; import org.jclouds.net.IPSocket;
import org.jclouds.predicates.InetSocketAddressConnect; import org.jclouds.predicates.InetSocketAddressConnect;
import org.jclouds.predicates.RetryablePredicate; import org.jclouds.predicates.RetryablePredicate;
import org.jclouds.ssh.SshClient; import org.jclouds.ssh.SshClient;
import org.jclouds.ssh.jsch.config.JschSshClientModule; import org.jclouds.sshj.config.SshjSshClientModule;
import org.jclouds.util.Strings2; import org.jclouds.util.Strings2;
import org.jclouds.virtualbox.experiment.settings.KeyboardScancodes; import org.jclouds.virtualbox.experiment.settings.KeyboardScancodes;
import org.testng.annotations.AfterClass; import org.testng.annotations.AfterClass;
import org.testng.annotations.AfterMethod; import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeGroups; import org.testng.annotations.BeforeGroups;
import org.testng.annotations.BeforeMethod; import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Optional;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import org.virtualbox_4_0.AccessMode; import org.virtualbox_4_0.AccessMode;
import org.virtualbox_4_0.DeviceType; import org.virtualbox_4_0.DeviceType;
@ -49,28 +49,17 @@ import org.virtualbox_4_0.IStorageController;
import org.virtualbox_4_0.LockType; import org.virtualbox_4_0.LockType;
import org.virtualbox_4_0.MachineState; import org.virtualbox_4_0.MachineState;
import org.virtualbox_4_0.NATProtocol; import org.virtualbox_4_0.NATProtocol;
import org.virtualbox_4_0.NetworkAdapterType;
import org.virtualbox_4_0.SessionState; import org.virtualbox_4_0.SessionState;
import org.virtualbox_4_0.StorageBus; import org.virtualbox_4_0.StorageBus;
import org.virtualbox_4_0.VirtualBoxManager; import org.virtualbox_4_0.VirtualBoxManager;
import org.virtualbox_4_0.jaxws.MediumVariant; import org.virtualbox_4_0.jaxws.MediumVariant;
import com.google.common.base.Predicate; import com.google.common.base.Predicate;
import com.google.common.base.Throwables;
import com.google.common.io.Files; import com.google.common.io.Files;
import com.google.common.io.InputSupplier; import com.google.common.io.InputSupplier;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector; import com.google.inject.Injector;
import org.eclipse.jetty.server.Handler;
import org.eclipse.jetty.server.Request;
import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.server.handler.AbstractHandler;
import org.eclipse.jetty.server.handler.DefaultHandler;
import org.eclipse.jetty.server.handler.HandlerList;
import org.eclipse.jetty.server.handler.ResourceHandler;
import org.eclipse.jetty.util.log.Log;
@Test(groups = "live", testName = "virtualbox.VirtualboxAdministrationKickstartTest") @Test(groups = "live", testName = "virtualbox.VirtualboxAdministrationKickstartTest")
public class VirtualboxAdministrationKickstartTest { public class VirtualboxAdministrationKickstartTest {
@ -92,8 +81,6 @@ public class VirtualboxAdministrationKickstartTest {
protected String osTypeId; // Guest OS Type ID. protected String osTypeId; // Guest OS Type ID.
protected String vmId; // Machine UUID (optional). protected String vmId; // Machine UUID (optional).
protected boolean forceOverwrite; protected boolean forceOverwrite;
protected String osUsername;
protected String osPassword;
protected String diskFormat; protected String diskFormat;
protected String workingDir; protected String workingDir;
@ -121,6 +108,11 @@ public class VirtualboxAdministrationKickstartTest {
protected Server server = null; protected Server server = null;
private InetSocketAddress testPort; private InetSocketAddress testPort;
private String vboxManageCommand; private String vboxManageCommand;
private String sshHost;
private String sshPort;
private String sshUser;
private String sshPass;
private String sshKeyFile;
protected void setupCredentials() { protected void setupCredentials() {
@ -135,13 +127,16 @@ public class VirtualboxAdministrationKickstartTest {
protected void setupConfigurationProperties() { protected void setupConfigurationProperties() {
sshHost = System.getProperty("test.ssh.host", "localhost");
sshPort = System.getProperty("test.ssh.port", "22");
sshUser = System.getProperty("test.ssh.username", "root");
sshPass = System.getProperty("test.ssh.password", "password");
sshKeyFile = System.getProperty("test.ssh.keyfile");
admin_pwd = System.getProperty("test." + provider + ".admin_pwd", admin_pwd = System.getProperty("test." + provider + ".admin_pwd",
"password"); "password");
// OS
osUsername = System.getProperty("test." + provider + ".osusername",
"toor");
osPassword = System.getProperty("test." + provider + ".ospassword",
"password");
controllerIDE = System.getProperty("test." + provider controllerIDE = System.getProperty("test." + provider
+ ".controllerIde", "IDE Controller"); + ".controllerIde", "IDE Controller");
controllerSATA = System.getProperty("test." + provider controllerSATA = System.getProperty("test." + provider
@ -247,7 +242,7 @@ public class VirtualboxAdministrationKickstartTest {
hostPassword = System.getProperty("test." + provider + ".hostpassword", hostPassword = System.getProperty("test." + provider + ".hostpassword",
"password"); "password");
injector = Guice.createInjector(new JschSshClientModule(), injector = Guice.createInjector(new SshjSshClientModule(),
new Log4JLoggingModule()); new Log4JLoggingModule());
sshFactory = injector.getInstance(SshClient.Factory.class); sshFactory = injector.getInstance(SshClient.Factory.class);
socketTester = new RetryablePredicate<IPSocket>( socketTester = new RetryablePredicate<IPSocket>(
@ -293,7 +288,7 @@ public class VirtualboxAdministrationKickstartTest {
client.connect(); client.connect();
client.exec("echo " + hostPassword + " | " + installVboxOse); client.exec("echo " + hostPassword + " | " + installVboxOse);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); System.out.println("It is impossible to install virtualbox with this command " + installVboxOse);
} finally { } finally {
if (client != null) if (client != null)
client.disconnect(); client.disconnect();
@ -313,12 +308,9 @@ public class VirtualboxAdministrationKickstartTest {
InterruptedException { InterruptedException {
// Disable login credential: $ // Disable login credential: $
// rt.exec("VBoxManage setproperty websrvauthlibrary null"); // rt.exec("VBoxManage setproperty websrvauthlibrary null");
IPSocket socket = new IPSocket("127.0.0.1", 22); SshClient client = setupSshClient();
socketTester.apply(socket);
SshClient client = sshFactory.create(socket, new Credentials(hostUsername, hostPassword));
try { try {
client.connect(); ExecResponse response = client.exec(command);
ExecResponse response = client.exec("start " + command);
System.out.println(response.getOutput()); System.out.println(response.getOutput());
} catch (Exception e) { } catch (Exception e) {
propagate(e); propagate(e);
@ -328,6 +320,22 @@ public class VirtualboxAdministrationKickstartTest {
} }
} }
private SshClient setupSshClient() throws FileNotFoundException, IOException {
int port = Integer.parseInt(sshPort);
Injector i = Guice.createInjector(new SshjSshClientModule());
SshClient.Factory factory = i.getInstance(SshClient.Factory.class);
SshClient connection;
if (sshKeyFile != null && !sshKeyFile.trim().equals("")) {
connection = factory.create(new IPSocket(sshHost, port),
new Credentials(sshUser, Strings2.toStringAndClose(new FileInputStream(sshKeyFile))));
} else {
connection = factory.create(new IPSocket(sshHost, port), new Credentials(sshUser, sshPass));
}
connection.connect();
return connection;
}
@BeforeMethod @BeforeMethod
protected void setupManager() { protected void setupManager() {
manager.connect(endpoint, identity, credential); manager.connect(endpoint, identity, credential);
@ -501,16 +509,13 @@ public class VirtualboxAdministrationKickstartTest {
} }
@Test(dependsOnMethods = "testStartVirtualMachine") @Test(dependsOnMethods = "testStartVirtualMachine")
public void testConfigureGuestAdditions() { public void testConfigureGuestAdditions() throws FileNotFoundException, IOException {
// configure GA // configure GA
IPSocket socket = new IPSocket("127.0.0.1", 2222); SshClient client = setupSshClient();
socketTester.apply(socket);
SshClient client = sshFactory.create(socket, new Credentials(osUsername, osPassword));
try { try {
client.connect();
//Configure your system for building kernel modules by running //Configure your system for building kernel modules by running
ExecResponse exec = client.exec("echo " + osPassword + " | " + "sudo -S m-a prepare -i"); ExecResponse exec = client.exec("echo " + sshPass + " | " + "sudo -S m-a prepare -i");
System.out.println(exec); System.out.println(exec);
} finally { } finally {
if (client != null) { if (client != null) {
@ -518,16 +523,11 @@ public class VirtualboxAdministrationKickstartTest {
} }
} }
socketTester.apply(socket);
client = sshFactory.create(socket, new Credentials(osUsername,
osPassword));
try { try {
client.connect();
ExecResponse exec = client ExecResponse exec = client
.exec("echo " + osPassword + " | " + "sudo -S mount -o loop /usr/share/virtualbox/VBoxGuestAdditions.iso /mnt"); .exec("echo " + sshPass + " | " + "sudo -S mount -o loop /usr/share/virtualbox/VBoxGuestAdditions.iso /mnt");
System.out.println(exec); System.out.println(exec);
exec = client.exec("echo " + osPassword + " | " + "sudo -S sh /mnt/VBoxLinuxAdditions.run"); exec = client.exec("echo " + sshPass + " | " + "sudo -S sh /mnt/VBoxLinuxAdditions.run");
System.out.println(exec); System.out.println(exec);
} finally { } finally {
if (client != null) if (client != null)

View File

@ -2,11 +2,9 @@ package org.jclouds.virtualbox.experiment;
import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertEquals;
import java.io.BufferedReader;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection; import java.net.HttpURLConnection;
import java.net.MalformedURLException; import java.net.MalformedURLException;
import java.net.Proxy; import java.net.Proxy;
@ -21,7 +19,7 @@ import org.jclouds.net.IPSocket;
import org.jclouds.predicates.InetSocketAddressConnect; import org.jclouds.predicates.InetSocketAddressConnect;
import org.jclouds.predicates.RetryablePredicate; import org.jclouds.predicates.RetryablePredicate;
import org.jclouds.ssh.SshClient; import org.jclouds.ssh.SshClient;
import org.jclouds.ssh.jsch.config.JschSshClientModule; import org.jclouds.sshj.config.SshjSshClientModule;
import org.testng.annotations.AfterClass; import org.testng.annotations.AfterClass;
import org.testng.annotations.AfterMethod; import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeGroups; import org.testng.annotations.BeforeGroups;
@ -198,7 +196,7 @@ public class VirtualboxAdministrationTest {
hostUsername = System.getProperty("test." + provider + ".hostusername", "toor"); hostUsername = System.getProperty("test." + provider + ".hostusername", "toor");
hostPassword = System.getProperty("test." + provider + ".hostpassword", "password"); hostPassword = System.getProperty("test." + provider + ".hostpassword", "password");
injector = Guice.createInjector(new JschSshClientModule(), injector = Guice.createInjector(new SshjSshClientModule(),
new Log4JLoggingModule()); new Log4JLoggingModule());
sshFactory = injector.getInstance(SshClient.Factory.class); sshFactory = injector.getInstance(SshClient.Factory.class);
socketTester = new RetryablePredicate<IPSocket>( socketTester = new RetryablePredicate<IPSocket>(

View File

@ -9,7 +9,6 @@ import java.io.IOException;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.net.MalformedURLException; import java.net.MalformedURLException;
import java.rmi.RemoteException; import java.rmi.RemoteException;
import java.util.Properties;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import org.jclouds.compute.domain.ExecResponse; import org.jclouds.compute.domain.ExecResponse;
@ -19,7 +18,7 @@ import org.jclouds.net.IPSocket;
import org.jclouds.predicates.InetSocketAddressConnect; import org.jclouds.predicates.InetSocketAddressConnect;
import org.jclouds.predicates.RetryablePredicate; import org.jclouds.predicates.RetryablePredicate;
import org.jclouds.ssh.SshClient; import org.jclouds.ssh.SshClient;
import org.jclouds.ssh.jsch.config.JschSshClientModule; 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.BeforeMethod; import org.testng.annotations.BeforeMethod;
@ -37,7 +36,6 @@ import org.virtualbox_4_0.SessionState;
import org.virtualbox_4_0.StorageBus; import org.virtualbox_4_0.StorageBus;
import org.virtualbox_4_0.VirtualBoxManager; import org.virtualbox_4_0.VirtualBoxManager;
import org.virtualbox_4_0.jaxws.MediumState; import org.virtualbox_4_0.jaxws.MediumState;
import org.virtualbox_4_0.jaxws.MediumVariant;
import com.google.common.base.Predicate; import com.google.common.base.Predicate;
import com.google.inject.Guice; import com.google.inject.Guice;
@ -117,7 +115,7 @@ public class VirtualboxLiveTest {
endpoint = System.getProperty("test." + provider + ".endpoint", "http://localhost:18083/"); endpoint = System.getProperty("test." + provider + ".endpoint", "http://localhost:18083/");
apiversion = System.getProperty("test." + provider + ".apiversion"); apiversion = System.getProperty("test." + provider + ".apiversion");
injector = Guice.createInjector(new JschSshClientModule(), injector = Guice.createInjector(new SshjSshClientModule(),
new Log4JLoggingModule()); new Log4JLoggingModule());
sshFactory = injector.getInstance(SshClient.Factory.class); sshFactory = injector.getInstance(SshClient.Factory.class);
socketTester = new RetryablePredicate<IPSocket>( socketTester = new RetryablePredicate<IPSocket>(