Merge remote-tracking branch 'Trismegiste/unit-test-for-observer'

This commit is contained in:
Dominik Liebler
2013-09-03 14:36:58 +02:00
3 changed files with 100 additions and 23 deletions

View File

@@ -0,0 +1,62 @@
<?php
namespace DesignPatterns\Tests\Observer;
use DesignPatterns\Observer\UserObserver;
use DesignPatterns\Observer\User;
/**
* ObserverTest tests the Observer pattern
*/
class ObserverTest extends \PHPUnit_Framework_TestCase
{
protected $observer;
protected function setUp()
{
$this->observer = new UserObserver();
}
/**
* Tests the notification
*/
public function testNotify()
{
$this->expectOutputString('DesignPatterns\Observer\User has been updated');
$subject = new User();
$subject->attach($this->observer);
$subject->property = 123;
}
/**
* Tests the subscribing
*/
public function testAttachDetach()
{
$subject = new User();
$this->assertAttributeEmpty('_observers', $subject);
$subject->attach($this->observer);
$this->assertAttributeNotEmpty('_observers', $subject);
$subject->detach($this->observer);
$this->assertAttributeEmpty('_observers', $subject);
}
/**
* Tests the update() invocation on a mockup
*/
public function testUpdateCalling()
{
$subject = new User();
$observer = $this->getMock('SplObserver');
$subject->attach($observer);
$observer->expects($this->once())
->method('update')
->with($subject);
$subject->notify();
}
}