Files
openide/testSource/com/intellij/codeInsight/daemon/quickFix/LightQuickFixTestCase.java
Alexey Kudravtsev 687600e0af (no message)
2005-02-08 13:59:19 +03:00

132 lines
5.4 KiB
Java

package com.intellij.codeInsight.daemon.quickFix;
import com.intellij.codeInsight.daemon.LightDaemonAnalyzerTestCase;
import com.intellij.codeInsight.daemon.impl.HighlightInfo;
import com.intellij.codeInsight.intention.IntentionAction;
import com.intellij.openapi.util.Pair;
import com.intellij.openapi.util.TextRange;
import com.intellij.openapi.util.io.FileUtil;
import com.intellij.openapi.util.text.StringUtil;
import com.intellij.openapi.editor.Editor;
import com.intellij.psi.xml.XmlFile;
import com.intellij.psi.PsiFile;
import java.io.File;
import java.io.FilenameFilter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public abstract class LightQuickFixTestCase extends LightDaemonAnalyzerTestCase {
protected void doTestFor(final String testName) throws Exception {
final String relativePath = getBasePath() + "/before" + testName;
final String testFullPath = getTestDataPath().replace(File.separatorChar, '/') + relativePath;
final File ioFile = new File(testFullPath);
String contents = StringUtil.convertLineSeparators(new String(FileUtil.loadFileText(ioFile)), "\n");
configureFromFileText(ioFile.getName(), contents);
final Pair<String, Boolean> pair = parseActionHint(getFile());
final String text = pair.getFirst();
final boolean actionShouldBeAvailable = pair.getSecond().booleanValue();
doAction(text, actionShouldBeAvailable, testFullPath, testName);
}
public static Pair<String, Boolean> parseActionHint(final PsiFile file) throws IOException {
String comment = file instanceof XmlFile ? "<!--" : "//";
// "quick fix action text to perform" "should be available"
Pattern pattern = Pattern.compile("^" + comment + " \"([^\"]*)\" \"(\\S*)\".*", Pattern.DOTALL);
Matcher matcher = pattern.matcher(new String(file.getVirtualFile().contentsToCharArray()));
assertTrue(matcher.matches());
final String text = matcher.group(1);
final Boolean actionShouldBeAvailable = Boolean.valueOf(matcher.group(2));
return Pair.create(text, actionShouldBeAvailable);
}
protected void doAction(final String text, final boolean actionShouldBeAvailable, final String testFullPath, final String testName)
throws Exception {
IntentionAction action = findActionWithText(text);
if (action == null) {
if (actionShouldBeAvailable) {
fail("Action with text '" + text + "' is not available in test " + testFullPath);
}
}
else {
if (!actionShouldBeAvailable) {
fail("Action '" + text + "' is available in test " + testFullPath);
}
action.invoke(getProject(), getEditor(), getFile());
final IntentionAction afterAction = findActionWithText(text);
if (afterAction != null) {
fail("Action '" + text + "' is still available after it's invocation in test " + testFullPath);
}
final String expectedFilePath = getBasePath() + "/after" + testName;
checkResultByFile("In file :" + expectedFilePath, expectedFilePath, false);
}
}
protected IntentionAction findActionWithText(final String text) {
final List<IntentionAction> actions = getAvailableActions();
return findActionWithText(actions, text);
}
public static IntentionAction findActionWithText(final List<IntentionAction> actions, final String text) {
for (int j = 0; j < actions.size(); j++) {
IntentionAction action = actions.get(j);
if (text.equals(action.getText())) {
return action;
}
}
return null;
}
protected void doAllTests() throws Exception {
final String testDirPath = getTestDataPath().replace(File.separatorChar, '/') + getBasePath();
File testDir = new File(testDirPath);
final File[] files = testDir.listFiles(new FilenameFilter() {
public boolean accept(File dir, String name) {
return name.startsWith("before");
}
});
for (int i = 0; i < files.length; i++) {
File file = files[i];
final String testName = file.getName().substring("before".length());
doTestFor(testName);
System.out.print((i + 1) % 10);
}
}
private List<IntentionAction> getAvailableActions() {
final HighlightInfo[] infos = doHighlighting();
return getAvailableActions(infos, getEditor(), getFile());
}
public static List<IntentionAction> getAvailableActions(final HighlightInfo[] infos, final Editor editor, final PsiFile file) {
final int offset = editor.getCaretModel().getOffset();
final List<IntentionAction> availableActions = new ArrayList<IntentionAction>();
for (int i = 0; infos != null && i < infos.length; i++) {
HighlightInfo info = infos[i];
final int startOffset = info.fixStartOffset;
final int endOffset = info.fixEndOffset;
if (startOffset <= offset && offset <= endOffset
&& info.quickFixActionRanges != null
) {
for (int j = 0; j < info.quickFixActionRanges.size(); j++) {
Pair<IntentionAction, TextRange> pair = info.quickFixActionRanges.get(j);
IntentionAction action = pair.first;
TextRange range = pair.second;
if (range.getStartOffset() <= offset && offset <= range.getEndOffset() &&
action.isAvailable(getProject(), editor, file)) {
availableActions.add(action);
}
}
}
}
return availableActions;
}
protected abstract String getBasePath();
}