/tests/Zend/Feed/PubSubHubbub/PublisherTest.php
https://github.com/intellix/zf2 · PHP · 329 lines · 258 code · 37 blank · 34 comment · 0 complexity · a7ce139dc1cca1fd0a8eea8931fa2eac MD5 · raw file
- <?php
- /**
- * Zend Framework
- *
- * LICENSE
- *
- * This source file is subject to the new BSD license that is bundled
- * with this package in the file LICENSE.txt.
- * It is also available through the world-wide-web at this URL:
- * http://framework.zend.com/license/new-bsd
- * If you did not receive a copy of the license and are unable to
- * obtain it through the world-wide-web, please send an email
- * to license@zend.com so we can send you a copy immediately.
- *
- * @category Zend
- * @package UnitTests
- * @copyright Copyright (c) 2005-2011 Zend Technologies USA Inc. (http://www.zend.com)
- * @license http://framework.zend.com/license/new-bsd New BSD License
- */
- /**
- * @namespace
- */
- namespace ZendTest\Feed\PubSubHubbub;
- use Zend\Http;
- use Zend\Feed\PubSubHubbub;
- /**
- * @category Zend
- * @package Zend_Feed
- * @subpackage UnitTests
- * @group Zend_Feed
- * @group Zend_Feed_Subsubhubbub
- * @copyright Copyright (c) 2005-2011 Zend Technologies USA Inc. (http://www.zend.com)
- * @license http://framework.zend.com/license/new-bsd New BSD License
- */
- class PublisherTest extends \PHPUnit_Framework_TestCase
- {
- /**
- * @var \Zend\Feed\PubSubHubbub\Publisher
- */
- protected $_publisher = null;
- public function setUp()
- {
- $client = new Http\Client;
- PubSubHubbub\PubSubHubbub::setHttpClient($client);
- $this->_publisher = new PubSubHubbub\Publisher;
- }
- public function testAddsHubServerUrl()
- {
- $this->_publisher->addHubUrl('http://www.example.com/hub');
- $this->assertEquals(array('http://www.example.com/hub'), $this->_publisher->getHubUrls());
- }
- public function testAddsHubServerUrlsFromArray()
- {
- $this->_publisher->addHubUrls(array(
- 'http://www.example.com/hub', 'http://www.example.com/hub2'
- ));
- $this->assertEquals(array(
- 'http://www.example.com/hub', 'http://www.example.com/hub2'
- ), $this->_publisher->getHubUrls());
- }
- public function testAddsHubServerUrlsFromArrayUsingSetConfig()
- {
- $this->_publisher->setConfig(array('hubUrls' => array(
- 'http://www.example.com/hub', 'http://www.example.com/hub2'
- )));
- $this->assertEquals(array(
- 'http://www.example.com/hub', 'http://www.example.com/hub2'
- ), $this->_publisher->getHubUrls());
- }
- public function testRemovesHubServerUrl()
- {
- $this->_publisher->addHubUrls(array(
- 'http://www.example.com/hub', 'http://www.example.com/hub2'
- ));
- $this->_publisher->removeHubUrl('http://www.example.com/hub');
- $this->assertEquals(array(
- 1 => 'http://www.example.com/hub2'
- ), $this->_publisher->getHubUrls());
- }
- public function testRetrievesUniqueHubServerUrlsOnly()
- {
- $this->_publisher->addHubUrls(array(
- 'http://www.example.com/hub', 'http://www.example.com/hub2',
- 'http://www.example.com/hub'
- ));
- $this->assertEquals(array(
- 'http://www.example.com/hub', 'http://www.example.com/hub2'
- ), $this->_publisher->getHubUrls());
- }
- public function testThrowsExceptionOnSettingEmptyHubServerUrl()
- {
- try {
- $this->_publisher->addHubUrl('');
- $this->fail('Should not fail as an Exception would be raised and caught');
- } catch (PubSubHubbub\Exception $e) {}
- }
- public function testThrowsExceptionOnSettingNonStringHubServerUrl()
- {
- try {
- $this->_publisher->addHubUrl(123);
- $this->fail('Should not fail as an Exception would be raised and caught');
- } catch (PubSubHubbub\Exception $e) {}
- }
- public function testThrowsExceptionOnSettingInvalidHubServerUrl()
- {
- try {
- $this->_publisher->addHubUrl('http://');
- $this->fail('Should not fail as an Exception would be raised and caught');
- } catch (PubSubHubbub\Exception $e) {}
- }
- public function testAddsUpdatedTopicUrl()
- {
- $this->_publisher->addUpdatedTopicUrl('http://www.example.com/topic');
- $this->assertEquals(array('http://www.example.com/topic'), $this->_publisher->getUpdatedTopicUrls());
- }
- public function testAddsUpdatedTopicUrlsFromArray()
- {
- $this->_publisher->addUpdatedTopicUrls(array(
- 'http://www.example.com/topic', 'http://www.example.com/topic2'
- ));
- $this->assertEquals(array(
- 'http://www.example.com/topic', 'http://www.example.com/topic2'
- ), $this->_publisher->getUpdatedTopicUrls());
- }
- public function testAddsUpdatedTopicUrlsFromArrayUsingSetConfig()
- {
- $this->_publisher->setConfig(array('updatedTopicUrls' => array(
- 'http://www.example.com/topic', 'http://www.example.com/topic2'
- )));
- $this->assertEquals(array(
- 'http://www.example.com/topic', 'http://www.example.com/topic2'
- ), $this->_publisher->getUpdatedTopicUrls());
- }
- public function testRemovesUpdatedTopicUrl()
- {
- $this->_publisher->addUpdatedTopicUrls(array(
- 'http://www.example.com/topic', 'http://www.example.com/topic2'
- ));
- $this->_publisher->removeUpdatedTopicUrl('http://www.example.com/topic');
- $this->assertEquals(array(
- 1 => 'http://www.example.com/topic2'
- ), $this->_publisher->getUpdatedTopicUrls());
- }
- public function testRetrievesUniqueUpdatedTopicUrlsOnly()
- {
- $this->_publisher->addUpdatedTopicUrls(array(
- 'http://www.example.com/topic', 'http://www.example.com/topic2',
- 'http://www.example.com/topic'
- ));
- $this->assertEquals(array(
- 'http://www.example.com/topic', 'http://www.example.com/topic2'
- ), $this->_publisher->getUpdatedTopicUrls());
- }
- public function testThrowsExceptionOnSettingEmptyUpdatedTopicUrl()
- {
- try {
- $this->_publisher->addUpdatedTopicUrl('');
- $this->fail('Should not fail as an Exception would be raised and caught');
- } catch (PubSubHubbub\Exception $e) {}
- }
- public function testThrowsExceptionOnSettingNonStringUpdatedTopicUrl()
- {
- try {
- $this->_publisher->addUpdatedTopicUrl(123);
- $this->fail('Should not fail as an Exception would be raised and caught');
- } catch (PubSubHubbub\Exception $e) {}
- }
- public function testThrowsExceptionOnSettingInvalidUpdatedTopicUrl()
- {
- try {
- $this->_publisher->addUpdatedTopicUrl('http://');
- $this->fail('Should not fail as an Exception would be raised and caught');
- } catch (PubSubHubbub\Exception $e) {}
- }
- public function testAddsParameter()
- {
- $this->_publisher->setParameter('foo', 'bar');
- $this->assertEquals(array('foo'=>'bar'), $this->_publisher->getParameters());
- }
- public function testAddsParametersFromArray()
- {
- $this->_publisher->setParameters(array(
- 'foo' => 'bar', 'boo' => 'baz'
- ));
- $this->assertEquals(array(
- 'foo' => 'bar', 'boo' => 'baz'
- ), $this->_publisher->getParameters());
- }
- public function testAddsParametersFromArrayInSingleMethod()
- {
- $this->_publisher->setParameter(array(
- 'foo' => 'bar', 'boo' => 'baz'
- ));
- $this->assertEquals(array(
- 'foo' => 'bar', 'boo' => 'baz'
- ), $this->_publisher->getParameters());
- }
- public function testAddsParametersFromArrayUsingSetConfig()
- {
- $this->_publisher->setConfig(array('parameters' => array(
- 'foo' => 'bar', 'boo' => 'baz'
- )));
- $this->assertEquals(array(
- 'foo' => 'bar', 'boo' => 'baz'
- ), $this->_publisher->getParameters());
- }
- public function testRemovesParameter()
- {
- $this->_publisher->setParameters(array(
- 'foo' => 'bar', 'boo' => 'baz'
- ));
- $this->_publisher->removeParameter('boo');
- $this->assertEquals(array(
- 'foo' => 'bar'
- ), $this->_publisher->getParameters());
- }
- public function testRemovesParameterIfSetToNull()
- {
- $this->_publisher->setParameters(array(
- 'foo' => 'bar', 'boo' => 'baz'
- ));
- $this->_publisher->setParameter('boo', null);
- $this->assertEquals(array(
- 'foo' => 'bar'
- ), $this->_publisher->getParameters());
- }
- public function testNotifiesHubWithCorrectParameters()
- {
- PubSubHubbub\PubSubHubbub::setHttpClient(new ClientSuccess);
- $client = PubSubHubbub\PubSubHubbub::getHttpClient();
- $this->_publisher->addHubUrl('http://www.example.com/hub');
- $this->_publisher->addUpdatedTopicUrl('http://www.example.com/topic');
- $this->_publisher->setParameter('foo', 'bar');
- $this->_publisher->notifyAll();
- $this->assertEquals('hub.mode=publish&hub.url=http%3A%2F%2Fwww.example.com%2Ftopic&foo=bar', $client->getBody());
- }
- public function testNotifiesHubWithCorrectParametersAndMultipleTopics()
- {
- PubSubHubbub\PubSubHubbub::setHttpClient(new ClientSuccess);
- $client = PubSubHubbub\PubSubHubbub::getHttpClient();
- $this->_publisher->addHubUrl('http://www.example.com/hub');
- $this->_publisher->addUpdatedTopicUrl('http://www.example.com/topic');
- $this->_publisher->addUpdatedTopicUrl('http://www.example.com/topic2');
- $this->_publisher->notifyAll();
- $this->assertEquals('hub.mode=publish&hub.url=http%3A%2F%2Fwww.example.com%2Ftopic&hub.url=http%3A%2F%2Fwww.example.com%2Ftopic2', $client->getBody());
- }
- public function testNotifiesHubAndReportsSuccess()
- {
- PubSubHubbub\PubSubHubbub::setHttpClient(new ClientSuccess);
- $client = PubSubHubbub\PubSubHubbub::getHttpClient();
- $this->_publisher->addHubUrl('http://www.example.com/hub');
- $this->_publisher->addUpdatedTopicUrl('http://www.example.com/topic');
- $this->_publisher->setParameter('foo', 'bar');
- $this->_publisher->notifyAll();
- $this->assertTrue($this->_publisher->isSuccess());
- }
- public function testNotifiesHubAndReportsFail()
- {
- PubSubHubbub\PubSubHubbub::setHttpClient(new ClientFail);
- $client = PubSubHubbub\PubSubHubbub::getHttpClient();
- $this->_publisher->addHubUrl('http://www.example.com/hub');
- $this->_publisher->addUpdatedTopicUrl('http://www.example.com/topic');
- $this->_publisher->setParameter('foo', 'bar');
- $this->_publisher->notifyAll();
- $this->assertFalse($this->_publisher->isSuccess());
- }
- }
- // Some stubs for what Http_Client would be doing
- class ClientSuccess extends Http\Client
- {
- public function request($method = null) {
- $response = new ResponseSuccess;
- return $response;
- }
- public function getBody(){return $this->_prepareBody();}
- }
- class ClientFail extends Http\Client
- {
- public function request($method = null) {
- $response = new ResponseFail;
- return $response;
- }
- public function getBody(){return $this->_prepareBody();}
- }
- class ResponseSuccess
- {
- public function getStatus(){return 204;}
- }
- class ResponseFail
- {
- public function getStatus(){return 404;}
- }