Merge pull request #339 from sk89q/feature/improved-travis-builds

Improve Travis builds
This commit is contained in:
Wizjany 2016-02-05 14:20:22 -05:00
commit 3bd87cfb2d
2 changed files with 44 additions and 8 deletions

View File

@ -2,8 +2,19 @@ language: java
notifications: notifications:
email: false email: false
before_install: chmod +x gradlew before_install: chmod +x gradlew
install: ./gradlew setupCIWorkspace -S install: ./gradlew setupCIWorkspace -s
matrix: script: ./gradlew build -s
include: jdk:
- jdk: oraclejdk7 - oraclejdk8
script: ./gradlew build -S - oraclejdk7
- openjdk6
# Caching for Gradle files, prevents hitting Maven too much.
before_cache:
- rm -f $HOME/.gradle/caches/modules-2/modules-2.lock
cache:
directories:
- $HOME/.gradle/caches/
- $HOME/.gradle/wrapper/
# Faster builds without sudo.
sudo: false

View File

@ -29,6 +29,7 @@ import java.util.ArrayDeque;
import java.util.Deque; import java.util.Deque;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
import java.util.zip.ZipFile;
import static com.google.common.base.Preconditions.checkNotNull; import static com.google.common.base.Preconditions.checkNotNull;
@ -55,6 +56,7 @@ public final class Closer implements Closeable {
// only need space for 2 elements in most cases, so try to use the smallest array possible // only need space for 2 elements in most cases, so try to use the smallest array possible
private final Deque<Closeable> stack = new ArrayDeque<Closeable>(4); private final Deque<Closeable> stack = new ArrayDeque<Closeable>(4);
private final Deque<ZipFile> zipStack = new ArrayDeque<ZipFile>(4);
private Throwable thrown; private Throwable thrown;
@VisibleForTesting Closer(Suppressor suppressor) { @VisibleForTesting Closer(Suppressor suppressor) {
@ -73,6 +75,17 @@ public final class Closer implements Closeable {
return closeable; return closeable;
} }
/**
* Registers the given {@code zipFile} to be closed when this {@code Closer} is
* {@linkplain #close closed}.
*
* @return the given {@code closeable}
*/
public <Z extends ZipFile> Z register(Z zipFile) {
zipStack.push(zipFile);
return zipFile;
}
/** /**
* Stores the given throwable and rethrows it. It will be rethrown as is if it is an * Stores the given throwable and rethrows it. It will be rethrown as is if it is an
* {@code IOException}, {@code RuntimeException} or {@code Error}. Otherwise, it will be rethrown * {@code IOException}, {@code RuntimeException} or {@code Error}. Otherwise, it will be rethrown
@ -161,6 +174,18 @@ public final class Closer implements Closeable {
} }
} }
} }
while (!zipStack.isEmpty()) {
ZipFile zipFile = zipStack.pop();
try {
zipFile.close();
} catch (Throwable e) {
if (throwable == null) {
throwable = e;
} else {
suppressor.suppress(zipFile, throwable, e);
}
}
}
if (thrown == null && throwable != null) { if (thrown == null && throwable != null) {
Throwables.propagateIfPossible(throwable, IOException.class); Throwables.propagateIfPossible(throwable, IOException.class);
@ -177,7 +202,7 @@ public final class Closer implements Closeable {
* the given closeable. {@code thrown} is the exception that is actually being thrown from the * the given closeable. {@code thrown} is the exception that is actually being thrown from the
* method. Implementations of this method should not throw under any circumstances. * method. Implementations of this method should not throw under any circumstances.
*/ */
void suppress(Closeable closeable, Throwable thrown, Throwable suppressed); void suppress(Object closeable, Throwable thrown, Throwable suppressed);
} }
/** /**
@ -188,7 +213,7 @@ public final class Closer implements Closeable {
static final LoggingSuppressor INSTANCE = new LoggingSuppressor(); static final LoggingSuppressor INSTANCE = new LoggingSuppressor();
@Override @Override
public void suppress(Closeable closeable, Throwable thrown, Throwable suppressed) { public void suppress(Object closeable, Throwable thrown, Throwable suppressed) {
// log to the same place as Closeables // log to the same place as Closeables
logger.log(Level.WARNING, "Suppressing exception thrown when closing " + closeable, suppressed); logger.log(Level.WARNING, "Suppressing exception thrown when closing " + closeable, suppressed);
} }
@ -217,7 +242,7 @@ public final class Closer implements Closeable {
} }
@Override @Override
public void suppress(Closeable closeable, Throwable thrown, Throwable suppressed) { public void suppress(Object closeable, Throwable thrown, Throwable suppressed) {
// ensure no exceptions from addSuppressed // ensure no exceptions from addSuppressed
if (thrown == suppressed) { if (thrown == suppressed) {
return; return;