2019-11-04 15:57:28 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* AMR test controller
|
|
|
|
*
|
|
|
|
* @package plugin
|
|
|
|
* @subpackage Mod Rewrite
|
|
|
|
* @version SVN Revision $Rev: 128 $
|
|
|
|
* @id $Id: class.modrewrite_contenttest_controller.php 128 2019-07-03 11:58:28Z oldperl $:
|
|
|
|
* @author Murat Purc <murat@purc.de>
|
|
|
|
* @copyright four for business AG <www.4fb.de>
|
|
|
|
* @license http://www.contenido.org/license/LIZENZ.txt
|
|
|
|
* @link http://www.4fb.de
|
|
|
|
* @link http://www.contenido.org
|
|
|
|
*/
|
|
|
|
|
|
|
|
if (!defined('CON_FRAMEWORK')) {
|
|
|
|
die('Illegal call');
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Content controller to run tests.
|
|
|
|
*
|
|
|
|
* @author Murat Purc <murat@purc.de>
|
|
|
|
* @package plugin
|
|
|
|
* @subpackage Mod Rewrite
|
|
|
|
*/
|
|
|
|
class ModRewrite_ContentTestController extends ModRewrite_ControllerAbstract {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Number of max items to process
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
protected $_iMaxItems = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initializer method, sets some view variables
|
|
|
|
*/
|
|
|
|
public function init() {
|
|
|
|
$this->_oView->content = '';
|
|
|
|
$this->_oView->form_idart_chk = ($this->_getParam('idart')) ? ' checked="checked"' : '';
|
|
|
|
$this->_oView->form_idcat_chk = ($this->_getParam('idcat')) ? ' checked="checked"' : '';
|
|
|
|
$this->_oView->form_idcatart_chk = ($this->_getParam('idcatart')) ? ' checked="checked"' : '';
|
|
|
|
$this->_oView->form_idartlang_chk = ($this->_getParam('idartlang')) ? ' checked="checked"' : '';
|
|
|
|
$this->_oView->form_maxitems = (int) $this->_getParam('maxitems', 200);
|
|
|
|
$this->_iMaxItems = $this->_oView->form_maxitems;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Index action
|
|
|
|
*/
|
|
|
|
public function indexAction() {
|
|
|
|
$this->_oView->content = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test action
|
|
|
|
*/
|
|
|
|
public function testAction() {
|
|
|
|
$this->_oView->content = '';
|
|
|
|
|
|
|
|
// Array for testcases
|
2023-07-19 16:59:11 +00:00
|
|
|
$aTests = [];
|
2019-11-04 15:57:28 +00:00
|
|
|
|
|
|
|
// Instance of mr test
|
2023-07-19 16:59:11 +00:00
|
|
|
$modRewriteTest = new ModRewriteTest($this->_iMaxItems);
|
2019-11-04 15:57:28 +00:00
|
|
|
|
|
|
|
$startTime = getmicrotime();
|
|
|
|
|
|
|
|
// Fetch complete CONTENIDO page structure
|
2023-07-19 16:59:11 +00:00
|
|
|
$aStruct = $modRewriteTest->fetchFullStructure();
|
2022-03-11 09:04:26 +00:00
|
|
|
ModRewriteDebugger::add($aStruct, 'ModRewrite_ContentTestController::testAction() $aStruct');
|
2019-11-04 15:57:28 +00:00
|
|
|
|
|
|
|
// Loop through the structure and compose testcases
|
2023-07-19 16:59:11 +00:00
|
|
|
foreach ($aStruct as $aCat) {
|
2019-11-04 15:57:28 +00:00
|
|
|
// category
|
2023-07-19 16:59:11 +00:00
|
|
|
$aTests[] = ['url' => $modRewriteTest->composeURL($aCat, 'c'), 'level' => $aCat['level'], 'name' => $aCat['name']];
|
2019-11-04 15:57:28 +00:00
|
|
|
|
2023-07-19 16:59:11 +00:00
|
|
|
foreach ($aCat['articles'] as $aArt) {
|
2019-11-04 15:57:28 +00:00
|
|
|
// articles
|
2023-07-19 16:59:11 +00:00
|
|
|
$aTests[] = ['url' => $modRewriteTest->composeURL($aArt, 'a'), 'level' => $aCat['level'], 'name' => $aCat['name'] . ' :: ' . $aArt['title']];
|
2019-11-04 15:57:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// compose content
|
|
|
|
$this->_oView->content = '<pre>';
|
|
|
|
|
|
|
|
$oMRUrlStack = ModRewriteUrlStack::getInstance();
|
|
|
|
|
|
|
|
// first loop to add urls to mr url stack
|
2023-07-19 16:59:11 +00:00
|
|
|
foreach ($aTests as $v) {
|
2019-11-04 15:57:28 +00:00
|
|
|
$oMRUrlStack->add($v['url']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$successCounter = 0;
|
|
|
|
$failCounter = 0;
|
|
|
|
|
|
|
|
// second loop to do the rest
|
2023-07-19 16:59:11 +00:00
|
|
|
foreach ($aTests as $aTest) {
|
|
|
|
$url = mr_buildNewUrl($aTest['url']);
|
|
|
|
$arr = $modRewriteTest->resolveUrl($url);
|
2019-11-04 15:57:28 +00:00
|
|
|
$error = '';
|
2023-07-19 16:59:11 +00:00
|
|
|
$resUrl = $modRewriteTest->getResolvedUrl();
|
2019-11-04 15:57:28 +00:00
|
|
|
$color = 'green';
|
|
|
|
|
|
|
|
if ($url !== $resUrl) {
|
2023-07-19 16:59:11 +00:00
|
|
|
if ($modRewriteTest->getRoutingFoundState()) {
|
2019-11-04 15:57:28 +00:00
|
|
|
$successCounter++;
|
|
|
|
$resUrl = 'route to -> ' . $resUrl;
|
|
|
|
} else {
|
|
|
|
$color = 'red';
|
|
|
|
$failCounter++;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$successCounter++;
|
|
|
|
}
|
|
|
|
|
|
|
|
// @todo: translate
|
|
|
|
if (isset($arr['error'])) {
|
|
|
|
switch ($arr['error']) {
|
|
|
|
case ModRewriteController::ERROR_CLIENT:
|
|
|
|
$error = 'client';
|
|
|
|
break;
|
|
|
|
case ModRewriteController::ERROR_LANGUAGE:
|
|
|
|
$error = 'language';
|
|
|
|
break;
|
|
|
|
case ModRewriteController::ERROR_CATEGORY:
|
|
|
|
$error = 'category';
|
|
|
|
break;
|
|
|
|
case ModRewriteController::ERROR_ARTICLE:
|
|
|
|
$error = 'article';
|
|
|
|
break;
|
|
|
|
case ModRewriteController::ERROR_POST_VALIDATION:
|
|
|
|
$error = 'validation';
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-19 16:59:11 +00:00
|
|
|
$pref = str_repeat(' ', $aTest['level']);
|
2019-11-04 15:57:28 +00:00
|
|
|
|
|
|
|
// render resolve information for current item
|
|
|
|
$itemTpl = $this->_oView->lng_result_item_tpl;
|
|
|
|
$itemTpl = str_replace('{pref}', $pref, $itemTpl);
|
2023-07-19 16:59:11 +00:00
|
|
|
$itemTpl = str_replace('{name}', $aTest['name'], $itemTpl);
|
|
|
|
$itemTpl = str_replace('{url_in}', $aTest['url'], $itemTpl);
|
2019-11-04 15:57:28 +00:00
|
|
|
$itemTpl = str_replace('{url_out}', $url, $itemTpl);
|
|
|
|
$itemTpl = str_replace('{color}', $color, $itemTpl);
|
|
|
|
$itemTpl = str_replace('{url_res}', $resUrl, $itemTpl);
|
|
|
|
$itemTpl = str_replace('{err}', $error, $itemTpl);
|
2023-07-19 16:59:11 +00:00
|
|
|
$itemTpl = str_replace('{data}', $modRewriteTest->getReadableResolvedData($arr), $itemTpl);
|
2019-11-04 15:57:28 +00:00
|
|
|
|
|
|
|
$this->_oView->content .= "\n" . $itemTpl . "\n";
|
|
|
|
}
|
|
|
|
$this->_oView->content .= '</pre>';
|
|
|
|
|
|
|
|
$totalTime = sprintf('%.4f', (getmicrotime() - $startTime));
|
|
|
|
|
|
|
|
// render information about current test
|
|
|
|
$msg = $this->_oView->lng_result_message_tpl;
|
|
|
|
$msg = str_replace('{time}', $totalTime, $msg);
|
|
|
|
$msg = str_replace('{num_urls}', ($successCounter + $failCounter), $msg);
|
|
|
|
$msg = str_replace('{num_success}', $successCounter, $msg);
|
|
|
|
$msg = str_replace('{num_fail}', $failCounter, $msg);
|
|
|
|
|
|
|
|
$this->_oView->content = $msg . $this->_oView->content;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|