X-Git-Url: http://git.phpeclipse.com diff --git a/net.sourceforge.phpeclipse.tests/src/net/sourceforge/phpeclipse/tests/parser/PHPParserTestCase.java b/net.sourceforge.phpeclipse.tests/src/net/sourceforge/phpeclipse/tests/parser/PHPParserTestCase.java index ff9c420..0f9e6b8 100644 --- a/net.sourceforge.phpeclipse.tests/src/net/sourceforge/phpeclipse/tests/parser/PHPParserTestCase.java +++ b/net.sourceforge.phpeclipse.tests/src/net/sourceforge/phpeclipse/tests/parser/PHPParserTestCase.java @@ -7,22 +7,151 @@ package net.sourceforge.phpeclipse.tests.parser; * distribution, and is available at http://www.eclipse.org/legal/cpl-v10.html ******************************************************************************/ import net.sourceforge.phpdt.core.tests.util.AbstractCompilerTest; -import net.sourceforge.phpdt.internal.compiler.parser.Scanner; /** * Tests the php parser */ public class PHPParserTestCase extends AbstractCompilerTest { - // Parser parser; + public PHPParserTestCase(String name) { super(name); } /** + * Test the PHP Parser with failing PHP snippets + * + */ + public void testPHPParserFailingSyntax() { + checkPHP("i=10;", + "----------\n" + + "1. ERROR in (at line 1)\n" + + " i=10;\n" + + " ^^\n" + + "Parser error \"Assignment operator \'=\' not allowed after identifier \'i\' (use \'define(...)\' to define constants).\"\n" + + "----------\n"); + } + + /** + * Test Interface Extending multiple Interfaces + * + * This is valid PHP5 syntax + * Bug 1431425 + */ + public void testMIInterfaceExtendsInterface() { + // valid PHP5 + checkPHP("interface a {}\n" + + "interface b {}\n" + + "\n" + + "interface c extends a, b\n" + + "{}\n"); + } + + /** + * Test Interface implementing multiple Interfaces + * + * This is invalid PHP5 syntax + * Bug 1431425 + */ + public void testMIInterfaceImplementsInterface() { + // invalid PHP5 + checkPHP("interface a {}\n" + + "interface b {}\n" + + "\n" + + "interface c implements a, b\n" + + "{}\n" + , + "----------\n" + + "1. ERROR in (at line 1)\n" + + " interface c implements a, b\n" + + " ^^^^^^^^^^^\n" + + "Parser error \"'{' expected at start of class body.\"\n" + + "----------\n" + + "2. ERROR in (at line 1)\n" + + " {}\n" + + "\n" + + " ^^\n" + + "Parser error \"Too many closing '}'; end-of-file not reached.\"\n" + + "----------\n"); + + } + + /** + * Test Class Extending multiple Interfaces + * + * This is invalid PHP5 syntax + * Bug 1431425 + */ + public void testMIClassExtendsInterface() { + // invalid PHP5 + checkPHP("interface a {}\n" + + "interface b {}\n" + + "\n" + + "class c extends a, b\n" + + "{}\n" + ,"----------\n" + + "1. ERROR in (at line 1)\n" + + " class c extends a, b\n" + + " ^^\n" + + "Parser error \"No multiple inheritence allowed. Expected token \'implements\' or \'{\'.\"\n" + + "----------\n"); + } + + /** + * Test Class implementing multiple Interfaces + * + * This is valid PHP5 syntax + * Bug 1431425 + */ + public void testMIClassImplementsInterfaces() { + // valid PHP5 + checkPHP("interface a {}\n" + + "interface b {}\n" + + "\n" + + "class c implements a, b\n" + + "{}\n"); + } + + /** + * Test Class Implementing multiple classes + * + * This is invalid PHP5 syntax + * Bug 1431425 + */ + public void testMIClassImplementsClasses() { + // invalid PHP5 + checkPHP("class a {}\n" + + "class b {}\n" + + "\n" + + "class c implements a, b\n" + + "{}\n" + ,"This should fail, but doesn't currently."); + } + + /** + * Test Class Extending multiple Classes + * + * This is invalid PHP5 syntax + * Bug 1431425 + */ + public void testMIClassExtendsClasses() { + // invalid PHP5 + checkPHP("class a {}\n" + + "class b {}\n" + + "\n" + + "class c extends a, b\n" + + "{}\n" + ,"----------\n" + + "1. ERROR in (at line 1)\n" + + " class c extends a, b\n" + + " ^^\n" + + "Parser error \"No multiple inheritence allowed. Expected token \'implements\' or \'{\'.\"\n" + + "----------\n"); + } + + /** * Test the PHP Parser with different PHP snippets */ - public void testPHPParser() { - // checkPHP("i=10;"); // should get an error ! + public void testPHPParserGoodSyntax() { checkPHP("$y=self::$x->huba;"); checkPHP("self::x()->set();"); checkPHP("$test=\"{4IP}/{$include}\";"); @@ -30,34 +159,49 @@ public class PHPParserTestCase extends AbstractCompilerTest { checkPHP("$schema_create .= \" DEFAULT \'$row[Default]\'\";"); checkPHP("$stringVar=\"ein normaler $varText\";"); checkPHP("$stringVar=\'ein normaler $varText\';"); - checkPHP("switch ($aItem[ELM_NAME]) {\r\n" + " case \'channel\':\r\n" - + " $this->readChannel($aItem);\r\n" + " break;\r\n" - + " case \'item\':\r\n" + " $this->readItem($aItem);\r\n" - + " break;\r\n" + " default:\r\n" + " //printr($aItem);\r\n" + checkPHP("switch ($aItem[ELM_NAME]) {\r\n" + + " case \'channel\':\r\n" + + " $this->readChannel($aItem);\r\n" + + " break;\r\n" + + " case \'item\':\r\n" + + " $this->readItem($aItem);\r\n" + + " break;\r\n" + + " default:\r\n" + + " //printr($aItem);\r\n" + " }"); - checkPHP("try {echo $Stream->readAll(); } catch (Exception $e) {\r\n" + " // Swallow exception\r\n" + " }"); + checkPHP("try {echo $Stream->readAll(); } catch (Exception $e) {\r\n" + + " // Swallow exception\r\n" + " }"); - checkHTML("ol_path = $path;\n" - + "\n" + "?>\n" + "\n" + "ol_path/overlib.css\' \"; ?> \n" + "\n" + checkHTML("ol_path = $path;\n" + + "\n" + + "?>\n" + + "\n" + "ol_path/overlib.css\' \"; ?> \n" + + "\n" + " type=\'text/css\'>\n" + "\n" - + "
\n" + "\n" + "
\n" + "\n" - + "\n" + "\n" - + ""); + + "
\n" + + "\n" + "
\n" + + "\n" + + "\n" + + "\n" + + ""); checkPHP("$t = \') {$ya[]=\'.$this->iFunc.\';$xa[]=\'.$this->iXFunc.\';}\';"); checkPHP("$output .= \n" + " \"\\$_smarty_tpl_vars = \\$this->_tpl_vars;\\n\" . \n" + " \"\\$this->_smarty_include(\".$include_file.\", array(\".implode(\',\', (array)$arg_list).\"));\\n\" .\n" - + " \"\\$this->_tpl_vars = \\$_smarty_tpl_vars;\\n\" .\n" + " \"unset(\\$_smarty_tpl_vars);\\n\";"); + + " \"\\$this->_tpl_vars = \\$_smarty_tpl_vars;\\n\" .\n" + + " \"unset(\\$_smarty_tpl_vars);\\n\";"); checkPHP("$test=\"=$post_id#$post_id\""); checkPHP("$comments .= \" \\${$attrname}[\'xmlns\'] = \'{$this->namespaces[$_argtype[\'namespace\']]}\';\\n\";"); checkPHP("$this->_raiseSoapFault(\"method \'{{$this->method_namespace}}$this->methodname\' not defined in service\",\'\',\'\',\'Server\');"); - // checkPHP("$emailer->assign_vars(array(\r\n" + - // " \'U_TOPIC\' => $server_protocol . POST_POST_URL . - // \"=$post_id#$post_id\",\r\n" + - // " \'U_STOP_WATCHING_TOPIC\' => $server_protocol . $server_name . - // $server_port . $script_name . \'&\' . POST_TOPIC_URL . - // \"=$topic_id&unwatch=topic\")\r\n" + - // " );"); + checkPHP("$emailer->assign_vars(array(\r\n" + + " \'U_TOPIC\' => $server_protocol . POST_POST_URL . \"=$post_id#$post_id\",\r\n" + + " \'U_STOP_WATCHING_TOPIC\' => $server_protocol . $server_name . $server_port . $script_name . \'&\' . POST_TOPIC_URL . \"=$topic_id&unwatch=topic\")\r\n" + + " );"); checkPHP("$_compile_data = \'\';"); checkPHP("$output = \'raiseError(\"The auth mode: $mode isn\'t implemented\");"); checkPHP("\'{$this->_keycolumn[$i]};"); checkPHP("$this->_reg_objects[$object] =\n" + " array(&$object_impl, $allowed, $smarty_args);"); @@ -134,7 +278,7 @@ public class PHPParserTestCase extends AbstractCompilerTest { checkPHP("$this->result_field_names[$result_id][] = odbc_field_name($result_id, $i);"); checkPHP("$db->sql_query($sql);"); checkPHP("$val = $$add;"); - // checkPHP("if(!$result = mysql_query($sql)) return(array());"); + checkPHP("if(!$result = mysql_query($sql)) return(array());"); checkPHP("class test { function &fetchRow($result, $fetchmode = DB_FETCHMODE_DEFAULT, $rownum=null) \n{ \n } \n }"); // Bugs item #690938 checkPHP("$ebus_sql['sel_url_list'] = <<blockvariables[$block][$varname]);"); checkPHP("new IT_Error(\"The block '$block' was not found in the template.\", __FILE__, __LINE__);"); checkPHP("for ($i=156, $j=0; $i<512; $i++, $j++) $v_checksum += ord(substr($v_binary_data_last,$j,1));"); @@ -174,8 +317,8 @@ public class PHPParserTestCase extends AbstractCompilerTest { checkPHP("function validateAndParseResponse($code, &$arguments) { }"); checkPHP("$options = Console_Getopt::getopt($argv, \"h?v:e:p:d:\");"); checkPHP("$this->container = new $container_class($container_options);"); - // checkPHP("class Cmd extends PEAR { var $arrSetting = array(); }"); - // checkPHP("class Cmd extends PEAR { var $arrSetting = array(), $i=10; }"); + checkPHP("class Cmd extends PEAR { var $arrSetting = array(); }"); + checkPHP("class Cmd extends PEAR { var $arrSetting = array(), $i=10; }"); 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"); @@ -206,30 +349,11 @@ public class PHPParserTestCase extends AbstractCompilerTest { + "$message = str_replace(\"
\", \"\\n\", $message); \n" + "$message = str_replace(\"
\", \"\\n\", $message); \n } "); checkPHP("$ol = new Overlib();"); checkPHP("$risultato = mysql_query($sql) or\n die(mysql_error());"); - // checkHTML("\n\n\n\n "); - // checkHTML(""); - // checkHTML(""); - // checkHTML(" foo "); - // checkHTML(" "); - // checkHTML(""); - } - - private void checkPHP(String strEval) { - if (Scanner.DEBUG) { - System.out.println("\n------------------------------------"); - System.out.println(strEval); - } - checkParsePHP(strEval.toCharArray(), ""); - // parser.phpParserTester(strEval, 1); + checkHTML("\n\n\n\n "); + checkHTML(""); + checkHTML(""); + checkHTML(" foo "); + checkHTML(" "); + checkHTML(""); } - -// private void checkHTML(String strEval) { -// if (Scanner.DEBUG) { -// System.out.println("\n------------------------------------"); -// System.out.println(strEval); -// } -// checkParseHTML(strEval.toCharArray(), ""); -// // parser.phpParserTester(strEval, 1); -// } - }