com.github.webdriverextensions.DriverDownloader Maven / Gradle / Ivy
package com.github.webdriverextensions;
import org.apache.commons.io.FileUtils;
import org.apache.http.HttpEntity;
import org.apache.http.HttpHost;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.client.config.CookieSpecs;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.config.SocketConfig;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.DefaultHttpRequestRetryHandler;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.settings.Proxy;
import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.List;
import static com.github.webdriverextensions.Utils.quote;
import static org.apache.commons.io.FileUtils.copyInputStreamToFile;
public class DriverDownloader {
public static final int FILE_DOWNLOAD_READ_TIMEOUT = 30 * 60 * 1000; // 30 min
public static final int FILE_DOWNLOAD_CONNECT_TIMEOUT = 30 * 1000; // 30 seconds
public static final int FILE_DOWNLOAD_RETRY_ATTEMPTS = 3;
private final InstallDriversMojo mojo;
private final Proxy proxySettings;
public DriverDownloader(InstallDriversMojo mojo) throws MojoExecutionException {
this.mojo = mojo;
this.proxySettings = ProxyUtils.getProxyFromSettings(mojo);
}
public Path downloadFile(Driver driver, Path downloadDirectory) throws MojoExecutionException {
String url = driver.getUrl();
Path downloadFilePath = downloadDirectory.resolve(driver.getFilenameFromUrl());
if (downloadFilePath.toFile().exists() && !downloadCompletedFileExists(downloadDirectory)) {
mojo.getLog().info(" Removing downloaded driver " + quote(downloadFilePath) + " since it may be corrupt");
cleanupDriverDownloadDirectory(downloadDirectory);
} else if (!mojo.keepDownloadedWebdrivers) {
cleanupDriverDownloadDirectory(downloadDirectory);
}
if (downloadFilePath.toFile().exists()) {
mojo.getLog().info(" Using cached driver from " + quote(downloadFilePath));
} else {
mojo.getLog().info(" Downloading " + quote(url) + " to " + quote(downloadFilePath));
HttpClientBuilder httpClientBuilder = prepareHttpClientBuilderWithTimeoutsAndProxySettings(proxySettings);
httpClientBuilder.setRetryHandler(new DefaultHttpRequestRetryHandler(FILE_DOWNLOAD_RETRY_ATTEMPTS, true));
try (CloseableHttpClient httpClient = httpClientBuilder.build()) {
try (CloseableHttpResponse fileDownloadResponse = httpClient.execute(new HttpGet(url))) {
HttpEntity remoteFileStream = fileDownloadResponse.getEntity();
copyInputStreamToFile(remoteFileStream.getContent(), downloadFilePath.toFile());
if (driverFileIsCorrupt(downloadFilePath)) {
printXmlFileContetIfPresentInDonwloadedFile(downloadFilePath);
cleanupDriverDownloadDirectory(downloadDirectory);
throw new InstallDriversMojoExecutionException("Failed to download a non corrupt driver", mojo, driver);
}
}
} catch (InstallDriversMojoExecutionException e) {
throw e;
} catch (Exception e) {
throw new InstallDriversMojoExecutionException("Failed to download driver from " + quote(url) + " to " + quote(downloadFilePath) + " cause of " + e.getCause(), e, mojo, driver);
}
createDownloadCompletedFile(downloadDirectory);
}
return downloadFilePath;
}
private void printXmlFileContetIfPresentInDonwloadedFile(Path downloadFilePath) {
try {
List fileContent = Files.readAllLines(Paths.get("/Users/anders/Temp/downloads/old/phantomjs-linux-64bit-1.9.8/phantomjs-1.9.8-linux-x86_64.tar.bz2"), StandardCharsets.UTF_8);
if (fileContent.get(0).startsWith("
© 2015 - 2025 Weber Informatics LLC | Privacy Policy