mirror of
				https://github.com/yiisoft/yii2.git
				synced 2025-11-04 14:46:19 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/**
 | 
						|
 * @link http://www.yiiframework.com/
 | 
						|
 * @copyright Copyright (c) 2008 Yii Software LLC
 | 
						|
 * @license http://www.yiiframework.com/license/
 | 
						|
 */
 | 
						|
 | 
						|
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. This property is read-only.
 | 
						|
 *
 | 
						|
 * @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\Actor the testing guy object
 | 
						|
     */
 | 
						|
    protected $actor;
 | 
						|
 | 
						|
 | 
						|
    /**
 | 
						|
     * Constructor.
 | 
						|
     *
 | 
						|
     * @param \Codeception\Actor $I the testing guy object
 | 
						|
     */
 | 
						|
    public function __construct($I)
 | 
						|
    {
 | 
						|
        $this->actor = $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)) {
 | 
						|
            $params[0] = $this->route;
 | 
						|
 | 
						|
            return Yii::$app->getUrlManager()->createUrl($params);
 | 
						|
        } elseif (is_array($this->route) && isset($this->route[0])) {
 | 
						|
            return Yii::$app->getUrlManager()->createUrl(array_merge($this->route, $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\Actor $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;
 | 
						|
    }
 | 
						|
}
 |