Add unit tests for signature methods, and a couple for Request.
This commit is contained in:
parent
b564cbd103
commit
52d9317cfd
79
tests/HmacSha1Test.php
Normal file
79
tests/HmacSha1Test.php
Normal file
@ -0,0 +1,79 @@
|
||||
<?php
|
||||
|
||||
use Mockery as m;
|
||||
use GaryJones\OAuth\HmacSha1;
|
||||
|
||||
class HmacSha1Test extends PHPUnit_Framework_TestCase
|
||||
{
|
||||
public function tearDown()
|
||||
{
|
||||
m::close();
|
||||
}
|
||||
|
||||
public function testSignatureName()
|
||||
{
|
||||
$hmacsha1 = $this->getSignatureMethod();
|
||||
$this->assertEquals('HMAC-SHA1', $hmacsha1->getName());
|
||||
}
|
||||
|
||||
public function testBuildSignatureWithoutToken()
|
||||
{
|
||||
// Create instance of class to test
|
||||
$hmacsha1 = $this->getSignatureMethod();
|
||||
|
||||
// Get mock objects
|
||||
$request = $this->getRequest();
|
||||
$client = $this->getClient();
|
||||
|
||||
// Run method being tested
|
||||
$signature = $hmacsha1->buildSignature($request, $client);
|
||||
|
||||
// Check results
|
||||
$this->assertEquals('RaZU4UG/wwJ/E5Df2/pePmwaS1Q=', $signature);
|
||||
}
|
||||
|
||||
public function testBuildSignatureWithToken()
|
||||
{
|
||||
// Create instance of class to test
|
||||
$hmacsha1 = $this->getSignatureMethod();
|
||||
|
||||
// Get mock objects
|
||||
$request = $this->getRequest();
|
||||
$client = $this->getClient();
|
||||
$token = $this->getToken();
|
||||
|
||||
// Run method being tested
|
||||
$signature = $hmacsha1->buildSignature($request, $client, $token);
|
||||
|
||||
// Check results
|
||||
$this->assertEquals('1P/rfHzjnxBcNzngW9BEuT01goM=', $signature);
|
||||
}
|
||||
|
||||
private function getSignatureMethod()
|
||||
{
|
||||
return new HmacSha1;
|
||||
}
|
||||
|
||||
private function getRequest()
|
||||
{
|
||||
return m::mock('GaryJones\OAuth\Request', function ($mock) {
|
||||
$mock->shouldReceive('getSignatureBaseString')
|
||||
->withNoArgs()
|
||||
->andReturn('POST&http%3A%2F%2Fexample.com%2Ffoobar&oauth_signature_method%3DHMAC-SHA1')->once();
|
||||
});
|
||||
}
|
||||
|
||||
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');
|
||||
});
|
||||
}
|
||||
}
|
75
tests/PlainTextTest.php
Normal file
75
tests/PlainTextTest.php
Normal file
@ -0,0 +1,75 @@
|
||||
<?php
|
||||
|
||||
use Mockery as m;
|
||||
use GaryJones\OAuth\PlainText;
|
||||
|
||||
class PlainTextTest extends PHPUnit_Framework_TestCase
|
||||
{
|
||||
public function tearDown()
|
||||
{
|
||||
m::close();
|
||||
}
|
||||
|
||||
public function testSignatureName()
|
||||
{
|
||||
$plaintext = $this->getSignatureMethod();
|
||||
$this->assertEquals('PLAINTEXT', $plaintext->getName());
|
||||
}
|
||||
|
||||
public function testBuildSignatureWithoutToken()
|
||||
{
|
||||
// Create instance of class to test
|
||||
$plaintext = $this->getSignatureMethod();
|
||||
|
||||
// Get mock objects
|
||||
$request = $this->getRequest();
|
||||
$client = $this->getClient();
|
||||
|
||||
// Run method being tested
|
||||
$signature = $plaintext->buildSignature($request, $client);
|
||||
|
||||
// Check results
|
||||
$this->assertEquals('secret&', $signature);
|
||||
}
|
||||
|
||||
public function testBuildSignatureWithToken()
|
||||
{
|
||||
// Create instance of class to test
|
||||
$plaintext = $this->getSignatureMethod();
|
||||
|
||||
// Get mock objects
|
||||
$request = $this->getRequest();
|
||||
$client = $this->getClient();
|
||||
$token = $this->getToken();
|
||||
|
||||
// Run method being tested
|
||||
$signature = $plaintext->buildSignature($request, $client, $token);
|
||||
|
||||
// Check results
|
||||
$this->assertEquals('secret&token_secret', $signature);
|
||||
}
|
||||
|
||||
private function getSignatureMethod()
|
||||
{
|
||||
return new PlainText;
|
||||
}
|
||||
|
||||
private function getRequest()
|
||||
{
|
||||
return m::mock('GaryJones\OAuth\Request');
|
||||
}
|
||||
|
||||
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');
|
||||
});
|
||||
}
|
||||
}
|
36
tests/RequestTest.php
Normal file
36
tests/RequestTest.php
Normal file
@ -0,0 +1,36 @@
|
||||
<?php
|
||||
|
||||
use Mockery as m;
|
||||
use GaryJones\OAuth\Request;
|
||||
|
||||
class RequestTest extends PHPUnit_Framework_TestCase
|
||||
{
|
||||
public function tearDown()
|
||||
{
|
||||
m::close();
|
||||
}
|
||||
|
||||
public function testHttpMethodCanBeNormalized()
|
||||
{
|
||||
$request = new Request('foo', 'bar');
|
||||
$this->assertEquals('FOO', $request->getNormalizedHttpMethod());
|
||||
}
|
||||
|
||||
public function testHttpUrlCanBeNormalized()
|
||||
{
|
||||
$request = new Request('foo', 'bar');
|
||||
$this->assertEquals('http://bar', $request->getNormalizedHttpUrl());
|
||||
$request = new Request('foo', 'example.com:80');
|
||||
$this->assertEquals('http://example.com', $request->getNormalizedHttpUrl());
|
||||
$request = new Request('foo', 'example.com:81');
|
||||
$this->assertEquals('http://example.com:81', $request->getNormalizedHttpUrl());
|
||||
$request = new Request('foo', 'https://example.com');
|
||||
$this->assertEquals('https://example.com', $request->getNormalizedHttpUrl());
|
||||
$request = new Request('foo', 'https://example.com:443');
|
||||
$this->assertEquals('https://example.com', $request->getNormalizedHttpUrl());
|
||||
$request = new Request('foo', 'http://example.com/foobar');
|
||||
$this->assertEquals('http://example.com/foobar', $request->getNormalizedHttpUrl());
|
||||
$request = new Request('foo', 'example.org:80/foobar');
|
||||
$this->assertEquals('http://example.org/foobar', $request->getNormalizedHttpUrl());
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user