mirror of
https://github.com/phpbb/phpbb.git
synced 2025-01-18 22:58:10 +01:00
Merge branch 'develop-olympus' into develop
# By Andreas Fischer # Via Andreas Fischer (1) and Nathan Guse (1) * develop-olympus: [ticket/11619] Use HTTP/1.0 because of lack of chunked-encoding handling. [ticket/11619] Some tests for get_remote_file().
This commit is contained in:
commit
e03586f2cf
@ -2899,7 +2899,7 @@ function get_remote_file($host, $directory, $filename, &$errstr, &$errno, $port
|
|||||||
|
|
||||||
if ($fsock = @fsockopen($host, $port, $errno, $errstr, $timeout))
|
if ($fsock = @fsockopen($host, $port, $errno, $errstr, $timeout))
|
||||||
{
|
{
|
||||||
@fputs($fsock, "GET $directory/$filename HTTP/1.1\r\n");
|
@fputs($fsock, "GET $directory/$filename HTTP/1.0\r\n");
|
||||||
@fputs($fsock, "HOST: $host\r\n");
|
@fputs($fsock, "HOST: $host\r\n");
|
||||||
@fputs($fsock, "Connection: close\r\n\r\n");
|
@fputs($fsock, "Connection: close\r\n\r\n");
|
||||||
|
|
||||||
|
75
tests/functions/get_remote_file_test.php
Normal file
75
tests/functions/get_remote_file_test.php
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @package testing
|
||||||
|
* @copyright (c) 2013 phpBB Group
|
||||||
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
require_once dirname(__FILE__) . '/../../phpBB/includes/functions.php';
|
||||||
|
require_once dirname(__FILE__) . '/../../phpBB/includes/functions_admin.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group slow
|
||||||
|
*/
|
||||||
|
class phpbb_functions_get_remote_file extends phpbb_test_case
|
||||||
|
{
|
||||||
|
public function test_version_phpbb_com()
|
||||||
|
{
|
||||||
|
$hostname = 'version.phpbb.com';
|
||||||
|
|
||||||
|
if (!phpbb_checkdnsrr($hostname, 'A'))
|
||||||
|
{
|
||||||
|
$this->markTestSkipped(sprintf(
|
||||||
|
'Could not find a DNS record for hostname %s. ' .
|
||||||
|
'Assuming network is down.',
|
||||||
|
$hostname
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
$errstr = $errno = null;
|
||||||
|
$file = get_remote_file($hostname, '/phpbb', '30x.txt', $errstr, $errno);
|
||||||
|
|
||||||
|
$this->assertNotEquals(
|
||||||
|
0,
|
||||||
|
strlen($file),
|
||||||
|
'Failed asserting that the response is not empty.'
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
'',
|
||||||
|
$errstr,
|
||||||
|
'Failed asserting that the error string is empty.'
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
0,
|
||||||
|
$errno,
|
||||||
|
'Failed asserting that the error number is 0 (i.e. no error occurred).'
|
||||||
|
);
|
||||||
|
|
||||||
|
$lines = explode("\n", $file);
|
||||||
|
|
||||||
|
$this->assertGreaterThanOrEqual(
|
||||||
|
2,
|
||||||
|
sizeof($lines),
|
||||||
|
'Failed asserting that the version file has at least two lines.'
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertStringStartsWith(
|
||||||
|
'3.',
|
||||||
|
$lines[0],
|
||||||
|
"Failed asserting that the first line of the version file starts with '3.'"
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertNotSame(
|
||||||
|
false,
|
||||||
|
filter_var($lines[1], FILTER_VALIDATE_URL),
|
||||||
|
'Failed asserting that the second line of the version file is a valid URL.'
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertContains('http', $lines[1]);
|
||||||
|
$this->assertContains('phpbb.com', $lines[1], '', true);
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user