blob: b69636bd643e8532caad78085a789ed9b589c211 [file] [log] [blame]
/*
* Copyright 2000-2009 JetBrains s.r.o.
*
* 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 com.intellij.execution.testframework.ui;
import com.intellij.execution.filters.HyperlinkInfo;
import com.intellij.execution.testframework.*;
import com.intellij.execution.ui.ConsoleView;
import com.intellij.execution.ui.ConsoleViewContentType;
import com.intellij.openapi.Disposable;
import org.jetbrains.annotations.NotNull;
public class TestsOutputConsolePrinter implements Printer, Disposable {
private final ConsoleView myConsole;
private final TestConsoleProperties myProperties;
private final AbstractTestProxy myUnboundOutputRoot;
private AbstractTestProxy myCurrentTest;
// After pause action has been invoked - all output will be redirected to special
// myPausedPrinter which will dump all buffered data after user will continue process.
private final DeferingPrinter myPausedPrinter = new DeferingPrinter();
private boolean myPaused = false;
private int myMarkOffset = 0;
private final TestFrameworkPropertyListener<Boolean> myPropertyListener = new TestFrameworkPropertyListener<Boolean>() {
public void onChanged(final Boolean value) {
if (!value.booleanValue()) myMarkOffset = 0;
}
};
public TestsOutputConsolePrinter(@NotNull BaseTestsOutputConsoleView testsOutputConsoleView, final TestConsoleProperties properties, final AbstractTestProxy unboundOutputRoot) {
this(testsOutputConsoleView.getConsole(), properties, unboundOutputRoot);
}
/**
* @deprecated left for JSTestDriver compatibility
*/
@Deprecated
public TestsOutputConsolePrinter(final ConsoleView console, final TestConsoleProperties properties, final AbstractTestProxy unboundOutputRoot) {
myConsole = console;
myProperties = properties;
myUnboundOutputRoot = unboundOutputRoot;
myProperties.addListener(TestConsoleProperties.SCROLL_TO_STACK_TRACE, myPropertyListener);
}
public ConsoleView getConsole() {
return myConsole;
}
public boolean isPaused() {
return myPaused;
}
public void pause(final boolean doPause) {
myPaused = doPause;
if (!doPause) {
myPausedPrinter.printAndForget(this);
}
}
public void print(final String text, final ConsoleViewContentType contentType) {
myConsole.print(text, contentType);
}
public void onNewAvailable(@NotNull final Printable printable) {
if (myPaused) {
printable.printOn(myPausedPrinter);
} else {
printable.printOn(this);
}
}
/**
* Clears console, prints output of selected test and scrolls to beginning
* of output.
* This method must be invoked in Event Dispatch Thread
* @param test Selected test
*/
public void updateOnTestSelected(final AbstractTestProxy test) {
if (myCurrentTest == test) {
return;
}
if (myCurrentTest != null) {
myCurrentTest.setPrinter(null);
}
myMarkOffset = 0;
final Runnable clearRunnable = new Runnable() {
public void run() {
myConsole.clear();
}
};
if (test == null) {
myCurrentTest = null;
CompositePrintable.invokeInAlarm(clearRunnable);
return;
}
myCurrentTest = test;
myCurrentTest.setPrinter(this);
final Runnable scrollRunnable = new Runnable() {
@Override
public void run() {
scrollToBeginning();
}
};
final AbstractTestProxy currentProxyOrRoot = getCurrentProxyOrRoot();
CompositePrintable.invokeInAlarm(clearRunnable);
currentProxyOrRoot.printOn(this);
CompositePrintable.invokeInAlarm(scrollRunnable);
}
private AbstractTestProxy getCurrentProxyOrRoot() {
return isRoot() && myUnboundOutputRoot != null ? myUnboundOutputRoot : myCurrentTest;
}
public boolean isCurrent(CompositePrintable printable) {
return myCurrentTest == printable || isRoot();
}
private boolean isRoot() {
final AbstractTestProxy currentTest = myCurrentTest;
return currentTest != null && currentTest.getParent() == myUnboundOutputRoot;
}
public void printHyperlink(final String text, final HyperlinkInfo info) {
myConsole.printHyperlink(text, info);
}
public void mark() {
if (TestConsoleProperties.SCROLL_TO_STACK_TRACE.value(myProperties))
myMarkOffset = myConsole.getContentSize();
}
public void dispose() {
myProperties.removeListener(TestConsoleProperties.SCROLL_TO_STACK_TRACE, myPropertyListener);
}
public boolean canPause() {
return myCurrentTest != null ? myCurrentTest.isInProgress() : false;
}
protected void scrollToBeginning() {
myConsole.performWhenNoDeferredOutput(new Runnable() {
public void run() {
final AbstractTestProxy currentProxyOrRoot = getCurrentProxyOrRoot();
if (currentProxyOrRoot != null && !currentProxyOrRoot.isInProgress()) {
//do not scroll to any mark during run
myConsole.scrollTo(myMarkOffset);
}
}
});
}
}