All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.flapdoodle.embed.process.io.LogWatchStreamProcessor Maven / Gradle / Ivy

/*
 * Copyright (C) 2011
 *   Michael Mosmann 
 *   Martin Jöhren 
 *
 * with contributions from
 * 	konstantin-ba@github,
	Archimedes Trajano (trajano@github),
	Kevin D. Keck (kdkeck@github),
	Ben McCann (benmccann@github)
 *
 * 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 de.flapdoodle.embed.process.io;

import java.util.HashSet;
import java.util.Set;

/**
 * @see ListeningStreamProcessor
 * @see SuccessMessageLineListener
 */
@Deprecated
public class LogWatchStreamProcessor implements StreamProcessor {

	//private final Reader _reader;
	private final StringBuilder output = new StringBuilder();
	private final String success;
	private final Set failures;

	private boolean initWithSuccess = false;
	private String failureFound = null;

	private final StreamProcessor destination;

	public LogWatchStreamProcessor(String success, Set failures, StreamProcessor destination) {
		this.success = success;
		this.failures = new HashSet<>(failures);
		this.destination = destination;
	}

	@Override
	public void process(String block) {
		destination.process(block);

		output.append((CharSequence) block);

		if (output.indexOf(success) != -1) {
			gotResult(true,null);
		} else {
			for (String failure : failures) {
				int failureIndex = output.indexOf(failure);
				if (failureIndex != -1) {
					gotResult(false,output.substring(failureIndex));
				}
			}
		}
	}

	@Override
	public void onProcessed() {
		gotResult(false,"");
	}

	private synchronized void gotResult(boolean success, String message) {
		this.initWithSuccess=success;
		failureFound=message;
		notify();
	}

	public synchronized void waitForResult(long timeout) {
		try {
			wait(timeout);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
	}

	public boolean isInitWithSuccess() {
		return initWithSuccess;
	}
	
	public String getFailureFound() {
		return failureFound;
	}
	
	public String getOutput() {
		return output.toString();
	}


}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy