mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-25 21:56:32 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			172 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
| *
 | |
| * @package testing
 | |
| * @copyright (c) 2011 phpBB Group
 | |
| * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
 | |
| *
 | |
| */
 | |
| 
 | |
| require_once dirname(__FILE__) . '/../mock/session_testable.php';
 | |
| 
 | |
| /**
 | |
| * This class exists to setup an instance of phpbb's session class for testing.
 | |
| *
 | |
| * The session class has rather complex dependencies, so in order to make its
 | |
| * tests more * understandable and to make its dependencies more visible this
 | |
| * factory class sets up all the necessary global state & variable contents.
 | |
| */
 | |
| class phpbb_session_testable_factory
 | |
| {
 | |
| 	protected $config_data;
 | |
| 	protected $cache_data;
 | |
| 	protected $cookies;
 | |
| 
 | |
| 	protected $config;
 | |
| 	protected $cache;
 | |
| 
 | |
| 	/**
 | |
| 	* Initialises the factory with a set of default config and cache values.
 | |
| 	*/
 | |
| 	public function __construct()
 | |
| 	{
 | |
| 		// default configuration values
 | |
| 		$this->config_data = array(
 | |
| 			'allow_autologin' => false,
 | |
| 			'auth_method' => 'db',
 | |
| 			'forwarded_for_check' => true,
 | |
| 			'active_sessions' => 0, // disable
 | |
| 			'rand_seed' => 'foo',
 | |
| 			'rand_seed_last_update' => 0,
 | |
| 			'max_autologin_time' => 0,
 | |
| 			'session_length' => 100,
 | |
| 			'form_token_lifetime' => 100,
 | |
| 			'cookie_name' => '',
 | |
| 			'limit_load' => 0,
 | |
| 			'limit_search_load' => 0,
 | |
| 			'ip_check' => 3,
 | |
| 			'browser_check' => 1,
 | |
| 		);
 | |
| 
 | |
| 		$this->cache_data = array(
 | |
| 			'_bots' => array(),
 | |
| 		);
 | |
| 
 | |
| 		$this->cookies = array();
 | |
| 
 | |
| 		$this->server_data = $_SERVER;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Retrieve the configured session class instance
 | |
| 	*
 | |
| 	* @param dbal $dbal The database connection to use for session data
 | |
| 	* @return phpbb_mock_session_testable A session instance
 | |
| 	*/
 | |
| 	public function get_session(dbal $dbal)
 | |
| 	{
 | |
| 		// set up all the global variables used by session
 | |
| 		global $SID, $_SID, $db, $config, $cache;
 | |
| 
 | |
| 		$config = $this->config = $this->get_config_data();
 | |
| 		$db = $dbal;
 | |
| 
 | |
| 		$cache = $this->cache = new phpbb_mock_cache($this->get_cache_data());
 | |
| 		$SID = $_SID = null;
 | |
| 
 | |
| 		$_COOKIE = $this->cookies;
 | |
| 		$_SERVER = $this->server_data;
 | |
| 
 | |
| 		$session = new phpbb_mock_session_testable;
 | |
| 		return $session;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Set the cookies which should be present in the request data.
 | |
| 	*
 | |
| 	* @param array $cookies The cookie data, structured like $_COOKIE contents.
 | |
| 	*/
 | |
| 	public function set_cookies(array $cookies)
 | |
| 	{
 | |
| 		$this->cookies = $cookies;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Check if the cache used for the generated session contains correct data.
 | |
| 	*
 | |
| 	* @param PHPUnit_Framework_Assert $test The test case to call assert methods
 | |
| 	*                                       on
 | |
| 	*/
 | |
| 	public function check(PHPUnit_Framework_Assert $test)
 | |
| 	{
 | |
| 		$this->cache->check($test, $this->get_cache_data());
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Merge config data with the current config data to be supplied to session.
 | |
| 	*
 | |
| 	* New values overwrite new ones.
 | |
| 	*
 | |
| 	* @param array $config_data The config data to merge with previous data
 | |
| 	*/
 | |
| 	public function merge_config_data(array $config_data)
 | |
| 	{
 | |
| 		$this->config_data = array_merge($this->config_data, $config_data);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Retrieve the entire config data to be passed to the session.
 | |
| 	*
 | |
| 	* @return array Configuration
 | |
| 	*/
 | |
| 	public function get_config_data()
 | |
| 	{
 | |
| 		return $this->config_data;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Merge the cache contents with more data.
 | |
| 	*
 | |
| 	* New values overwrite old ones.
 | |
| 	*
 | |
| 	* @param array $cache_data The additional cache data
 | |
| 	*/
 | |
| 	public function merge_cache_data(array $cache_data)
 | |
| 	{
 | |
| 		$this->cache_data = array_merge($this->cache_data, $cache_data);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Retrieve the entire cache data to be passed to the session.
 | |
| 	*
 | |
| 	* @return array Cache contents
 | |
| 	*/
 | |
| 	public function get_cache_data()
 | |
| 	{
 | |
| 		return $this->cache_data;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Merge the current server info ($_SERVER) with more data.
 | |
| 	*
 | |
| 	* New values overwrite old ones.
 | |
| 	*
 | |
| 	* @param array $server_data The additional server variables
 | |
| 	*/
 | |
| 	public function merge_server_data($server_data)
 | |
| 	{
 | |
| 		return $this->server_data = array_merge($this->server_data, $server_data);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Retrieve all server variables to be passed to the session.
 | |
| 	*
 | |
| 	* @return array Server variables
 | |
| 	*/
 | |
| 	public function get_server_data()
 | |
| 	{
 | |
| 		return $this->server_data;
 | |
| 	}
 | |
| }
 | |
| 
 |