Add tests for concrete method inside abstract SignatureMethod class.
This commit is contained in:
parent
7457f612b7
commit
a5ba220ae1
80
tests/SignatureMethodTest.php
Normal file
80
tests/SignatureMethodTest.php
Normal file
@ -0,0 +1,80 @@
|
||||
<?php
|
||||
|
||||
use Mockery as m;
|
||||
use GaryJones\OAuth\SignatureMethod;
|
||||
|
||||
/**
|
||||
* Create concrete class from abstract SignatureMethod.
|
||||
*
|
||||
* Have to define two methods which are abstract in SignatureMethod.
|
||||
*/
|
||||
class FooBarSignatureMethod extends SignatureMethod
|
||||
{
|
||||
public function getName() {
|
||||
}
|
||||
|
||||
public function buildSignature(
|
||||
\GaryJones\OAuth\Request $request,
|
||||
\GaryJones\OAuth\Client $client,
|
||||
\GaryJones\OAuth\Token $token = null
|
||||
) {
|
||||
}
|
||||
}
|
||||
|
||||
class SignatureTest extends PHPUnit_Framework_TestCase
|
||||
{
|
||||
public function tearDown()
|
||||
{
|
||||
m::close();
|
||||
}
|
||||
|
||||
public function testGetSignatureKeyWithoutToken()
|
||||
{
|
||||
// Create instance of class to test, with mock objects passed in.
|
||||
$signature_method = $this->getSignatureMethod();
|
||||
|
||||
// Get mock objects
|
||||
$client = $this->getClient();
|
||||
|
||||
// Run method being tested
|
||||
$signature_key = $signature_method->getSignatureKey($client);
|
||||
|
||||
// Check results
|
||||
$this->assertEquals('secret&', $signature_key);
|
||||
}
|
||||
|
||||
public function testGetSignatureKeyWithToken()
|
||||
{
|
||||
// Create instance of class to test, with mock objects passed in.
|
||||
$signature_method = $this->getSignatureMethod();
|
||||
|
||||
// Get mock objects
|
||||
$client = $this->getClient();
|
||||
$token = $this->getToken();
|
||||
|
||||
// Run method being tested
|
||||
$signature_key = $signature_method->getSignatureKey($client, $token);
|
||||
|
||||
// Check results
|
||||
$this->assertEquals('secret&token_secret', $signature_key);
|
||||
}
|
||||
|
||||
private function getSignatureMethod()
|
||||
{
|
||||
return new FooBarSignatureMethod;
|
||||
}
|
||||
|
||||
private function getClient()
|
||||
{
|
||||
return m::mock('GaryJones\OAuth\Client', function ($mock) {
|
||||
$mock->shouldReceive('getSecret')->withNoArgs()->andReturn('secret')->once();
|
||||
});
|
||||
}
|
||||
|
||||
private function getToken()
|
||||
{
|
||||
return m::mock('GaryJones\OAuth\Token', function ($mock) {
|
||||
$mock->shouldReceive('getSecret')->withNoArgs()->andReturn('token_secret');
|
||||
});
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user