mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-07 20:08:53 +00:00
[ticket/10492] Backporting functional tests
PHPBB3-10492
This commit is contained in:
parent
de70b17b1d
commit
2aa994b5ad
8 changed files with 251 additions and 0 deletions
|
@ -14,6 +14,10 @@
|
||||||
<testsuites>
|
<testsuites>
|
||||||
<testsuite name="phpBB Test Suite">
|
<testsuite name="phpBB Test Suite">
|
||||||
<directory suffix="_test.php">./tests/</directory>
|
<directory suffix="_test.php">./tests/</directory>
|
||||||
|
<exclude>./tests/functional</exclude>
|
||||||
|
</testsuite>
|
||||||
|
<testsuite name="phpBB Functional Tests">
|
||||||
|
<directory suffix="_test.php" phpVersion="5.3.0" phpVersionOperator=">=">./tests/functional</directory>
|
||||||
</testsuite>
|
</testsuite>
|
||||||
</testsuites>
|
</testsuites>
|
||||||
|
|
||||||
|
|
|
@ -14,11 +14,16 @@
|
||||||
<testsuites>
|
<testsuites>
|
||||||
<testsuite name="phpBB Test Suite">
|
<testsuite name="phpBB Test Suite">
|
||||||
<directory suffix="_test.php">./tests/</directory>
|
<directory suffix="_test.php">./tests/</directory>
|
||||||
|
<exclude>./tests/functional</exclude>
|
||||||
|
</testsuite>
|
||||||
|
<testsuite name="phpBB Functional Tests">
|
||||||
|
<directory suffix="_test.php" phpVersion="5.3.0" phpVersionOperator=">=">./tests/functional</directory>
|
||||||
</testsuite>
|
</testsuite>
|
||||||
</testsuites>
|
</testsuites>
|
||||||
|
|
||||||
<groups>
|
<groups>
|
||||||
<exclude>
|
<exclude>
|
||||||
|
<group>functional</group>
|
||||||
<group>slow</group>
|
<group>slow</group>
|
||||||
</exclude>
|
</exclude>
|
||||||
</groups>
|
</groups>
|
||||||
|
|
35
phpunit.xml.functional
Normal file
35
phpunit.xml.functional
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
|
||||||
|
<phpunit backupGlobals="true"
|
||||||
|
backupStaticAttributes="true"
|
||||||
|
colors="true"
|
||||||
|
convertErrorsToExceptions="true"
|
||||||
|
convertNoticesToExceptions="true"
|
||||||
|
convertWarningsToExceptions="true"
|
||||||
|
processIsolation="false"
|
||||||
|
stopOnFailure="false"
|
||||||
|
syntaxCheck="false"
|
||||||
|
bootstrap="tests/bootstrap.php"
|
||||||
|
>
|
||||||
|
<testsuites>
|
||||||
|
<testsuite name="phpBB Test Suite">
|
||||||
|
<directory suffix="_test.php">./tests/</directory>
|
||||||
|
<exclude>./tests/functional</exclude>
|
||||||
|
</testsuite>
|
||||||
|
<testsuite name="phpBB Functional Tests">
|
||||||
|
<directory suffix="_test.php" phpVersion="5.3.0" phpVersionOperator=">=">./tests/functional</directory>
|
||||||
|
</testsuite>
|
||||||
|
</testsuites>
|
||||||
|
|
||||||
|
<groups>
|
||||||
|
<include>
|
||||||
|
<group>functional</group>
|
||||||
|
</include>
|
||||||
|
</groups>
|
||||||
|
|
||||||
|
<filter>
|
||||||
|
<blacklist>
|
||||||
|
<directory>./tests/</directory>
|
||||||
|
</blacklist>
|
||||||
|
</filter>
|
||||||
|
</phpunit>
|
|
@ -19,3 +19,8 @@ require_once 'test_framework/phpbb_test_case_helpers.php';
|
||||||
require_once 'test_framework/phpbb_test_case.php';
|
require_once 'test_framework/phpbb_test_case.php';
|
||||||
require_once 'test_framework/phpbb_database_test_case.php';
|
require_once 'test_framework/phpbb_database_test_case.php';
|
||||||
require_once 'test_framework/phpbb_database_test_connection_manager.php';
|
require_once 'test_framework/phpbb_database_test_connection_manager.php';
|
||||||
|
|
||||||
|
if (version_compare(PHP_VERSION, '5.3.0-dev', '>='))
|
||||||
|
{
|
||||||
|
require_once 'test_framework/phpbb_functional_test_case.php';
|
||||||
|
}
|
||||||
|
|
26
tests/functional/browse_test.php
Normal file
26
tests/functional/browse_test.php
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @package testing
|
||||||
|
* @copyright (c) 2011 phpBB Group
|
||||||
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group functional
|
||||||
|
*/
|
||||||
|
class phpbb_functional_browse_test extends phpbb_functional_test_case
|
||||||
|
{
|
||||||
|
public function test_index()
|
||||||
|
{
|
||||||
|
$crawler = $this->request('GET', 'index.php');
|
||||||
|
$this->assertGreaterThan(0, $crawler->filter('.topiclist')->count());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_viewforum()
|
||||||
|
{
|
||||||
|
$crawler = $this->request('GET', 'viewforum.php?f=2');
|
||||||
|
$this->assertGreaterThan(0, $crawler->filter('.topiclist')->count());
|
||||||
|
}
|
||||||
|
}
|
164
tests/test_framework/phpbb_functional_test_case.php
Normal file
164
tests/test_framework/phpbb_functional_test_case.php
Normal file
|
@ -0,0 +1,164 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @package testing
|
||||||
|
* @copyright (c) 2011 phpBB Group
|
||||||
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
require_once __DIR__ . '/../../phpBB/includes/functions_install.php';
|
||||||
|
|
||||||
|
class phpbb_functional_test_case extends phpbb_test_case
|
||||||
|
{
|
||||||
|
protected $client;
|
||||||
|
protected $root_url;
|
||||||
|
|
||||||
|
static protected $config = array();
|
||||||
|
static protected $already_installed = false;
|
||||||
|
|
||||||
|
static public function setUpBeforeClass()
|
||||||
|
{
|
||||||
|
if (!extension_loaded('phar'))
|
||||||
|
{
|
||||||
|
self::markTestSkipped('phar extension is not loaded');
|
||||||
|
}
|
||||||
|
|
||||||
|
require_once 'phar://' . __DIR__ . '/../../vendor/goutte.phar';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
if (!isset(self::$config['phpbb_functional_url']))
|
||||||
|
{
|
||||||
|
$this->markTestSkipped('phpbb_functional_url was not set in test_config and wasn\'t set as PHPBB_FUNCTIONAL_URL environment variable either.');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->client = new Goutte\Client();
|
||||||
|
$this->root_url = self::$config['phpbb_functional_url'];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function request($method, $path)
|
||||||
|
{
|
||||||
|
return $this->client->request($method, $this->root_url . $path);
|
||||||
|
}
|
||||||
|
|
||||||
|
// bootstrap, called after board is set up
|
||||||
|
// once per test case class
|
||||||
|
// test cases can override this
|
||||||
|
protected function bootstrap()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __construct($name = NULL, array $data = array(), $dataName = '')
|
||||||
|
{
|
||||||
|
parent::__construct($name, $data, $dataName);
|
||||||
|
|
||||||
|
$this->backupStaticAttributesBlacklist += array(
|
||||||
|
'phpbb_functional_test_case' => array('config', 'already_installed'),
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!static::$already_installed)
|
||||||
|
{
|
||||||
|
$this->install_board();
|
||||||
|
$this->bootstrap();
|
||||||
|
static::$already_installed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function install_board()
|
||||||
|
{
|
||||||
|
global $phpbb_root_path, $phpEx;
|
||||||
|
|
||||||
|
self::$config = phpbb_test_case_helpers::get_test_config();
|
||||||
|
|
||||||
|
if (!isset(self::$config['phpbb_functional_url']))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
self::$config['table_prefix'] = 'phpbb_';
|
||||||
|
$this->recreate_database(self::$config);
|
||||||
|
|
||||||
|
if (file_exists($phpbb_root_path . "config.$phpEx"))
|
||||||
|
{
|
||||||
|
if (!file_exists($phpbb_root_path . "config_dev.$phpEx"))
|
||||||
|
{
|
||||||
|
rename($phpbb_root_path . "config.$phpEx", $phpbb_root_path . "config_dev.$phpEx");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
unlink($phpbb_root_path . "config.$phpEx");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// begin data
|
||||||
|
$data = array();
|
||||||
|
|
||||||
|
$data = array_merge($data, self::$config);
|
||||||
|
|
||||||
|
$data = array_merge($data, array(
|
||||||
|
'default_lang' => 'en',
|
||||||
|
'admin_name' => 'admin',
|
||||||
|
'admin_pass1' => 'admin',
|
||||||
|
'admin_pass2' => 'admin',
|
||||||
|
'board_email' => 'nobody@example.com',
|
||||||
|
));
|
||||||
|
|
||||||
|
$parseURL = parse_url(self::$config['phpbb_functional_url']);
|
||||||
|
|
||||||
|
$data = array_merge($data, array(
|
||||||
|
'email_enable' => false,
|
||||||
|
'smtp_delivery' => false,
|
||||||
|
'smtp_host' => '',
|
||||||
|
'smtp_auth' => '',
|
||||||
|
'smtp_user' => '',
|
||||||
|
'smtp_pass' => '',
|
||||||
|
'cookie_secure' => false,
|
||||||
|
'force_server_vars' => false,
|
||||||
|
'server_protocol' => $parseURL['scheme'] . '://',
|
||||||
|
'server_name' => 'localhost',
|
||||||
|
'server_port' => isset($parseURL['port']) ? (int) $parseURL['port'] : 80,
|
||||||
|
'script_path' => $parseURL['path'],
|
||||||
|
));
|
||||||
|
// end data
|
||||||
|
|
||||||
|
$content = $this->do_request('install');
|
||||||
|
$this->assertContains('Welcome to Installation', $content);
|
||||||
|
|
||||||
|
$this->do_request('create_table', $data);
|
||||||
|
|
||||||
|
file_put_contents($phpbb_root_path . "config.$phpEx", phpbb_create_config_file_data($data, self::$config['dbms'], array(), true));
|
||||||
|
|
||||||
|
$this->do_request('config_file', $data);
|
||||||
|
|
||||||
|
copy($phpbb_root_path . "config.$phpEx", $phpbb_root_path . "config_test.$phpEx");
|
||||||
|
|
||||||
|
$this->do_request('final', $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function do_request($sub, $post_data = null)
|
||||||
|
{
|
||||||
|
$context = null;
|
||||||
|
|
||||||
|
if ($post_data)
|
||||||
|
{
|
||||||
|
$context = stream_context_create(array(
|
||||||
|
'http' => array(
|
||||||
|
'method' => 'POST',
|
||||||
|
'header' => 'Content-Type: application/x-www-form-urlencoded',
|
||||||
|
'content' => http_build_query($post_data),
|
||||||
|
'ignore_errors' => true,
|
||||||
|
),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
return file_get_contents(self::$config['phpbb_functional_url'] . 'install/index.php?mode=install&sub=' . $sub, false, $context);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function recreate_database($config)
|
||||||
|
{
|
||||||
|
$db_conn_mgr = new phpbb_database_test_connection_manager($config);
|
||||||
|
$db_conn_mgr->recreate_db();
|
||||||
|
}
|
||||||
|
}
|
|
@ -70,6 +70,11 @@ class phpbb_test_case_helpers
|
||||||
'dbuser' => $dbuser,
|
'dbuser' => $dbuser,
|
||||||
'dbpasswd' => $dbpasswd,
|
'dbpasswd' => $dbpasswd,
|
||||||
));
|
));
|
||||||
|
|
||||||
|
if (isset($phpbb_functional_url))
|
||||||
|
{
|
||||||
|
$config['phpbb_functional_url'] = $phpbb_functional_url;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($_SERVER['PHPBB_TEST_DBMS']))
|
if (isset($_SERVER['PHPBB_TEST_DBMS']))
|
||||||
|
@ -84,6 +89,13 @@ class phpbb_test_case_helpers
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (isset($_SERVER['PHPBB_FUNCTIONAL_URL']))
|
||||||
|
{
|
||||||
|
$config = array_merge($config, array(
|
||||||
|
'phpbb_functional_url' => isset($_SERVER['PHPBB_FUNCTIONAL_URL']) ? $_SERVER['PHPBB_FUNCTIONAL_URL'] : '',
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
return $config;
|
return $config;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
BIN
vendor/goutte.phar
vendored
Normal file
BIN
vendor/goutte.phar
vendored
Normal file
Binary file not shown.
Loading…
Add table
Reference in a new issue