*/
package net.sourceforge.phpeclipse.phpeditor.php.test;
-import java.io.PrintWriter;
-import java.io.StringWriter;
-import java.util.Locale;
-
-import net.sourceforge.phpdt.core.compiler.IProblem;
import net.sourceforge.phpdt.core.tests.util.AbstractCompilerTest;
-import net.sourceforge.phpdt.core.tests.util.Util;
-import net.sourceforge.phpdt.internal.compiler.CompilationResult;
-import net.sourceforge.phpdt.internal.compiler.DefaultErrorHandlingPolicies;
-import net.sourceforge.phpdt.internal.compiler.batch.CompilationUnit;
-import net.sourceforge.phpdt.internal.compiler.env.ICompilationUnit;
-import net.sourceforge.phpdt.internal.compiler.parser.UnitParser;
-import net.sourceforge.phpdt.internal.compiler.problem.DefaultProblem;
-import net.sourceforge.phpdt.internal.compiler.problem.DefaultProblemFactory;
-import net.sourceforge.phpdt.internal.compiler.problem.ProblemReporter;
-import net.sourceforge.phpeclipse.internal.compiler.ast.CompilationUnitDeclaration;
-import net.sourceforge.phpeclipse.internal.compiler.ast.TypeDeclaration;
-/**
- * @author khartlage
- *
- * To change the template for this generated type comment go to
- * Window - Preferences - Java - Code Generation - Code and Comments
- */
public class DualParseSyntaxErrorTest extends AbstractCompilerTest {
public static boolean optimizeStringLiterals = false;
public DualParseSyntaxErrorTest(String testName){
super(testName);
}
- public void checkParse(
- char[] source,
- String expectedSyntaxErrorDiagnosis,
- String testName) {
+
+ public void test01() {
+ String s =
+ "$login =1; " +
+ "final class test {\n" +
+ "\n" +
+ "private function f1() {\n" +
+ "\n" +
+ "}\n" +
+ "public function f2() {\n" +
+ "\n" +
+ " \n" +
+ "} \n" +
+ "}";
- UnitParser parser =
- new UnitParser(
- new ProblemReporter(
- DefaultErrorHandlingPolicies.proceedWithAllProblems(),
- //new CompilerOptions(getCompilerOptions()),
- new DefaultProblemFactory(Locale.getDefault())));
+ String expectedSyntaxErrorDiagnosis =
+ "";
- ICompilationUnit sourceUnit = new CompilationUnit(source, testName, null);
- CompilationResult compilationResult = new CompilationResult(sourceUnit, 0, 0, 0);
-
- CompilationUnitDeclaration computedUnit = parser.dietParse(sourceUnit, compilationResult, true);
-// if (computedUnit.types != null) {
-// for (int i = computedUnit.types.size(); --i >= 0;){
-// ((TypeDeclaration)computedUnit.types.get(i)).parseMethod(parser, computedUnit);
-// }
-// }
+ String testName = "<test01>";
+ checkParsePHP(
+ s.toCharArray(),
+ expectedSyntaxErrorDiagnosis);
+// testName);
+ }
+ public void test02() {
+ String s =
+ "class test { \n"+
+ " function f0() \n"+
+ " { \n"+
+ " } \n"+
+ "} \n";
- StringBuffer buffer = new StringBuffer(100);
- if (compilationResult.hasProblems() || compilationResult.hasTasks()) {
- IProblem[] problems = compilationResult.getAllProblems();
- int count = problems.length;
- int problemCount = 0;
- char[] unitSource = compilationResult.compilationUnit.getContents();
- for (int i = 0; i < count; i++) {
- if (problems[i] != null) {
- if (problemCount == 0)
- buffer.append("----------\n");
- problemCount++;
- buffer.append(problemCount + (problems[i].isError() ? ". ERROR" : ". WARNING"));
- buffer.append(" in " + new String(problems[i].getOriginatingFileName()).replace('/', '\\'));
- try {
- buffer.append(((DefaultProblem)problems[i]).errorReportSource(unitSource));
- buffer.append("\n");
- buffer.append(problems[i].getMessage());
- buffer.append("\n");
- } catch (Exception e) {
- StringWriter stringWriter = new StringWriter();
- e.printStackTrace(new PrintWriter(stringWriter));
- buffer.append(stringWriter.getBuffer());
- }
- buffer.append("----------\n");
- }
- }
- }
- String computedSyntaxErrorDiagnosis = buffer.toString();
- if(!expectedSyntaxErrorDiagnosis.equals(computedSyntaxErrorDiagnosis)) {
- System.out.println(Util.displayString(computedSyntaxErrorDiagnosis));
- }
- assertEquals(
- "Invalid syntax error diagnosis" + testName,
- expectedSyntaxErrorDiagnosis,
- computedSyntaxErrorDiagnosis);
+ String expectedSyntaxErrorDiagnosis =
+ "";
+
+ String testName = "<test02>";
+ checkParsePHP(
+ s.toCharArray(),
+ expectedSyntaxErrorDiagnosis);
+// testName);
}
-
- public void test01() {
+ public void test03() {
+ String s =
+ "$chars = ( isset($HTTP_GET_VARS['chars']) ) ? intval($HTTP_GET_VARS['chars']) : 200;";
+ String expectedSyntaxErrorDiagnosis =
+ "";
+
+ checkParsePHP(
+ s.toCharArray(),
+ expectedSyntaxErrorDiagnosis);
+// testName);
+}
+ public void test96() {
+ String s = "$str = <<<EOD\n" + "Example of string\n"
+ + "spanning multiple lines\n" + "using heredoc syntax.\n" + "EOD;\n"
+ + "\n" + "/* More complex example, with variables. */\n"
+ + "class foo\n" + "{\n" + " var $foo;\n" + " var $bar;\n" + "\n"
+ + " function foo()\n" + " {\n" + " $this->foo = 'Foo';\n"
+ + " $this->bar = array('Bar1', 'Bar2', 'Bar3');\n" + " }\n"
+ + "}\n" + "\n" + "$foo = new foo();\n" + "$name = 'MyName';\n" + "\n"
+ + "echo <<<EOT\n"
+ + "My name is \"$name\". I am printing some $foo->foo.\n"
+ + "Now, I am printing some {$foo->bar[1]}.\n"
+ + "This should print a capital 'A': \\x41\n" + "EOT;\n";
+ String expectedSyntaxErrorDiagnosis =
+ "";
+
+ checkParsePHP(
+ s.toCharArray(),
+ expectedSyntaxErrorDiagnosis);
+// testName);
+ }
+ public void test97() {
String s =
- "class class { \n"+
+ "class momo { \n"+
" function &fetchRow($result, $fetchmode = DB_FETCHMODE_DEFAULT, $rownum=null) \n"+
" { \n"+
" } \n"+
"} \n";
String expectedSyntaxErrorDiagnosis =
- "----------\n" +
- "1. ERROR in <test1> (at line 1)\n" +
- " class class { \n" +
- " ^^^^^\n" +
- "Parse error \"Don\'t use keyword for class declaration [class].\"\n" +
- "----------\n" +
- "2. ERROR in <test1> (at line 1)\n" +
- " class class { \n" +
- " ^\n" +
- "Parse error \"Class name expected after keyword \'class\'.\"\n" +
- "----------\n";
+ "";
- String testName = "<test1>";
- checkParse(
+ checkParsePHP(
s.toCharArray(),
- expectedSyntaxErrorDiagnosis,
- testName);
+ expectedSyntaxErrorDiagnosis);
+// testName);
}
-
- public void test02() {
+ public void test98() {
String s =
+ "return(array());"+
"if(!$result = mysql_query($sql)) return(array());\n";
String expectedSyntaxErrorDiagnosis =
"";
- String testName = "<test2>";
- checkParse(
+ checkParsePHP(
s.toCharArray(),
- expectedSyntaxErrorDiagnosis,
- testName);
+ expectedSyntaxErrorDiagnosis);
+// testName);
}
- public void test03() {
+ public void test99() {
String s =
"class test { \n"+
" murks; \n"+
"} \n";
String expectedSyntaxErrorDiagnosis =
- "";
+ "----------\n" +
+ "1. ERROR in (at line 1)\n" +
+ " murks; \n" +
+ " ^^^^^\n" +
+ "Parser error \"\'public\' \'private\' or \'protected\' modifier expected for field declarations.\"\n" +
+ "----------\n" +
+ "2. ERROR in (at line 1)\n" +
+ " } \n" +
+ " ^\n" +
+ "Parser error \"Too many closing \'}\'; end-of-file not reached.\"\n" +
+ "----------\n";
- String testName = "<test3>";
- checkParse(
+ checkParsePHP(
s.toCharArray(),
- expectedSyntaxErrorDiagnosis,
- testName);
+ expectedSyntaxErrorDiagnosis);
+// testName);
}
}