A lot of changes
[phpeclipse.git] / net.sourceforge.phpeclipse / src / test / PHPParserTestCase2.java
index f890b38..143f9a9 100644 (file)
@@ -8,22 +8,20 @@ package test;
  http://www.eclipse.org/legal/cpl-v10.html
  **********************************************************************/
 
+
+import org.eclipse.core.runtime.CoreException;
 import junit.framework.TestCase;
-import test.PHPParser2;
-import test.ParseException;
 
 import java.io.CharArrayReader;
-import java.io.InputStream;
+import java.io.File;
 
-import net.sourceforge.phpeclipse.phpeditor.phpparser.PHPParser;
-import org.eclipse.core.runtime.CoreException;
 
 /**
  *  Tests the php parser
  */
 public class PHPParserTestCase2 extends TestCase {
 
-  PHPParser2 phpparser;
+  PHPParser parser;
 
   public PHPParserTestCase2(String name) {
     super(name);
@@ -33,32 +31,52 @@ public class PHPParserTestCase2 extends TestCase {
    *  Test the PHP Parser with different PHP snippets
    */
   public void testPHPParser() {
-    checkPHP("$b = $c;");
-    checkPHP("$b = ($c);");
-    checkPHP("$b = ($b) ? $a : $c;");
-    checkPHP("$b = $b.$a && $f.'a' || 'n '.$b;");
-    checkPHP("$toto = 0;");
-    checkPHP("$toto = \"tata\";");
-    checkPHP("$toto = 'tata';");
-    checkPHP("$$a = 'toto';");
-    checkPHP("$add = 'a'.$i;");
-    checkPHP("$add = 'a'.$i;$val = $$add;");
-    checkPHP("$a==2;");
-    checkPHP("($a==\"b\") || c($this->x)==\"d\";");
+    //checkHTML(new File("class.adm_gestuser.php"));
+    checkHTML("<?php function f($a,$b) {" +
+             "echo $a; } ?>");
+    checkHTML("<?php ec ho 'coucou'; ?>" +
+              "\n dfgdfgfdfg" +
+              "\n" +
+              "\n" +
+              "<?php" +
+              "\necho ' caca';" +
+              "\n?>" +
+              "dfgdfg" +
+              "\ndsfgdf");
+    checkHTML("<?php echo 'coucou'; ?>" +
+              "\n dfgdfgfdfg" +
+              "\n" +
+              "\n" +
+              "<?php" +
+              "\necho ' caca';" +
+              "\n?>");
+    checkHTML("<html>sdfsdf  <?php phpinfo(); ?>");
+    checkHTML("\n\n\n\n  <?php print \"Hello world\"?> ");
+    checkHTML("<?php phpinfo()?>");
+    checkHTML("<?php phpinfo(); ?> foo <?php phpinfo(); ?>");
+    checkHTML(" <?php //this is a line comment ?>");
+    checkPHP("'caca'");
+    checkPHP("if $cac a) echo 'coucou';");
+    checkPHP("$oka dd = 'a'.$i;$val = $$add;");
+    checkPHP("($a==\"b\") || (c($this->x)==\"d\");");
     checkPHP("(substr($this->file, 0, 2) == \"MM\");");
     checkPHP("(substr($this->file, 0, 2) == \"MM\") || substr($this->file, 0, 2) == \"II\";");
     checkPHP("return (substr($this->file, 0, 2) == \"MM\") || substr($this->file, 0, 2) == \"II\";");
+    checkPHP("$this->highlightfile->linkscripts{$category};");
+    checkPHP("$code = call_user_method($this->highlightfile->linkscripts{$category}, $this->highlightfile, $oldword, $this->output_module);");
     checkPHP("$this->startmap[$startcurrtag]();");
     checkPHP("new $this->startmap[$startcurrtag]();");
     checkPHP("$this->highlightfile = new $this->startmap[$startcurrtag]();");
     checkPHP("echo \"Test\", \"me\";");
     checkPHP("print (\"Test me\");");
-//    checkPHP("$s = <<<HEREDOC \n dskjfhskj\n \n\nHEREDOC;"); invalid
-    checkPHP("$a == 0 ? print (\"true\") : print (\"false\");");
+//    checkPHP("$s = <<<HEREDOC \n dskjfhskj\n \n\nHEREDOC;");
+//    checkPHP("$a == 0 ? print \"true\" : print \"false\";");
     checkPHP("if(!$result = mysql_query($sql)) return(array());");
     checkPHP("class test { function &fetchRow($result, $fetchmode = DB_FETCHMODE_DEFAULT, $rownum=null) \n{ \n } \n }");
+    checkPHP("call_user_method_array($function_name[1], ${$objectname}, $arguments);");
     checkPHP("@$connect_function($dbhost, $user, $pw);");
     checkPHP("$conn = @$connect_function($dbhost, $user, $pw);");
+    checkPHP("global ${$objectname}; ");
     checkPHP("class DB_mssql extends DB_common { var $connection; var $phptype, $dbsyntax; }  ");
     checkPHP("unset($this->blockvariables[$block][$varname]);");
     checkPHP("new IT_Error(\"The block '$block' was not found in the template.\", __FILE__, __LINE__);");
@@ -75,6 +93,8 @@ public class PHPParserTestCase2 extends TestCase {
     checkPHP("if (isset($test)) { } elseif (isset($lang)) { }");
     checkPHP("require_once(\"mainfile.php\");  ");
     checkPHP("if (eregi(\"footer.php\",$PHP_SELF)) {\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "}\n");
+    checkPHP("while (eregi(\"footer.php\",$PHP_SELF)) {\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "}\n");
+    checkPHP("while (eregi(\"footer.php\",$PHP_SELF)) :\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "endwhile;\n");
     checkPHP("$tipath = \"images/topics/\";");
     checkPHP("$reasons = array(\"1\", \"2\",\"test\");");
     checkPHP("if ($home == 1) { message_box(); blocks(Center);}");
@@ -89,47 +109,67 @@ public class PHPParserTestCase2 extends TestCase {
     checkPHP("$message .= \"\"._THISISAUTOMATED.\"\\n\\n\";");
     checkPHP("if (!empty($pass) AND $pass==$passwd) { }");
     checkPHP("$AllowableHTML = array(\"b\"=>1,\n \"i\"=>1);");
+    checkPHP("if ($term{0}!=$firstChar) {}");
     checkPHP(
-      "echo \"<center><b>\"._NOADMINYET.\"</b></center><br><br>\"\n"
+        "echo \"<center><b>\"._NOADMINYET.\"</b></center><br><br>\"\n"
         + ".\"<form action=\\\"admin.php\\\" method=\\\"post\\\">\"\n"
         + ".\"<tr><td><b>\"._NICKNAME.\":</b></td><td><input type=\\\"text\\\" name=\\\"name\\\" size=\\\"30\\\" maxlength=\\\"25\\\"></td></tr>\"\n"
         + ";");
-    checkPHP("/* \n overLib is from Eric Bosrup (http://www.bosrup.com/web/overlib/) \n */");
+    checkPHP("/* \n overLib is from Eric Bosrup (http://www.bosrup.com/web/overlib/) \n */;");
     checkPHP("if ($arrAtchCookie[1]==0 && $IdAtchPostId!=null){  } ");
     checkPHP("$arrAtchCookie[1] -= filesize(realpath($AtchTempDir).\"/\".$xattachlist)/ 1024; ");
-    checkPHP("$ol = new Overlib();");
-    checkPHP("$risultato = mysql_query($sql) or\n    die(mysql_error());");
     checkPHP(
-      "if (!isset($message)){ \n"
+        "if (!isset($message)){ \n"
         + "$message = $myrow[post_text];\n"
         + "$message = eregi_replace(\"\\[addsig]\", \"\\n-----------------\\n\" .    $myrow[user_sig], $message); \n"
         + "$message = str_replace(\"<BR>\", \"\\n\", $message); \n"
         + "$message = str_replace(\"<br>\", \"\\n\", $message); \n } ");
-    checkPHP("while (eregi(\"footer.php\",$PHP_SELF)) {\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "}\n");
-    checkPHP("while (eregi(\"footer.php\",$PHP_SELF)) :\n" + "Header(\"Location: index.php\");\n" + "die();\n" + "endwhile;\n");
-    checkPHP("if ($term{0}!=$firstChar) {}");
-    checkPHP("$this->highlightfile->linkscripts{$category};");
-    checkPHP("$code = call_user_method($this->highlightfile->linkscripts{$category}, $this->highlightfile, $oldword, $this->output_module);");
-    checkPHP("call_user_method_array($function_name[1], ${$objectname}, $arguments);");
-    checkPHP("global ${$objectname};");
     checkPHP("do {$array[] = array(\"$myrow[uid]\" => \"$myrow[uname]\"); } while($myrow = mysql_fetch_array($result));");
+    checkPHP("$ol = new Overlib();");
+    checkPHP("$risultato = mysql_query($sql) or\n    die(mysql_error());");
   }
 
   private void checkPHP(String strEval) {
     try {
       System.out.println("strEval = " + strEval);
-      phpparser.ReInit(new CharArrayReader(strEval.toCharArray()));
-      phpparser.parse();
+      parser.phpParserTester(strEval);
+    } catch (CoreException e) {
+      e.printStackTrace();
     } catch (ParseException e) {
-      System.out.println(strEval);
       e.printStackTrace();
     }
+
+  }
+
+  private void checkHTML(String strEval) {
+    try {
+      System.out.println("strEval = " + strEval);
+      parser.htmlParserTester(strEval);
+    } catch (CoreException e) {
+      e.printStackTrace();
+    } catch (ParseException e) {
+      e.printStackTrace();
+    }
+
+  }
+
+  private void checkHTML(File strEval) {
+    try {
+      System.out.println("strEval = " + strEval.toString());
+      parser.htmlParserTester(strEval);
+    } catch (CoreException e) {
+      e.printStackTrace();
+    } catch (ParseException e) {
+      e.printStackTrace();
+    }
+
   }
 
   /**
    *  The JUnit setup method
    */
   protected void setUp() {
-    phpparser = new PHPParser2(new CharArrayReader("".toCharArray()));
+    parser = (test.PHPParser) PHPParserManager.getParser();
   }
+
 }