123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673 |
- <?php
- /**
- * SReg.php testing code.
- */
- require_once 'Auth/OpenID/SReg.php';
- require_once 'Auth/OpenID/Message.php';
- require_once 'Auth/OpenID/Server.php';
- class SRegURITest extends PHPUnit_Framework_TestCase {
- function test_is11()
- {
- $this->assertEquals(Auth_OpenID_SREG_NS_URI_1_1,
- Auth_OpenID_SREG_NS_URI);
- }
- }
- class CheckFieldNameTest extends PHPUnit_Framework_TestCase {
- function test_goodNamePasses()
- {
- global $Auth_OpenID_sreg_data_fields;
- foreach ($Auth_OpenID_sreg_data_fields as $field_name => $desc) {
- $this->assertTrue(Auth_OpenID_checkFieldName($field_name));
- }
- }
- function test_badNameFails()
- {
- $this->assertfalse(Auth_OpenID_checkFieldName('INVALID'));
- }
- function test_badTypeFails()
- {
- $this->assertfalse(Auth_OpenID_checkFieldName(null));
- }
- }
- // For supportsSReg test
- class FakeEndpoint {
- function FakeEndpoint($supported)
- {
- $this->supported = $supported;
- $this->checked_uris = array();
- }
- function usesExtension($namespace_uri)
- {
- $this->checked_uris[] = $namespace_uri;
- return in_array($namespace_uri, $this->supported);
- }
- }
- class SupportsSRegTest extends PHPUnit_Framework_TestCase {
- function test_unsupported()
- {
- $endpoint = new FakeEndpoint(array());
- $this->assertfalse(Auth_OpenID_supportsSReg($endpoint));
- $this->assertEquals(array(Auth_OpenID_SREG_NS_URI_1_1,
- Auth_OpenID_SREG_NS_URI_1_0),
- $endpoint->checked_uris);
- }
- function test_supported_1_1()
- {
- $endpoint = new FakeEndpoint(array(Auth_OpenID_SREG_NS_URI_1_1));
- $this->assertTrue(Auth_OpenID_supportsSReg($endpoint));
- $this->assertEquals(array(Auth_OpenID_SREG_NS_URI_1_1),
- $endpoint->checked_uris);
- }
- function test_supported_1_0()
- {
- $endpoint = new FakeEndpoint(array(Auth_OpenID_SREG_NS_URI_1_0));
- $this->assertTrue(Auth_OpenID_supportsSReg($endpoint));
- $this->assertEquals(array(Auth_OpenID_SREG_NS_URI_1_1,
- Auth_OpenID_SREG_NS_URI_1_0),
- $endpoint->checked_uris);
- }
- }
- class FakeMessage {
- function FakeMessage()
- {
- $this->openid1 = false;
- $this->namespaces = new Auth_OpenID_NamespaceMap();
- }
- function isOpenID1()
- {
- return $this->openid1;
- }
- }
- class GetNSTest extends PHPUnit_Framework_TestCase {
- function setUp()
- {
- $this->msg = new FakeMessage();
- }
- function test_openID2Empty()
- {
- $ns_uri = Auth_OpenID_SRegBase::_getSRegNS($this->msg);
- $this->assertEquals($this->msg->namespaces->getAlias($ns_uri), 'sreg');
- $this->assertEquals(Auth_OpenID_SREG_NS_URI, $ns_uri);
- }
- function test_openID1Empty()
- {
- $this->msg->openid1 = true;
- $ns_uri = Auth_OpenID_SRegBase::_getSRegNS($this->msg);
- $this->assertEquals($this->msg->namespaces->getAlias($ns_uri), 'sreg');
- $this->assertEquals(Auth_OpenID_SREG_NS_URI, $ns_uri);
- }
- function test_openID1Defined_1_0()
- {
- $this->msg->openid1 = true;
- $this->msg->namespaces->add(Auth_OpenID_SREG_NS_URI_1_0);
- $ns_uri = Auth_OpenID_SRegBase::_getSRegNS($this->msg);
- $this->assertEquals(Auth_OpenID_SREG_NS_URI_1_0, $ns_uri);
- }
- function test_openID1Defined_1_0_overrideAlias()
- {
- foreach (array(true, false) as $openid_version) {
- foreach (array(Auth_OpenID_SREG_NS_URI_1_0,
- Auth_OpenID_SREG_NS_URI_1_1) as $sreg_version) {
- foreach (array('sreg', 'bogus') as $alias) {
- $this->setUp();
- $this->msg->openid1 = $openid_version;
- $this->assertTrue($this->msg->namespaces->addAlias($sreg_version, $alias) !== null);
- $ns_uri = Auth_OpenID_SRegBase::_getSRegNS($this->msg);
- $this->assertEquals($this->msg->namespaces->getAlias($ns_uri), $alias);
- $this->assertEquals($sreg_version, $ns_uri);
- }
- }
- }
- }
- function test_openID1DefinedBadly()
- {
- $this->msg->openid1 = true;
- $this->msg->namespaces->addAlias('http://invalid/', 'sreg');
- $this->assertTrue(Auth_OpenID_SRegBase::_getSRegNS($this->msg) === null);
- }
- function test_openID2DefinedBadly()
- {
- $this->msg->openid1 = false;
- $this->msg->namespaces->addAlias('http://invalid/', 'sreg');
- $this->assertTrue(Auth_OpenID_SRegBase::_getSRegNS($this->msg) === null);
- }
- function test_openID2Defined_1_0()
- {
- $this->msg->namespaces->add(Auth_OpenID_SREG_NS_URI_1_0);
- $ns_uri = Auth_OpenID_SRegBase::_getSRegNS($this->msg);
- $this->assertEquals(Auth_OpenID_SREG_NS_URI_1_0, $ns_uri);
- }
- function test_openID1_sregNSfromArgs()
- {
- $args = array(
- 'sreg.optional' => 'nickname',
- 'sreg.required' => 'dob');
- $m = Auth_OpenID_Message::fromOpenIDArgs($args);
- $this->assertTrue($m->getArg(Auth_OpenID_SREG_NS_URI_1_1, 'optional') == 'nickname');
- $this->assertTrue($m->getArg(Auth_OpenID_SREG_NS_URI_1_1, 'required') == 'dob');
- }
- }
- global $__args_sentinel;
- global $__ns_sentinel;
- $__args_sentinel = 'args_sentinel';
- $__ns_sentinel = 'ns_sentinel';
- class SentinelFakeMessage {
- function SentinelFakeMessage($test_case)
- {
- $this->test_case =& $test_case;
- $this->message = new Auth_OpenID_Message();
- }
- function getArgs($ns_uri)
- {
- global $__ns_sentinel, $__args_sentinel;
- $this->test_case->assertEquals($__ns_sentinel, $ns_uri);
- return $__args_sentinel;
- }
- }
- // XXX Ugly hack. Thanks, PHP.
- global $__TestingReq_TEST_CASE;
- $__TestingReq_TEST_CASE = "FLUB";
- function __setTestCase($thing) {
- global $__TestingReq_TEST_CASE;
- $__TestingReq_TEST_CASE = $thing;
- }
- function &__getTestCase() {
- global $__TestingReq_TEST_CASE;
- return $__TestingReq_TEST_CASE;
- }
- class TestingReq extends Auth_OpenID_SRegRequest {
- static function fromOpenIDRequest($thing, $test_case)
- {
- __setTestCase($test_case);
- $obj = parent::fromOpenIDRequest($thing, 'TestingReq');
- return $obj;
- }
- static function _getSRegNS($unused)
- {
- global $__ns_sentinel;
- return $__ns_sentinel;
- }
- function parseExtensionArgs($args)
- {
- global $__args_sentinel;
- $tc =& __getTestCase();
- $tc->assertEquals($__args_sentinel, $args);
- }
- }
- class SRegRequestTest extends PHPUnit_Framework_TestCase {
- function test_constructEmpty()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertEquals(array(), $req->optional);
- $this->assertEquals(array(), $req->required);
- $this->assertEquals(null, $req->policy_url);
- $this->assertEquals(Auth_OpenID_SREG_NS_URI, $req->ns_uri);
- }
- function test_constructFields()
- {
- $req = Auth_OpenID_SRegRequest::build(
- array('nickname'),
- array('gender'),
- 'http://policy',
- 'http://sreg.ns_uri');
- $this->assertEquals(array('gender'), $req->optional);
- $this->assertEquals(array('nickname'), $req->required);
- $this->assertEquals('http://policy', $req->policy_url);
- $this->assertEquals('http://sreg.ns_uri', $req->ns_uri);
- }
- function test_constructBadFields()
- {
- $this->assertTrue(Auth_OpenID_SRegRequest::build(array('elvis')) === null);
- }
- function test_fromOpenIDResponse()
- {
- $openid_req = new Auth_OpenID_Request();
- $msg = new SentinelFakeMessage($this);
- $openid_req->message =& $msg;
- $req = TestingReq::fromOpenIDRequest($openid_req, $this);
- $this->assertTrue(is_a($req, 'TestingReq'));
- }
- function test_parseExtensionArgs_empty()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(array()));
- }
- function test_parseExtensionArgs_extraIgnored()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(array('janrain' => 'inc')));
- }
- function test_parseExtensionArgs_nonStrict()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(array('required' => 'beans')));
- $this->assertEquals(array(), $req->required);
- }
- function test_parseExtensionArgs_strict()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertFalse($req->parseExtensionArgs(array('required' => 'beans'),
- true));
- }
- function test_parseExtensionArgs_policy()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(
- array('policy_url' => 'http://policy'), true));
- $this->assertEquals('http://policy', $req->policy_url);
- }
- function test_parseExtensionArgs_requiredEmpty()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(array('required' => ''), true));
- $this->assertEquals(array(), $req->required);
- }
- function test_parseExtensionArgs_optionalEmpty()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(array('optional' => ''), true));
- $this->assertEquals(array(), $req->optional);
- }
- function test_parseExtensionArgs_optionalSingle()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(array('optional' => 'nickname'), true));
- $this->assertEquals(array('nickname'), $req->optional);
- }
- function test_parseExtensionArgs_optionalList()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(array('optional' => 'nickname,email'), true));
- $this->assertEquals(array('nickname','email'), $req->optional);
- }
- function test_parseExtensionArgs_optionalListBadNonStrict()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(array('optional' => 'nickname,email,beer')));
- $this->assertEquals(array('nickname','email'), $req->optional);
- }
- function test_parseExtensionArgs_optionalListBadStrict()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertFalse($req->parseExtensionArgs(array('optional' => 'nickname,email,beer'),
- true));
- }
- function test_parseExtensionArgs_bothNonStrict()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(array('optional' => 'nickname',
- 'required' => 'nickname')));
- $this->assertEquals(array(), $req->optional);
- $this->assertEquals(array('nickname'), $req->required);
- }
- function test_parseExtensionArgs_bothStrict()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertFalse($req->parseExtensionArgs(
- array('optional' => 'nickname',
- 'required' => 'nickname'),
- true));
- }
- function test_parseExtensionArgs_bothList()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertTrue($req->parseExtensionArgs(array('optional' => 'nickname,email',
- 'required' => 'country,postcode'),
- true));
- $this->assertEquals(array('nickname','email'), $req->optional);
- $this->assertEquals(array('country','postcode'), $req->required);
- }
- function test_allRequestedFields()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertEquals(array(), $req->allRequestedFields());
- $req->requestField('nickname');
- $this->assertEquals(array('nickname'), $req->allRequestedFields());
- $req->requestField('gender', true);
- $requested = $req->allRequestedFields();
- sort($requested);
- $this->assertEquals(array('gender', 'nickname'), $requested);
- }
- function test_wereFieldsRequested()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertFalse($req->wereFieldsRequested());
- $req->requestField('gender');
- $this->assertTrue($req->wereFieldsRequested());
- }
- function test_contains()
- {
- global $Auth_OpenID_sreg_data_fields;
- $req = Auth_OpenID_SRegRequest::build();
- foreach ($Auth_OpenID_sreg_data_fields as $field_name => $desc) {
- $this->assertFalse($req->contains($field_name));
- }
- $this->assertFalse($req->contains('something else'));
- $req->requestField('nickname');
- foreach ($Auth_OpenID_sreg_data_fields as $field_name => $desc) {
- if ($field_name == 'nickname') {
- $this->assertTrue($req->contains($field_name));
- } else {
- $this->assertFalse($req->contains($field_name));
- }
- }
- }
- function test_requestField_bogus()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertFalse($req->requestField('something else'));
- $this->assertFalse($req->requestField('something else', true));
- }
- function test_requestField()
- {
- global $Auth_OpenID_sreg_data_fields;
- // Add all of the fields, one at a time
- $req = Auth_OpenID_SRegRequest::build();
- $fields = array_keys($Auth_OpenID_sreg_data_fields);
- foreach ($fields as $field_name) {
- $req->requestField($field_name);
- }
- $this->assertEquals($fields, $req->optional);
- $this->assertEquals(array(), $req->required);
- // By default, adding the same fields over again has no effect
- foreach ($fields as $field_name) {
- $req->requestField($field_name);
- }
- $this->assertEquals($fields, $req->optional);
- $this->assertEquals(array(), $req->required);
- // Requesting a field as required overrides requesting it as
- // optional
- $expected = $fields;
- $overridden = array_pop($expected);
- $this->assertTrue($req->requestField($overridden, true));
- $this->assertEquals($expected, $req->optional);
- $this->assertEquals(array($overridden), $req->required);
- // Requesting a field as required overrides requesting it as
- // optional
- foreach ($fields as $field_name) {
- $this->assertTrue($req->requestField($field_name, true));
- }
- $this->assertEquals(array(), $req->optional);
- foreach ($fields as $f) {
- $this->assertTrue(in_array($f, $req->required));
- }
- // Requesting it as optional does not downgrade it to optional
- foreach ($fields as $field_name) {
- $req->requestField($field_name);
- }
- $this->assertEquals(array(), $req->optional);
- foreach ($fields as $f) {
- $this->assertTrue(in_array($f, $req->required));
- }
- }
- function test_requestFields_type()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertFalse($req->requestFields('nickname'));
- }
- function test_requestFields()
- {
- global $Auth_OpenID_sreg_data_fields;
- // Add all of the fields
- $req = Auth_OpenID_SRegRequest::build();
- $fields = array_keys($Auth_OpenID_sreg_data_fields);
- $req->requestFields($fields);
- $this->assertEquals($fields, $req->optional);
- $this->assertEquals(array(), $req->required);
- // By default, adding the same fields over again has no effect
- $req->requestFields($fields);
- $this->assertEquals($fields, $req->optional);
- $this->assertEquals(array(), $req->required);
- // Requesting a field as required overrides requesting it as
- // optional
- $expected = $fields;
- $overridden = array_shift($expected);
- $req->requestFields(array($overridden), true);
- foreach ($expected as $f) {
- $this->assertTrue(in_array($f, $req->optional));
- }
- $this->assertEquals(array($overridden), $req->required);
- // Requesting a field as required overrides requesting it as
- // optional
- $req->requestFields($fields, true);
- $this->assertEquals(array(), $req->optional);
- $this->assertEquals($fields, $req->required);
- // Requesting it as optional does not downgrade it to optional
- $req->requestFields($fields);
- $this->assertEquals(array(), $req->optional);
- $this->assertEquals($fields, $req->required);
- }
- function test_getExtensionArgs()
- {
- $req = Auth_OpenID_SRegRequest::build();
- $this->assertEquals(array(), $req->getExtensionArgs());
- $this->assertTrue($req->requestField('nickname'));
- $this->assertEquals(array('optional' => 'nickname'),
- $req->getExtensionArgs());
- $this->assertTrue($req->requestField('email'));
- $this->assertEquals(array('optional' => 'nickname,email'),
- $req->getExtensionArgs());
- $this->assertTrue($req->requestField('gender', true));
- $this->assertEquals(array('optional' => 'nickname,email',
- 'required' => 'gender'),
- $req->getExtensionArgs());
- $this->assertTrue($req->requestField('postcode', true));
- $this->assertEquals(array('optional' => 'nickname,email',
- 'required' => 'gender,postcode'),
- $req->getExtensionArgs());
- $req->policy_url = 'http://policy.invalid/';
- $this->assertEquals(array('optional' => 'nickname,email',
- 'required' => 'gender,postcode',
- 'policy_url' => 'http://policy.invalid/'),
- $req->getExtensionArgs());
- }
- }
- class DummySuccessResponse {
- function DummySuccessResponse($message, $signed_stuff)
- {
- $this->message = $message;
- $this->signed_stuff = $signed_stuff;
- }
- function getSignedNS($ns_uri)
- {
- return $this->signed_stuff;
- }
- }
- class SRegResponseTest extends PHPUnit_Framework_TestCase {
- function test_fromSuccessResponse_signed()
- {
- $message = Auth_OpenID_Message::fromOpenIDArgs(array(
- 'sreg.nickname' => 'The Mad Stork',
- ));
- $success_resp = new DummySuccessResponse($message, array());
- $sreg_resp = Auth_OpenID_SRegResponse::fromSuccessResponse($success_resp);
- $this->assertTrue(count($sreg_resp->contents()) === 0);
- }
- function test_fromSuccessResponse_unsigned()
- {
- $message = Auth_OpenID_Message::fromOpenIDArgs(array(
- 'sreg.nickname' => 'The Mad Stork',
- ));
- $success_resp = new DummySuccessResponse($message, array());
- $sreg_resp = Auth_OpenID_SRegResponse::fromSuccessResponse($success_resp,
- false);
- $this->assertEquals(array('nickname' => 'The Mad Stork'),
- $sreg_resp->contents());
- }
- }
- class SendFieldsTest extends PHPUnit_Framework_TestCase {
- function _test($uri)
- {
- // Create a request message with simple registration fields
- $sreg_req = Auth_OpenID_SRegRequest::build(array('nickname', 'email'),
- array('fullname'));
- $req_msg = new Auth_OpenID_Message($uri);
- $req_msg->updateArgs(Auth_OpenID_SREG_NS_URI,
- $sreg_req->getExtensionArgs());
- $req = new Auth_OpenID_Request();
- $req->message =& $req_msg;
- $req->namespace = $req_msg->getOpenIDNamespace();
- // -> send checkid_* request
- // Create an empty response message
- $resp_msg = new Auth_OpenID_Message($uri);
- $resp = new Auth_OpenID_ServerResponse($req);
- $resp->fields = $resp_msg;
- $data = array(
- 'nickname' => 'linusaur',
- 'postcode' => '12345',
- 'country' => 'US',
- 'gender' => 'M',
- 'fullname' => 'Leonhard Euler',
- 'email' => 'president@whitehouse.gov',
- 'dob' => '0000-00-00',
- 'language' => 'en-us');
- // Put the requested data fields in the response message
- $sreg_resp = Auth_OpenID_SRegResponse::extractResponse($sreg_req, $data);
- $resp->addExtension($sreg_resp);
- // <- send id_res response
- // Extract the fields that were sent
- $sreg_data_resp = $resp->fields->getArgs(Auth_OpenID_SREG_NS_URI);
- $this->assertEquals(
- array('nickname' => 'linusaur',
- 'email' => 'president@whitehouse.gov',
- 'fullname' => 'Leonhard Euler'),
- $sreg_data_resp);
- }
- function test()
- {
- foreach (array(Auth_OpenID_OPENID1_NS,
- Auth_OpenID_OPENID2_NS) as $uri) {
- $this->_test($uri);
- }
- }
- }
- class Tests_Auth_OpenID_SReg extends PHPUnit_Framework_TestSuite {
- function getName()
- {
- return "Tests_Auth_OpenID_SReg";
- }
- function Tests_Auth_OpenID_SReg()
- {
- $this->addTestSuite('SRegURITest');
- $this->addTestSuite('CheckFieldNameTest');
- $this->addTestSuite('SupportsSRegTest');
- $this->addTestSuite('GetNSTest');
- $this->addTestSuite('SRegRequestTest');
- $this->addTestSuite('SRegResponseTest');
- $this->addTestSuite('SendFieldsTest');
- }
- }
|