
org.scalatest.finders.WordSpecFinder Maven / Gradle / Ivy
The newest version!
/*
* Copyright 2001-2008 Artima, Inc.
*
* 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.scalatest.finders;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
public class WordSpecFinder implements Finder {
private Set scopeSet;
public WordSpecFinder() {
scopeSet = new HashSet();
scopeSet.add("should");
scopeSet.add("must");
scopeSet.add("can");
scopeSet.add("which");
scopeSet.add("when");
scopeSet.add("that"); // 'that' is deprecated
}
private String getTestNameBottomUp(MethodInvocation invocation) {
String result = "";
while (invocation != null) {
String targetText = invocation.name().equals("in") ? invocation.target().toString() : (invocation.target().toString() + " " + invocation.name());
result = targetText + " " + result;
if (invocation.parent() != null && invocation.parent() instanceof MethodInvocation)
invocation = (MethodInvocation) invocation.parent();
else
invocation = null;
}
return result.trim();
}
private String getDisplayNameBottomUp(MethodInvocation invocation) {
if (invocation.parent() == null || !(invocation.parent() instanceof MethodInvocation))
return invocation.target().toString();
else
return getTestNameBottomUp((MethodInvocation) invocation.parent()) + " " + invocation.target().toString();
}
private List getTestNamesTopDown(MethodInvocation invocation) {
List results = new ArrayList();
List nodes = new ArrayList();
nodes.add(invocation);
while (nodes.size() > 0) {
AstNode head = nodes.remove(0);
if (head instanceof MethodInvocation) {
MethodInvocation headInvocation = (MethodInvocation) head;
if (headInvocation.name().equals("in")) {
String testName = getTestNameBottomUp(headInvocation);
results.add(testName);
}
else
nodes.addAll(0, Arrays.asList(headInvocation.children()));
}
}
return results;
}
public Selection find(AstNode node) {
Selection result = null;
while (result == null) {
if (node instanceof MethodInvocation) {
MethodInvocation invocation = (MethodInvocation) node;
String name = invocation.name();
AstNode parent = invocation.parent();
if (name.equals("in") && scopeSet.contains(parent.name())) {
String testName = getTestNameBottomUp(invocation);
result = new Selection(invocation.className(), testName, new String[] { testName });
}
else if (scopeSet.contains(name)) {
String displayName = getDisplayNameBottomUp(invocation);
List testNames = getTestNamesTopDown(invocation);
result = new Selection(invocation.className(), displayName, testNames.toArray(new String[testNames.size()]));
}
}
if (result == null) {
if (node.parent() != null)
node = node.parent();
else
break;
}
}
return result;
}
}
/*package org.scalatest.finders
import scala.annotation.tailrec
class WordSpecFinder extends Finder {
val scopeSet = Set("should", "must", "can", "which", "when", "that") // note 'that' is deprecated
private def getTestNameBottomUp(invocation: MethodInvocation): String = {
val targetText =
if (invocation.name == "in")
invocation.target.toString
else
invocation.target.toString + " " + invocation.name
if(invocation.parent == null || !invocation.parent.isInstanceOf[MethodInvocation])
targetText
else
getTestNameBottomUp(invocation.parent.asInstanceOf[MethodInvocation]) + " " + targetText
}
private def getDisplayNameBottomUp(invocation: MethodInvocation): String = {
if(invocation.parent == null || !invocation.parent.isInstanceOf[MethodInvocation])
invocation.target.toString
else
getTestNameBottomUp(invocation.parent.asInstanceOf[MethodInvocation]) + " " + invocation.target.toString
}
private def getTestNamesTopDown(invocation: MethodInvocation): List[String] = {
@tailrec
def getTestNamesTopDownAcc(invocations: List[AstNode], acc: List[String]): List[String] = invocations match {
case Nil => acc
case node :: rs =>
node match {
case invocation: MethodInvocation =>
if (invocation.name == "in") {
val testName = getTestNameBottomUp(invocation)
getTestNamesTopDownAcc(rs, testName :: acc)
}
else {
getTestNamesTopDownAcc(invocation.children.toList ::: rs, acc)
}
case _ => getTestNamesTopDownAcc(rs, acc)
}
}
getTestNamesTopDownAcc(List(invocation), List.empty).reverse
}
def find(node: AstNode): Option[Selection] = {
node match {
case invocation @ MethodInvocation(className, target, parent, children, name, args) =>
name match {
case "in" if scopeSet.contains(parent.name) =>
val testName = getTestNameBottomUp(invocation)
Some(new Selection(className, testName, Array(testName)))
case _ =>
if (scopeSet.contains(name)) {
val displayName = getDisplayNameBottomUp(invocation)
val testNames = getTestNamesTopDown(invocation)
Some(new Selection(className, displayName, testNames.toArray))
}
else {
if (node.parent != null)
find(node.parent)
else
None
}
}
case _ =>
if (node.parent != null)
find(node.parent)
else
None
}
}
}*/
© 2015 - 2025 Weber Informatics LLC | Privacy Policy