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 0f9e6b8..0f3e50e 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 @@ -19,135 +19,114 @@ public class PHPParserTestCase extends AbstractCompilerTest { /** * 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"); + 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 + * 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"); + 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 + * 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" - , + 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"); - + + "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 + * 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"); + 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 + * 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"); + 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 + * 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."); + 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 + * 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"); + 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 */ @@ -159,48 +138,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" + checkPHP("switch ($aItem[ELM_NAME]) {\r\n" + " case \'channel\':\r\n" - + " $this->readChannel($aItem);\r\n" + + " $this->readChannel($aItem);\r\n" + " break;\r\n" - + " case \'item\':\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" + + " break;\r\n" + + " default:\r\n" + + " //printr($aItem);\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" - + " type=\'text/css\'>\n" + "\n" - + "
\n" - + "\n" + "
\n" + + "?>\n" + "\n" - + "\n" + + "ol_path/overlib.css\' \"; ?> \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" + 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" + + " \"\\$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" + 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" + + " \'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 = \' \"$myrow[uname]\"); } while($myrow = mysql_fetch_array($result));"); checkPHP("\"\\\"\";"); checkPHP(" print \"$value\"; \n"); - checkPHP("if ($shape instanceof Rectangle) { \n" + " print \'$shape is a Rectangle\'; \n" + "} "); + checkPHP("if ($shape instanceof Rectangle) { \n" + + " print \'$shape is a Rectangle\'; \n" + "} "); checkPHP("$test=\"values(\'$user\',\'${res[\"name\"]}\' \";"); checkPHP("$this->raiseError(\"The auth mode: $mode isn\'t implemented\");"); checkPHP("\'{$this->_keycolumn[$i]};"); - checkPHP("$this->_reg_objects[$object] =\n" + " array(&$object_impl, $allowed, $smarty_args);"); - checkPHP("echo <<< EOF\n" + "
\n" + "EOF;"); - checkPHP("interface Shape { \n" + " function draw(); \n" + "} \n" + "\n" + "class Rectangle implements Shape { \n" - + " function draw() { \n" + " print \"Drawing a rectangle\"; \n" + " } \n" + "}"); - checkPHP("class MyClass { \n" + " private $priv; \n" + "\n" + " public function getVar() { \n" + checkPHP("$this->_reg_objects[$object] =\n" + + " array(&$object_impl, $allowed, $smarty_args);"); + checkPHP("echo <<< EOF\n" + "
\n" + + "EOF;"); + checkPHP("interface Shape { \n" + " function draw(); \n" + "} \n" + + "\n" + "class Rectangle implements Shape { \n" + + " function draw() { \n" + + " print \"Drawing a rectangle\"; \n" + " } \n" + + "}"); + checkPHP("class MyClass { \n" + " private $priv; \n" + "\n" + + " public function getVar() { \n" + " return $this->priv; \n" + " } \n" + "} "); - checkPHP("class Test { \n" + " function __construct() { \n" + " print \"Test constructor\"; \n" + " } \n" + "}"); - checkPHP("class Test { \n" + " function __destruct() { \n" + " print \"Destroying Test object\"; \n" + " } \n" + checkPHP("class Test { \n" + " function __construct() { \n" + + " print \"Test constructor\"; \n" + " } \n" + "}"); + checkPHP("class Test { \n" + " function __destruct() { \n" + + " print \"Destroying Test object\"; \n" + " } \n" + "}"); - checkPHP("class Test { \n" + " final function doNotOverload() { \n" + " return __CLASS__; \n" + " } \n" + "}"); - checkPHP("final class Test { \n" + "} \n" + "\n" + "class DoNotInherit extends Test { \n" + "}"); - checkPHP("class Test { \n" + " function __clone() { \n" + " print \"Clone test object\"; \n" + " } \n" + "} \n" - + "$test = new Test(); \n" + "clone $test; "); - checkPHP("class Test { \n" + " const SEMICOLON = \";\"; \n" + " const QUESTIONMARK = \"?\"; \n" + "} \n" + checkPHP("class Test { \n" + " final function doNotOverload() { \n" + + " return __CLASS__; \n" + " } \n" + "}"); + checkPHP("final class Test { \n" + "} \n" + "\n" + + "class DoNotInherit extends Test { \n" + "}"); + checkPHP("class Test { \n" + " function __clone() { \n" + + " print \"Clone test object\"; \n" + " } \n" + + "} \n" + "$test = new Test(); \n" + "clone $test; "); + checkPHP("class Test { \n" + " const SEMICOLON = \";\"; \n" + + " const QUESTIONMARK = \"?\"; \n" + "} \n" + "print Test::SEMICOLON; "); - checkPHP("class Singleton { \n" + " static $instance = NULL; \n" + " function getInstance() { \n" - + " if ($this->instance == NULL) { \n" + " $this->instance = new Singleton(); \n" + " } \n" - + " return $this->instance; \n" + " } \n" + "} "); - checkPHP("class Test { \n" + " static function helloWorld() { \n" + " print \"Hello, world\"; \n" + " } \n" - + "} \n" + "Test::helloWorld();"); - checkPHP("abstract class Test { \n" + " function draw() { \n" + " print \"Inside draw()\"; \n" + " } \n" + "} "); - checkPHP("abstract class Test { \n" + " abstract function draw(); \n" + "} "); + checkPHP("class Singleton { \n" + " static $instance = NULL; \n" + + " function getInstance() { \n" + + " if ($this->instance == NULL) { \n" + + " $this->instance = new Singleton(); \n" + + " } \n" + " return $this->instance; \n" + + " } \n" + "} "); + checkPHP("class Test { \n" + " static function helloWorld() { \n" + + " print \"Hello, world\"; \n" + " } \n" + "} \n" + + "Test::helloWorld();"); + checkPHP("abstract class Test { \n" + " function draw() { \n" + + " print \"Inside draw()\"; \n" + " } \n" + "} "); + checkPHP("abstract class Test { \n" + + " abstract function draw(); \n" + "} "); checkPHP("function f1(Test $test) { \n" + "\n" + "}"); checkPHP("$test->m1()->m2(); "); - checkPHP("$test = new IteratorImpl(); \n" + "foreach ($test as $value) { \n" + " print \"$value\"; \n" + "}"); - checkPHP("function __autoload($clazz) { \n" + " include_once($clazz . \"php\"); \n" + "} \n" + "\n" + checkPHP("$test = new IteratorImpl(); \n" + + "foreach ($test as $value) { \n" + " print \"$value\"; \n" + + "}"); + checkPHP("function __autoload($clazz) { \n" + + " include_once($clazz . \"php\"); \n" + "} \n" + "\n" + "$obj = new Test1(); \n" + "$obj2 = new Test2(); "); - checkPHP("class SQLException extends Exception { \n" + " public $problem; \n" + " function __construct($problem) { \n" - + " $this->problem = $problem; \n" + " } \n" + "} \n" + "\n" + "try { \n" - + " throw new SQLException(\"Couldn’t connect to database\"); \n" + "} catch (SQLException $e) { \n" - + " print \"Caught an SQLException with problem $obj->problem\"; \n" + "} catch (Exception $e) { \n" + checkPHP("class SQLException extends Exception { \n" + + " public $problem; \n" + + " function __construct($problem) { \n" + + " $this->problem = $problem; \n" + + " } \n" + + "} \n" + + "\n" + + "try { \n" + + " throw new SQLException(\"Couldn’t connect to database\"); \n" + + "} catch (SQLException $e) { \n" + + " print \"Caught an SQLException with problem $obj->problem\"; \n" + + "} catch (Exception $e) { \n" + " print \"Caught unrecognized exception\"; \n" + "}"); - checkPHP("function my_func(&$arg = null) { \n" + " if ($arg === NULL) { \n" + " print \'$arg is empty\'; \n" - + " } \n" + "} \n" + "my_func();"); - checkPHP("foreach ($array as &$value) { \n" + " if ($value === \"NULL\") { \n" + " $value = NULL; \n" + " } \n" - + "}"); - checkPHP("$testxml = simplexml_load_file(\'test.xml\'); \n" + "foreach ($$testxml->client as $test) { \n" - + " print \"$test->name has account number $test->account_number \"; \n" + "} "); + checkPHP("function my_func(&$arg = null) { \n" + + " if ($arg === NULL) { \n" + + " print \'$arg is empty\'; \n" + " } \n" + "} \n" + + "my_func();"); + checkPHP("foreach ($array as &$value) { \n" + + " if ($value === \"NULL\") { \n" + + " $value = NULL; \n" + " } \n" + "}"); + checkPHP("$testxml = simplexml_load_file(\'test.xml\'); \n" + + "foreach ($$testxml->client as $test) { \n" + + " print \"$test->name has account number $test->account_number \"; \n" + + "} "); checkHTML(" "); - checkHTML("\n" + "test me\n" + ""); + checkHTML("\n" + + "test me\n" + ""); checkHTML(""); checkPHP("function clean_words($mode, &$entry, &$stopword_list, &$synonym_list)\r\n" @@ -281,9 +299,12 @@ public class PHPParserTestCase extends AbstractCompilerTest { 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'] = <<>\n" - + "and appl_sect_deftn_sk = <>\n" + "order by url_ord\n" + "EOS;\n"); + checkPHP("$ebus_sql['sel_url_list'] = <<>\n" + + "and appl_sect_deftn_sk = <>\n" + "order by url_ord\n" + + "EOS;\n"); checkPHP("foreach ($HTTP_GET_VARS as $secvalue) { }"); checkPHP("\"\\[addsig]\""); @@ -321,9 +342,13 @@ public class PHPParserTestCase extends AbstractCompilerTest { 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"); - 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 (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);}"); @@ -344,9 +369,11 @@ public class PHPParserTestCase extends AbstractCompilerTest { 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("if (!isset($message)){ \n" + "$message = $myrow[post_text];\n" + checkPHP("if (!isset($message)){ \n" + + "$message = $myrow[post_text];\n" + "$message = eregi_replace(\"\\[addsig]\", \"\\n-----------------\\n\" . $myrow[user_sig], $message); \n" - + "$message = str_replace(\"
\", \"\\n\", $message); \n" + "$message = str_replace(\"
\", \"\\n\", $message); \n } "); + + "$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 ");