57 lines
1.5 KiB
Java
Raw Normal View History

2014-03-14 16:34:25 +01:00
package syntaxTree;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import mycompiler.MyCompiler;
import mycompiler.MyCompilerAPI;
import mycompiler.SourceFile;
import mycompiler.SyntaxTreeNode;
import mycompiler.myparser.JavaParser.yyException;
import org.junit.Test;
import junit.framework.TestCase;
public class NodeEqualTest extends TestCase{
2014-03-17 17:55:55 +01:00
private static final String rootDirectory = System.getProperty("user.dir")+"/test/syntaxTree/";
private static final String testFile = "NodeEqualTest.jav";
2014-03-14 16:34:25 +01:00
@Test
public void test(){
MyCompilerAPI compiler = MyCompiler.getAPI();
2014-03-17 17:55:55 +01:00
MyCompilerAPI compiler2 = MyCompiler.getAPI();
2014-03-14 16:34:25 +01:00
SourceFile tree = null;
2014-03-17 17:55:55 +01:00
SourceFile tree2 = null;
2014-03-14 16:34:25 +01:00
try {
tree = compiler.parse(new File(rootDirectory + testFile));
2014-03-17 17:55:55 +01:00
tree2 = compiler2.parse(new File(rootDirectory + testFile));
2014-03-14 16:34:25 +01:00
} catch (IOException | yyException e) {
e.printStackTrace();
fail();
}
2014-03-17 17:55:55 +01:00
recursivlyCheckEqual(tree, tree2);
2014-03-14 16:34:25 +01:00
}
private void recursivlyCheckEqual(SyntaxTreeNode node1, SyntaxTreeNode node2){
for(SyntaxTreeNode n1 : node1.getChildren()){
int matches = 0;
for(SyntaxTreeNode n2 : node2.getChildren()){
if(n2.equals(n1)){
2014-03-17 17:55:55 +01:00
System.out.println(n2 + " == "+n1);
2014-03-14 16:34:25 +01:00
matches++;
this.recursivlyCheckEqual(n1, n2);
2014-03-17 17:55:55 +01:00
}else{
System.out.println(n2 + " != "+ n1);
2014-03-14 16:34:25 +01:00
}
}
2014-03-17 17:55:55 +01:00
System.out.println("");
assertTrue("Nur eines der Children darf gleich sein, nicht "+matches, matches == 1 && node2.getChildren().size()>0);
2014-03-14 16:34:25 +01:00
}
}
}