1

背景
我正在为 TeraWURFL 编写一个新的数据库连接器文件,它将使用 PDO 扩展名。有关这方面的更多详细信息,请查看

详细信息
我添加了一个新的数据库连接器 -TeraWurflDatabase_MySQL5_Mine.php并在配置文件中定义了相同的 - TeraWurflConfig.php(TeraWURFL 已经有许多连接器文件,配置文件中的值决定使用哪个连接器) -

public static $DB_CONNECTOR = "MySQL5_Mine";

然后我编写了一个测试脚本来对新TeraWurflDatabase_MySQL5_Mine.php类文件的所有功能进行单元测试,以确保它们在更改后返回相同的值。我在测试脚本中遇到问题。

一切正常,但内部TeraWurflDatabase_MySQL5_Mine.php调用的一个函数出了点问题rebuildCacheTable()。当我从我的测试脚本调用这个函数时,控制不会在该函数内的 return 语句之后返回到我的测试脚本。-

测试脚本中的代码test_connector.php-

/*file inclusiong start*/
require_once '/var/cake_1.2.0.6311-beta/app/webroot/Tera-Wurfl_PDO/TeraWurfl.php';
    require_once '/var/cake_1.2.0.6311-beta/app/webroot/Tera-Wurfl_PDO/TeraWurflConfig.php';

    require_once '/var/cake_1.2.0.6311-beta/app/webroot/Tera-Wurfl_PDO/DatabaseConnectors/TeraWurflDatabase.php'; //this file is same on both setups
    require_once '/var/cake_1.2.0.6311-beta/app/webroot/Tera-Wurfl_PDO/TeraWurflLoader.php';
    require_once '/var/cake_1.2.0.6311-beta/app/webroot/Tera-Wurfl_PDO/UserAgentFactory.php';
    require_once '/var/cake_1.2.0.6311-beta/app/webroot/Tera-Wurfl_PDO/UserAgentUtils.php';
    require_once '/var/cake_1.2.0.6311-beta/app/webroot/Tera-Wurfl_PDO/WurflConstants.php';
    require_once '/var/cake_1.2.0.6311-beta/app/webroot/Tera-Wurfl_PDO/WurflSupport.php';
    require_once '/var/cake_1.2.0.6311-beta/app/webroot/Tera-Wurfl_PDO/UserAgentMatchers/UserAgentMatcher.php';

    require_once '/var/cake_1.2.0.6311-beta/app/webroot/Tera-Wurfl_PDO/DatabaseConnectors/TeraWurflDatabase_MySQL5_Mine.php';
/*file inclusiong end*/


    $wurflDbPdoObj = new TeraWurflDatabase_MySQL5_Mine();
    $wurflDbPdoObj->connect();
    $dbObj = $wurflDbPdoObj;
    echo "before call";
    var_dump($dbObj->rebuildCacheTable());
    echo "after call"; //this does not execute if new TeraWurfl() object is initiated below

和里面的代码TeraWurflDatabase_MySQL5_Mine-

class TeraWurflDatabase_MySQL5_Mine extends TeraWurflDatabase{
    ...
    ...

    public function rebuildCacheTable(){
       $rebuilder = new TeraWurfl(); //if this object is initiated, return does not happen properly
       return true; //this does not return properly. 

   }
}

到目前为止我的调试

我验证了发起的对象$rebuilder = new TeraWurfl();是正确的对象。

我可以缩小到这一点,如果$rebuilder = new TeraWurfl();里面的线TeraWurflDatabase_MySQL5_Mine被移除,return 可以正常工作。

此外,如果我调用现有连接器类的相同函数TeraWurflDatabase_MySQL5(我包含TeraWurflDatabase_MySQL5.php而不是TeraWurflDatabase_MySQL5_Mine.php在文件包含部分和 make 中public static $DB_CONNECTOR = "MySQL5";),也不会有这样的问题 -

 $wurflDbPdoObj = new TeraWurflDatabase_MySQL5();
 $wurflDbPdoObj->connect();
 $dbObj = $wurflDbPdoObj;
 echo "before call";
 var_dump($dbObj->rebuildCacheTable());
 echo "after call"; //works

我还比较了在这两种情况下(新的和现有的)var_dump()创建的对象的值。那里没发现问题。$rebuilder = new TeraWurfl();TeraWurflDatabase_MySQL5_mine.phpTeraWurflDatabase_MySQL5.php

我不知道我的代码有什么问题。任何的想法??

更新
进一步发现问题出在TeraWurfl.php类的构造函数内部。构造函数再次启动数据库连接器类的对象——

public function __construct()
{
    ...
    $dbconnector = 'TeraWurflDatabase_'.TeraWurflConfig::$DB_CONNECTOR; //return fails if this object is initiated
    if($this->db === false) $this->db = new $dbconnector;
    ...
}

var_dump()与现有的数据库连接器案例相比,没有错误/警告出现并且看起来很好。该数据库连接器类的对象也已启动。

更新 #2 - 分析输出我按照http://kpayne.me/2012/02/04/use-register_tick_function-to-profile-your-code/
中提到的步骤设置代码分析,稍作修改也可以显示输出中的类名,这是输出 -

对测试脚本进行分析TeraWurflDatabase_MySQL5_Mine-

Array
(
    [TeraWurfl ->__construct] => Array
        (
            [time] => 9.0599060058594E-5
            [calls] => 8
        )

    [TeraWurflDatabase_MySQL5_Mine ->__construct] => Array
        (
            [time] => 4.3630599975586E-5
            [calls] => 4
        )

    [TeraWurflDatabase_MySQL5_Mine ->connect] => Array
        (
            [time] => 0.00010228157043457
            [calls] => 6
        )

    [TeraWurflDatabase_MySQL5_Mine ->rebuildCacheTable] => Array
        (
            [time] => 7.8678131103516E-6
            [calls] => 1
        )

    [show_profile] => Array
        (
            [time] => 1.7881393432617E-5
            [calls] => 1
        )

)

但是对于现有的类TeraWurflDatabase_MySQL5,我并没有得到函数调用的细节,这又奇怪了——

Array
(
    [show_profile] => Array
        (
            [time] => 0.00024199485778809
            [calls] => 1
        )

)
4

1 回答 1

1

在这种情况下,即使不xdebug使用以下命令,您也可以调试流程:

declare(ticks=1);
register_tick_function(function(){
    $debug = debug_backtrace();
    echo "Running on line " . $debug[0]['line'] . " in file " . $debug[0]['file'] . "\n"; 
});

编辑: 实际上,我的例子很糟糕,所以我只留下了重要的部分。

于 2012-06-19T08:33:43.187 回答