|
|
|
<?php
|
|
|
|
|
|
|
|
namespace yii\codeception;
|
|
|
|
|
|
|
|
use Yii;
|
|
|
|
use yii\base\Component;
|
|
|
|
use yii\base\InvalidConfigException;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* BasePage is the base class for page classes that represent Web pages to be tested.
|
|
|
|
*
|
|
|
|
* @property string $url the URL to this page
|
|
|
|
*
|
|
|
|
* @author Mark Jebri <mark.github@yandex.ru>
|
|
|
|
* @since 2.0
|
|
|
|
*/
|
|
|
|
abstract class BasePage extends Component
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var string|array the route (controller ID and action ID, e.g. `site/about`) to this page.
|
|
|
|
* Use array to represent a route with GET parameters. The first element of the array represents
|
|
|
|
* the route and the rest of the name-value pairs are treated as GET parameters, e.g. `array('site/page', 'name' => 'about')`.
|
|
|
|
*/
|
|
|
|
public $route;
|
|
|
|
/**
|
|
|
|
* @var \Codeception\AbstractGuy the testing guy object
|
|
|
|
*/
|
|
|
|
protected $guy;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor.
|
|
|
|
* @param \Codeception\AbstractGuy the testing guy object
|
|
|
|
*/
|
|
|
|
public function __construct($I)
|
|
|
|
{
|
|
|
|
$this->guy = $I;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the URL to this page.
|
|
|
|
* The URL will be returned by calling the URL manager of the application
|
|
|
|
* with [[route]] and the provided parameters.
|
|
|
|
* @param array $params the GET parameters for creating the URL
|
|
|
|
* @return string the URL to this page
|
|
|
|
* @throws InvalidConfigException if [[route]] is not set or invalid
|
|
|
|
*/
|
|
|
|
public function getUrl($params = [])
|
|
|
|
{
|
|
|
|
if (is_string($this->route)) {
|
|
|
|
return Yii::$app->getUrlManager()->createUrl($this->route, $params);
|
|
|
|
} elseif (is_array($this->route) && isset($this->route[0])) {
|
|
|
|
$route = $this->route[0];
|
|
|
|
$ps = $this->route;
|
|
|
|
unset($this->route[0]);
|
|
|
|
return Yii::$app->getUrlManager()->createUrl($route, array_merge($ps, $params));
|
|
|
|
} else {
|
|
|
|
throw new InvalidConfigException('The "route" property must be set.');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a page instance and sets the test guy to use [[url]].
|
|
|
|
* @param \Codeception\AbstractGuy $I the test guy instance
|
|
|
|
* @param array $params the GET parameters to be used to generate [[url]]
|
|
|
|
* @return static the page instance
|
|
|
|
*/
|
|
|
|
public static function openBy($I, $params = [])
|
|
|
|
{
|
|
|
|
$page = new static($I);
|
|
|
|
$I->amOnPage($page->getUrl($params));
|
|
|
|
return $page;
|
|
|
|
}
|
|
|
|
}
|