summaryrefslogtreecommitdiff
path: root/lib/facebook-graph-sdk/tests/HttpClients/FacebookCurlHttpClientTest.php
diff options
context:
space:
mode:
Diffstat (limited to 'lib/facebook-graph-sdk/tests/HttpClients/FacebookCurlHttpClientTest.php')
-rw-r--r--lib/facebook-graph-sdk/tests/HttpClients/FacebookCurlHttpClientTest.php334
1 files changed, 334 insertions, 0 deletions
diff --git a/lib/facebook-graph-sdk/tests/HttpClients/FacebookCurlHttpClientTest.php b/lib/facebook-graph-sdk/tests/HttpClients/FacebookCurlHttpClientTest.php
new file mode 100644
index 0000000..4cf31d3
--- /dev/null
+++ b/lib/facebook-graph-sdk/tests/HttpClients/FacebookCurlHttpClientTest.php
@@ -0,0 +1,334 @@
+<?php
+/**
+ * Copyright 2014 Facebook, Inc.
+ *
+ * You are hereby granted a non-exclusive, worldwide, royalty-free license to
+ * use, copy, modify, and distribute this software in source code or binary
+ * form for use in connection with the web services and APIs provided by
+ * Facebook.
+ *
+ * As with any software that integrates with the Facebook platform, your use
+ * of this software is subject to the Facebook Developer Principles and
+ * Policies [http://developers.facebook.com/policy/]. This copyright notice
+ * shall be included in all copies or substantial portions of the software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ * DEALINGS IN THE SOFTWARE.
+ *
+ */
+namespace Facebook\Tests\HttpClients;
+
+use Mockery as m;
+use Facebook\HttpClients\FacebookCurlHttpClient;
+
+class FacebookCurlHttpClientTest extends AbstractTestHttpClient
+{
+ /**
+ * @var \Facebook\HttpClients\FacebookCurl
+ */
+ protected $curlMock;
+
+ /**
+ * @var FacebookCurlHttpClient
+ */
+ protected $curlClient;
+
+ const CURL_VERSION_STABLE = 0x072400;
+ const CURL_VERSION_BUGGY = 0x071400;
+
+ public function setUp()
+ {
+ $this->curlMock = m::mock('Facebook\HttpClients\FacebookCurl');
+ $this->curlClient = new FacebookCurlHttpClient($this->curlMock);
+ }
+
+ public function testCanOpenGetCurlConnection()
+ {
+ $this->curlMock
+ ->shouldReceive('init')
+ ->once()
+ ->andReturn(null);
+ $this->curlMock
+ ->shouldReceive('setoptArray')
+ ->with(m::on(function ($arg) {
+
+ // array_diff() will sometimes trigger error on child-arrays
+ if (['X-Foo-Header: X-Bar'] !== $arg[CURLOPT_HTTPHEADER]) {
+ return false;
+ }
+ unset($arg[CURLOPT_HTTPHEADER]);
+
+ $caInfo = array_diff($arg, [
+ CURLOPT_CUSTOMREQUEST => 'GET',
+ CURLOPT_URL => 'http://foo.com',
+ CURLOPT_CONNECTTIMEOUT => 10,
+ CURLOPT_TIMEOUT => 123,
+ CURLOPT_RETURNTRANSFER => true,
+ CURLOPT_HEADER => true,
+ CURLOPT_SSL_VERIFYHOST => 2,
+ CURLOPT_SSL_VERIFYPEER => true,
+ ]);
+
+ if (count($caInfo) !== 1) {
+ return false;
+ }
+
+ if (1 !== preg_match('/.+\/certs\/DigiCertHighAssuranceEVRootCA\.pem$/', $caInfo[CURLOPT_CAINFO])) {
+ return false;
+ }
+
+ return true;
+ }))
+ ->once()
+ ->andReturn(null);
+
+ $this->curlClient->openConnection('http://foo.com', 'GET', 'foo_body', ['X-Foo-Header' => 'X-Bar'], 123);
+ }
+
+ public function testCanOpenCurlConnectionWithPostBody()
+ {
+ $this->curlMock
+ ->shouldReceive('init')
+ ->once()
+ ->andReturn(null);
+ $this->curlMock
+ ->shouldReceive('setoptArray')
+ ->with(m::on(function ($arg) {
+
+ // array_diff() will sometimes trigger error on child-arrays
+ if ([] !== $arg[CURLOPT_HTTPHEADER]) {
+ return false;
+ }
+ unset($arg[CURLOPT_HTTPHEADER]);
+
+ $caInfo = array_diff($arg, [
+ CURLOPT_CUSTOMREQUEST => 'POST',
+ CURLOPT_URL => 'http://bar.com',
+ CURLOPT_CONNECTTIMEOUT => 10,
+ CURLOPT_TIMEOUT => 60,
+ CURLOPT_RETURNTRANSFER => true,
+ CURLOPT_HEADER => true,
+ CURLOPT_SSL_VERIFYHOST => 2,
+ CURLOPT_SSL_VERIFYPEER => true,
+ CURLOPT_POSTFIELDS => 'baz=bar',
+ ]);
+
+ if (count($caInfo) !== 1) {
+ return false;
+ }
+
+ if (1 !== preg_match('/.+\/certs\/DigiCertHighAssuranceEVRootCA\.pem$/', $caInfo[CURLOPT_CAINFO])) {
+ return false;
+ }
+
+ return true;
+ }))
+ ->once()
+ ->andReturn(null);
+
+ $this->curlClient->openConnection('http://bar.com', 'POST', 'baz=bar', [], 60);
+ }
+
+ public function testCanCloseConnection()
+ {
+ $this->curlMock
+ ->shouldReceive('close')
+ ->once()
+ ->andReturn(null);
+
+ $this->curlClient->closeConnection();
+ }
+
+ public function testIsolatesTheHeaderAndBody()
+ {
+ $this->curlMock
+ ->shouldReceive('getinfo')
+ ->with(CURLINFO_HEADER_SIZE)
+ ->once()
+ ->andReturn(strlen($this->fakeRawHeader));
+ $this->curlMock
+ ->shouldReceive('version')
+ ->once()
+ ->andReturn(['version_number' => self::CURL_VERSION_STABLE]);
+ $this->curlMock
+ ->shouldReceive('exec')
+ ->once()
+ ->andReturn($this->fakeRawHeader . $this->fakeRawBody);
+
+ $this->curlClient->sendRequest();
+ list($rawHeader, $rawBody) = $this->curlClient->extractResponseHeadersAndBody();
+
+ $this->assertEquals($rawHeader, trim($this->fakeRawHeader));
+ $this->assertEquals($rawBody, $this->fakeRawBody);
+ }
+
+ public function testProperlyHandlesProxyHeaders()
+ {
+ $rawHeader = $this->fakeRawProxyHeader . $this->fakeRawHeader;
+ $this->curlMock
+ ->shouldReceive('getinfo')
+ ->with(CURLINFO_HEADER_SIZE)
+ ->once()
+ ->andReturn(mb_strlen($rawHeader));
+ $this->curlMock
+ ->shouldReceive('version')
+ ->once()
+ ->andReturn(['version_number' => self::CURL_VERSION_STABLE]);
+ $this->curlMock
+ ->shouldReceive('exec')
+ ->once()
+ ->andReturn($rawHeader . $this->fakeRawBody);
+
+ $this->curlClient->sendRequest();
+ list($rawHeaders, $rawBody) = $this->curlClient->extractResponseHeadersAndBody();
+
+ $this->assertEquals($rawHeaders, trim($rawHeader));
+ $this->assertEquals($rawBody, $this->fakeRawBody);
+ }
+
+ public function testProperlyHandlesProxyHeadersWithCurlBug()
+ {
+ $rawHeader = $this->fakeRawProxyHeader . $this->fakeRawHeader;
+ $this->curlMock
+ ->shouldReceive('getinfo')
+ ->with(CURLINFO_HEADER_SIZE)
+ ->once()
+ ->andReturn(mb_strlen($this->fakeRawHeader)); // Mimic bug that doesn't count proxy header
+ $this->curlMock
+ ->shouldReceive('version')
+ ->once()
+ ->andReturn(['version_number' => self::CURL_VERSION_BUGGY]);
+ $this->curlMock
+ ->shouldReceive('exec')
+ ->once()
+ ->andReturn($rawHeader . $this->fakeRawBody);
+
+ $this->curlClient->sendRequest();
+ list($rawHeaders, $rawBody) = $this->curlClient->extractResponseHeadersAndBody();
+
+ $this->assertEquals($rawHeaders, trim($rawHeader));
+ $this->assertEquals($rawBody, $this->fakeRawBody);
+ }
+
+ public function testProperlyHandlesProxyHeadersWithCurlBug2()
+ {
+ $rawHeader = $this->fakeRawProxyHeader2 . $this->fakeRawHeader;
+ $this->curlMock
+ ->shouldReceive('getinfo')
+ ->with(CURLINFO_HEADER_SIZE)
+ ->once()
+ ->andReturn(mb_strlen($this->fakeRawHeader)); // Mimic bug that doesn't count proxy header
+ $this->curlMock
+ ->shouldReceive('version')
+ ->once()
+ ->andReturn(['version_number' => self::CURL_VERSION_BUGGY]);
+ $this->curlMock
+ ->shouldReceive('exec')
+ ->once()
+ ->andReturn($rawHeader . $this->fakeRawBody);
+
+ $this->curlClient->sendRequest();
+ list($rawHeaders, $rawBody) = $this->curlClient->extractResponseHeadersAndBody();
+
+ $this->assertEquals($rawHeaders, trim($rawHeader));
+ $this->assertEquals($rawBody, $this->fakeRawBody);
+ }
+
+ public function testProperlyHandlesRedirectHeaders()
+ {
+ $rawHeader = $this->fakeRawRedirectHeader . $this->fakeRawHeader;
+ $this->curlMock
+ ->shouldReceive('getinfo')
+ ->with(CURLINFO_HEADER_SIZE)
+ ->once()
+ ->andReturn(mb_strlen($rawHeader));
+ $this->curlMock
+ ->shouldReceive('version')
+ ->once()
+ ->andReturn(['version_number' => self::CURL_VERSION_STABLE]);
+ $this->curlMock
+ ->shouldReceive('exec')
+ ->once()
+ ->andReturn($rawHeader . $this->fakeRawBody);
+
+ $this->curlClient->sendRequest();
+ list($rawHeaders, $rawBody) = $this->curlClient->extractResponseHeadersAndBody();
+
+ $this->assertEquals($rawHeaders, trim($rawHeader));
+ $this->assertEquals($rawBody, $this->fakeRawBody);
+ }
+
+ public function testCanSendNormalRequest()
+ {
+ $this->curlMock
+ ->shouldReceive('init')
+ ->once()
+ ->andReturn(null);
+ $this->curlMock
+ ->shouldReceive('setoptArray')
+ ->once()
+ ->andReturn(null);
+ $this->curlMock
+ ->shouldReceive('exec')
+ ->once()
+ ->andReturn($this->fakeRawHeader . $this->fakeRawBody);
+ $this->curlMock
+ ->shouldReceive('errno')
+ ->once()
+ ->andReturn(null);
+ $this->curlMock
+ ->shouldReceive('getinfo')
+ ->with(CURLINFO_HEADER_SIZE)
+ ->once()
+ ->andReturn(mb_strlen($this->fakeRawHeader));
+ $this->curlMock
+ ->shouldReceive('version')
+ ->once()
+ ->andReturn(['version_number' => self::CURL_VERSION_STABLE]);
+ $this->curlMock
+ ->shouldReceive('close')
+ ->once()
+ ->andReturn(null);
+
+ $response = $this->curlClient->send('http://foo.com/', 'GET', '', [], 60);
+
+ $this->assertInstanceOf('Facebook\Http\GraphRawResponse', $response);
+ $this->assertEquals($this->fakeRawBody, $response->getBody());
+ $this->assertEquals($this->fakeHeadersAsArray, $response->getHeaders());
+ $this->assertEquals(200, $response->getHttpResponseCode());
+ }
+
+ /**
+ * @expectedException \Facebook\Exceptions\FacebookSDKException
+ */
+ public function testThrowsExceptionOnClientError()
+ {
+ $this->curlMock
+ ->shouldReceive('init')
+ ->once()
+ ->andReturn(null);
+ $this->curlMock
+ ->shouldReceive('setoptArray')
+ ->once()
+ ->andReturn(null);
+ $this->curlMock
+ ->shouldReceive('exec')
+ ->once()
+ ->andReturn(false);
+ $this->curlMock
+ ->shouldReceive('errno')
+ ->once()
+ ->andReturn(123);
+ $this->curlMock
+ ->shouldReceive('error')
+ ->once()
+ ->andReturn('Foo error');
+
+ $this->curlClient->send('http://foo.com/', 'GET', '', [], 60);
+ }
+}