微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

所有测试均因PHP致命错误而失败:无法重新声明类

我在使用PHPUnit时遇到了奇怪的行为,无法确定我做错了什么还是测试框架中的错误.这是我的情况:

我的项目有几个类:BsInput,BsEmail,BsHidden,BsNumber. BsEmail,BsHidden和BsNumber扩展了BsInput.所有类都具有单元测试类(用于BsInput的BsInputTest,用于BsEmail的BsEmailTest等).

单独执行的每个单元测试都可以.

现在,如果我尝试在项目中运行所有测试,则会收到错误和消息“ PHP致命错误:无法在第80行的/some/path/to/B.PHP中重新声明B类”.

这是每个文件内容

BsInput.PHP

require_once __DIR__ . "/BsInputControl.PHP";

class BsInput extends BsInputControl {
    ...
}

BsEmail.PHP

require_once __DIR__ . "/BsInput.PHP";

class BsEmail extends BsInput {
    ...
}

BsHidden.PHP

require_once __DIR__ . "/BsInput.PHP";

class BsHidden extends BsInput {
    ...
}

BsNumber.PHP

require_once __DIR__ . "/BsInput.PHP";

class BsNumber extends BsInput {
    ...
}

BsInputTest.PHP

require_once "../colibri/bs/BsInput.PHP";

class BsInputTest extends PHPUnit_Framework_TestCase {
    ...
}

BsEmailTest.PHP

require_once "../colibri/bs/BsEmail.PHP";

class BsEmailTest extends PHPUnit_Framework_TestCase {
    ...
}

BsHiddenTest.PHP

require_once "../colibri/bs/BsHidden.PHP";

class BsHiddenTest extends PHPUnit_Framework_TestCase {
    ...
}

BsNumberTest.PHP

require_once "../colibri/bs/BsNumber.PHP";

class BsNumberTest extends PHPUnit_Framework_TestCase {
    ...
}

现在,让我发疯的最后一件事是:如果我注释掉BsHidden.PHP和BsHiddenTest.PHP中的所有代码,则PHPUnit All Tests的执行在BsNumber和以下类上都可以顺利进行!

有没有人看过类似的东西?有什么线索可以帮助我解决问题?

我尝试了一个丑陋的解决方法:在BsInput.PHP中插入以下代码

var_dump(class_exists('BsInput', FALSE));
if (class_exists('BsInput', FALSE)) { return; }

我得到这个结果:

bool(true)
PHP Fatal error: Cannot redeclare class BsInput in /.../BsInput.PHP on line 87

到目前为止,我已经研究了许多问题,包括上述问题,但到目前为止,我还没有找到任何解决方案.

> PHPUnit loads all classes at once. Causes PHP Fatal error: Cannot redeclare class
> PHPUnit Test Suite – Cannot redeclare class Mocking & Concrete classes
> “Fatal error: Cannot redeclare class” … but the class was not declared

我还尝试将PHPUnit更新到最新版本(4.6),但没有成功.

我的平台是:
Mac OS X 10.10
PHP 5.5.20
PHPUnit 4.6.6
Netbeans 8.0.2(如果有任何相关内容)

有任何线索吗?

在尝试解决此问题后,我终于删除了我的BsHidden.PHP文件,附加的测试文件并完全重新创建了它们(我的意思是我复制/粘贴的内容完全相同)…现在可以正常工作了!这确实让我想到了PHPPHPUnit之间的某个错误.

但是很快肮脏的解决方法似乎是:

>将文件和单元测试文件内容复制粘贴到另一个文件
>删除有问题的文件和单元测试文件(如果有)
>重新创建文件和单元测试文件并粘贴内容

解决方法:

我终于确定了我的问题.似乎至少在我的平台上存在PHP错误.

PHP的手册说(http://php.net/manual/en/function.include-once.php),在不区分大小写的系统上,PHP4中的名称解析不区分大小写,而PHP5处理此类问题.

这是我在平台(Mac OS X 10.10,PHP 5.5)上得到的行为:

假设我有一个文件A.PHP,它定义了一个A类和以下代码

<?PHP
require_once 'A.PHP';
require_once 'a.PHP';
?>

第二个require_once触发“无法重新声明类错误”.因此,在Mac OS X上的PHP5.5中,至少名称解析不区分大小写,但是PHP仍然认为它们是不同的文件.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐