use of org.robovm.libimobiledevice.AfcClient.UploadProgressCallback in project robovm by robovm.
the class InstallationProxyClientTest method testUpgradeIPA.
//removed as test until it can be rewritten to re-sign the ipa
public void testUpgradeIPA() throws Exception {
Path tmpDir = Files.createTempDirectory(getClass().getSimpleName());
Files.copy(getClass().getResourceAsStream("/demo.ipa"), tmpDir.resolve("demo.ipa"));
afcClient.upload(tmpDir.resolve("demo.ipa").toFile(), "/TestStaging", new UploadProgressCallback() {
public void progress(File path, int percentComplete) {
System.out.format("[%3d%%] Uploading %s\n", percentComplete, path);
}
public void success() {
System.out.format("[100%%] Upload done\n");
}
public void error(String message) {
System.out.format("Error: %s\n", message);
}
});
final boolean[] success = new boolean[] { false };
final CountDownLatch countDownLatch = new CountDownLatch(1);
client.upgrade("/TestStaging/demo.ipa", new Options(), new StatusCallback() {
@Override
public void progress(String status, int percentComplete) {
System.out.format("[%3d%%] %s\n", percentComplete, status);
}
@Override
public void success() {
System.out.format("[100%%] Complete\n");
success[0] = true;
countDownLatch.countDown();
}
@Override
public void error(String message) {
System.out.println("Error: " + message);
countDownLatch.countDown();
}
});
countDownLatch.await(10, TimeUnit.SECONDS);
assertTrue(success[0]);
}
use of org.robovm.libimobiledevice.AfcClient.UploadProgressCallback in project robovm by robovm.
the class InstallationProxyClientTest method testUpgradeAppBundle.
//removed as test until it can be rewritten to re-sign the ipa
public void testUpgradeAppBundle() throws Exception {
Path tmpDir = Files.createTempDirectory(getClass().getSimpleName());
Path ipaFile = tmpDir.resolve("demo.ipa");
Files.copy(getClass().getResourceAsStream("/demo.ipa"), ipaFile);
extractZip(ipaFile, tmpDir);
Path appDir = tmpDir.resolve("Payload/demo.app");
afcClient.upload(appDir.toFile(), "/TestStaging", new UploadProgressCallback() {
public void progress(File path, int percentComplete) {
System.out.format("[%3d%%] Uploading %s\n", percentComplete, path);
}
public void success() {
System.out.format("[100%%] Upload done\n");
}
public void error(String message) {
System.out.format("Error: %s\n", message);
}
});
final boolean[] success = new boolean[] { false };
final CountDownLatch countDownLatch = new CountDownLatch(1);
client.upgrade("/TestStaging/demo.app", new Options().packageType(PackageType.Developer), new StatusCallback() {
@Override
public void progress(String status, int percentComplete) {
System.out.format("[%3d%%] %s\n", percentComplete, status);
}
@Override
public void success() {
System.out.format("[100%%] Complete\n");
success[0] = true;
countDownLatch.countDown();
}
@Override
public void error(String message) {
System.out.println("Error: " + message);
countDownLatch.countDown();
}
});
countDownLatch.await(10, TimeUnit.SECONDS);
assertTrue(success[0]);
}
use of org.robovm.libimobiledevice.AfcClient.UploadProgressCallback in project robovm by robovm.
the class IOSTarget method createIOSDevLauncher.
private Launcher createIOSDevLauncher(LaunchParameters launchParameters) throws IOException {
IOSDeviceLaunchParameters deviceLaunchParameters = (IOSDeviceLaunchParameters) launchParameters;
String deviceId = deviceLaunchParameters.getDeviceId();
int forwardPort = deviceLaunchParameters.getForwardPort();
AppLauncherCallback callback = deviceLaunchParameters.getAppPathCallback();
if (deviceId == null) {
String[] udids = IDevice.listUdids();
if (udids.length == 0) {
throw new RuntimeException("No devices connected");
}
if (udids.length > 1) {
config.getLogger().warn("More than 1 device connected (%s). " + "Using %s.", Arrays.asList(udids), udids[0]);
}
deviceId = udids[0];
}
device = new IDevice(deviceId);
OutputStream out = null;
if (launchParameters.getStdoutFifo() != null) {
out = new OpenOnWriteFileOutputStream(launchParameters.getStdoutFifo());
} else {
out = System.out;
}
Map<String, String> env = launchParameters.getEnvironment();
if (env == null) {
env = new HashMap<>();
}
AppLauncher launcher = new AppLauncher(device, getAppDir()) {
protected void log(String s, Object... args) {
config.getLogger().info(s, args);
}
}.stdout(out).closeOutOnExit(true).args(launchParameters.getArguments().toArray(new String[0])).env(env).forward(forwardPort).appLauncherCallback(callback).xcodePath(ToolchainUtil.findXcodePath()).uploadProgressCallback(new UploadProgressCallback() {
boolean first = true;
public void success() {
config.getLogger().info("[100%%] Upload complete");
}
public void progress(File path, int percentComplete) {
if (first) {
config.getLogger().info("[ 0%%] Beginning upload...");
}
first = false;
config.getLogger().info("[%3d%%] Uploading %s...", percentComplete, path);
}
public void error(String message) {
}
}).installStatusCallback(new StatusCallback() {
boolean first = true;
public void success() {
config.getLogger().info("[100%%] Install complete");
}
public void progress(String status, int percentComplete) {
if (first) {
config.getLogger().info("[ 0%%] Beginning installation...");
}
first = false;
config.getLogger().info("[%3d%%] %s", percentComplete, status);
}
public void error(String message) {
}
});
return new AppLauncherProcess(config.getLogger(), launcher, launchParameters);
}
Aggregations