org.gradle.process.internal.worker.DefaultSingleRequestWorkerProcessBuilder Maven / Gradle / Ivy
/*
* Copyright 2016 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.gradle.process.internal.worker;
import org.gradle.api.logging.LogLevel;
import org.gradle.internal.Cast;
import org.gradle.internal.classloader.ClasspathUtil;
import org.gradle.internal.logging.events.OutputEventListener;
import org.gradle.internal.operations.CurrentBuildOperationRef;
import org.gradle.internal.remote.ObjectConnection;
import org.gradle.process.internal.JavaExecHandleBuilder;
import org.gradle.process.internal.worker.request.Receiver;
import org.gradle.process.internal.worker.request.Request;
import org.gradle.process.internal.worker.request.RequestArgumentSerializers;
import org.gradle.process.internal.worker.request.RequestProtocol;
import org.gradle.process.internal.worker.request.RequestSerializerRegistry;
import org.gradle.process.internal.worker.request.ResponseProtocol;
import org.gradle.process.internal.worker.request.WorkerAction;
import java.io.File;
import java.util.Set;
class DefaultSingleRequestWorkerProcessBuilder implements SingleRequestWorkerProcessBuilder {
private final Class> workerImplementation;
private final DefaultWorkerProcessBuilder builder;
private final RequestArgumentSerializers argumentSerializers = new RequestArgumentSerializers();
private final OutputEventListener outputEventListener;
public DefaultSingleRequestWorkerProcessBuilder(Class> workerImplementation, DefaultWorkerProcessBuilder builder, OutputEventListener outputEventListener) {
this.workerImplementation = workerImplementation;
this.builder = builder;
this.outputEventListener = outputEventListener;
builder.worker(new WorkerAction(workerImplementation));
builder.setImplementationClasspath(ClasspathUtil.getClasspath(workerImplementation.getClassLoader()).getAsURLs());
}
@Override
public WorkerProcessSettings setBaseName(String baseName) {
builder.setBaseName(baseName);
return this;
}
@Override
public String getBaseName() {
return builder.getBaseName();
}
@Override
public WorkerProcessSettings applicationClasspath(Iterable files) {
builder.applicationClasspath(files);
return this;
}
@Override
public Set getApplicationClasspath() {
return builder.getApplicationClasspath();
}
@Override
public WorkerProcessSettings applicationModulePath(Iterable files) {
builder.applicationModulePath(files);
return this;
}
@Override
public Set getApplicationModulePath() {
return builder.getApplicationModulePath();
}
@Override
public WorkerProcessSettings sharedPackages(String... packages) {
builder.sharedPackages(packages);
return this;
}
@Override
public WorkerProcessSettings sharedPackages(Iterable packages) {
builder.sharedPackages(packages);
return this;
}
@Override
public Set getSharedPackages() {
return builder.getSharedPackages();
}
@Override
public JavaExecHandleBuilder getJavaCommand() {
return builder.getJavaCommand();
}
@Override
public LogLevel getLogLevel() {
return builder.getLogLevel();
}
@Override
public WorkerProcessSettings setLogLevel(LogLevel logLevel) {
builder.setLogLevel(logLevel);
return this;
}
@Override
public RequestHandler build() {
return new RequestHandler() {
@Override
public OUT run(IN request) {
Receiver receiver = new Receiver(getBaseName(), outputEventListener);
try {
WorkerProcess workerProcess = builder.build();
workerProcess.start();
ObjectConnection connection = workerProcess.getConnection();
RequestProtocol requestProtocol = connection.addOutgoing(RequestProtocol.class);
connection.addIncoming(ResponseProtocol.class, receiver);
connection.useJavaSerializationForParameters(workerImplementation.getClassLoader());
connection.useParameterSerializers(RequestSerializerRegistry.create(workerImplementation.getClassLoader(), argumentSerializers));
connection.connect();
// TODO(ew): inject BuildOperationIdentifierRegistry instead of static use
requestProtocol.runThenStop(new Request(request, CurrentBuildOperationRef.instance().get()));
boolean hasResult = receiver.awaitNextResult();
workerProcess.waitForStop();
if (!hasResult) {
// Reached the end of input, worker has exited without failing
throw new IllegalStateException(String.format("No response was received from %s but the worker process has finished.", getBaseName()));
}
} catch (Exception e) {
throw WorkerProcessException.runFailed(getBaseName(), e);
}
return Cast.uncheckedNonnullCast(receiver.getNextResult());
}
};
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy