forked from GNUsocial/gnu-social
		
	
		
			
				
	
	
		
			263 lines
		
	
	
		
			7.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			263 lines
		
	
	
		
			7.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Phergie
 | |
|  *
 | |
|  * PHP version 5
 | |
|  *
 | |
|  * LICENSE
 | |
|  *
 | |
|  * This source file is subject to the new BSD license that is bundled
 | |
|  * with this package in the file LICENSE.
 | |
|  * It is also available through the world-wide-web at this URL:
 | |
|  * http://phergie.org/license
 | |
|  *
 | |
|  * @category  Phergie
 | |
|  * @package   Phergie_Tests
 | |
|  * @author    Phergie Development Team <team@phergie.org>
 | |
|  * @copyright 2008-2010 Phergie Development Team (http://phergie.org)
 | |
|  * @license   http://phergie.org/license New BSD License
 | |
|  * @link      http://pear.phergie.org/package/Phergie_Tests
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * Unit test suite for Pherge_Connection.
 | |
|  *
 | |
|  * @category Phergie
 | |
|  * @package  Phergie_Tests
 | |
|  * @author   Phergie Development Team <team@phergie.org>
 | |
|  * @license  http://phergie.org/license New BSD License
 | |
|  * @link     http://pear.phergie.org/package/Phergie_Tests
 | |
|  */
 | |
| class Phergie_ConnectionTest extends PHPUnit_Framework_TestCase
 | |
| {
 | |
|     /**
 | |
|      * Associative array containing an option-to-value mapping
 | |
|      *
 | |
|      * @var array
 | |
|      */
 | |
|     private $options = array(
 | |
|         'host' => 'example.com',
 | |
|         'port' => 4080,
 | |
|         'transport' => 'udp',
 | |
|         'encoding' => 'ASCII',
 | |
|         'nick' => 'MyNick',
 | |
|         'username' => 'MyUsername',
 | |
|         'realname' => 'MyRealName',
 | |
|         'password' => 'MyPassword',
 | |
|     );
 | |
| 
 | |
|     /**
 | |
|      * Data provider for testGetOptionReturnsDefault().
 | |
|      *
 | |
|      * @return array Enumerated array of enumerated arrays each containing a
 | |
|      *               set of parameters for a single call to
 | |
|      *               testGetOptionReturnsDefault()
 | |
|      */
 | |
|     public function dataProviderTestGetOptionReturnsDefault()
 | |
|     {
 | |
|         return array(
 | |
|             array('transport', 'tcp'),
 | |
|             array('encoding', 'ISO-8859-1'),
 | |
|             array('port', 6667),
 | |
|             array('password', null),
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Tests that a default values are used for some options.
 | |
|      *
 | |
|      * @param string $option Name of the option with a default value
 | |
|      * @param mixed  $value  Default value of the option
 | |
|      *
 | |
|      * @return void
 | |
|      * @dataProvider dataProviderTestGetOptionReturnsDefault
 | |
|      */
 | |
|     public function testGetOptionReturnsDefault($option, $value)
 | |
|     {
 | |
|         $connection = new Phergie_Connection;
 | |
|         $this->assertEquals($value, $connection->{'get' . ucfirst($option)}());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Tests that a default encoding is used if one isn't specified.
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testGetEncodingReturnsDefault()
 | |
|     {
 | |
|         $connection = new Phergie_Connection;
 | |
|         $this->assertEquals('ISO-8859-1', $connection->getEncoding());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Tests that options can be set via the constructor.
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testSetOptionsViaConstructor()
 | |
|     {
 | |
|         $connection = new Phergie_Connection($this->options);
 | |
|         foreach ($this->options as $key => $value) {
 | |
|             $this->assertEquals($value, $connection->{'get' . ucfirst($key)}());
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Data provider for testGetHostmaskMissingDataGeneratesException().
 | |
|      *
 | |
|      * @return array Enumerated array of enumerated arrays each containing a
 | |
|      *               set of parameters for a single call to
 | |
|      *               testGetHostmaskMissingDataGeneratesException()
 | |
|      */
 | |
|     public function dataProviderTestGetHostmaskMissingDataGeneratesException()
 | |
|     {
 | |
|         return array(
 | |
|             array(null, $this->options['username'], $this->options['host']),
 | |
|             array($this->options['nick'], null, $this->options['host']),
 | |
|             array($this->options['nick'], $this->options['username'], null),
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Tests that attempting to retrieve a hostmask without option values
 | |
|      * for all of its constituents generates an exception.
 | |
|      *
 | |
|      * @param string $nick     Bot nick
 | |
|      * @param string $username Bot username
 | |
|      * @param string $host     Server hostname
 | |
|      *
 | |
|      * @return void
 | |
|      * @dataProvider dataProviderTestGetHostmaskMissingDataGeneratesException
 | |
|      */
 | |
|     public function testGetHostmaskMissingDataGeneratesException($nick, $username, $host)
 | |
|     {
 | |
|         $options = array(
 | |
|             'nick' => $nick,
 | |
|             'username' => $username,
 | |
|             'host' => $host,
 | |
|         );
 | |
| 
 | |
|         $connection = new Phergie_Connection($options);
 | |
| 
 | |
|         try {
 | |
|             $hostmask = $connection->getHostmask();
 | |
|             $this->fail('Expected exception was not thrown');
 | |
|         } catch (Phergie_Connection_Exception $e) {
 | |
|             return;
 | |
|         } catch (Exception $e) {
 | |
|             $this->fail('Unexpected exception was thrown');
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Tests that attempting to retrieve a hostmask with all required
 | |
|      * options is successful.
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testGetHostmaskWithValidData()
 | |
|     {
 | |
|         $options = array(
 | |
|             'nick' => 'MyNick',
 | |
|             'username' => 'MyUsername',
 | |
|             'host' => 'example.com'
 | |
|         );
 | |
| 
 | |
|         $connection = new Phergie_Connection($options);
 | |
|         $hostmask = $connection->getHostmask();
 | |
|         $this->assertType('Phergie_Hostmask', $hostmask);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Data provider for testGetRequiredOptionsWithoutValuesSet().
 | |
|      *
 | |
|      * @return array Enumerated array of enumerated arrays each containing a
 | |
|      *               set of parameters for a single call to
 | |
|      *               testGetRequiredOptionsWithoutValuesSet()
 | |
|      */
 | |
|     public function dataProviderTestGetRequiredOptionsWithoutValuesSet()
 | |
|     {
 | |
|         return array(
 | |
|             array('host'),
 | |
|             array('nick'),
 | |
|             array('username'),
 | |
|             array('realname'),
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Tests that attempting to retrieve values of required options when no
 | |
|      * values are set results in an exception.
 | |
|      *
 | |
|      * @param string $option Option name
 | |
|      *
 | |
|      * @return void
 | |
|      * @dataProvider dataProviderTestGetRequiredOptionsWithoutValuesSet
 | |
|      */
 | |
|     public function testGetRequiredOptionsWithoutValuesSet($option)
 | |
|     {
 | |
|         try {
 | |
|             $connection = new Phergie_Connection;
 | |
|             $value = $connection->{'get' . ucfirst($option)}();
 | |
|             $this->fail('Expected exception was not thrown');
 | |
|         } catch (Phergie_Connection_Exception $e) {
 | |
|             return;
 | |
|         } catch (Exception $e) {
 | |
|             $this->fail('Unexpected exception was thrown');
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Tests that attempting to set an invalid value for the transport
 | |
|      * results in an exception.
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testSetTransportWithInvalidValue()
 | |
|     {
 | |
|         $connection = new Phergie_Connection;
 | |
|         try {
 | |
|             $connection->setTransport('blah');
 | |
|             $this->fail('Expected exception was not thrown');
 | |
|         } catch (Phergie_Connection_Exception $e) {
 | |
|             return;
 | |
|         } catch (Exception $e) {
 | |
|             $this->fail('Unexpected exception was thrown');
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Tests that attempting to set an invalid value for the encoding
 | |
|      * results in an exception.
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testSetEncodingWithInvalidValue()
 | |
|     {
 | |
|         $connection = new Phergie_Connection;
 | |
|         try {
 | |
|             $connection->setEncoding('blah');
 | |
|             $this->fail('Expected exception was not thrown');
 | |
|         } catch (Phergie_Connection_Exception $e) {
 | |
|             return;
 | |
|         } catch (Exception $e) {
 | |
|             $this->fail('Unexpected exception was thrown');
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Tests that options can be set collectively after the connection is
 | |
|      * instantiated.
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testSetOptions()
 | |
|     {
 | |
|         $connection = new Phergie_Connection;
 | |
|         $connection->setOptions($this->options);
 | |
|         foreach ($this->options as $key => $value) {
 | |
|             $this->assertEquals($value, $connection->{'get' . ucfirst($key)}());
 | |
|         }
 | |
|     }
 | |
| }
 |