mirror of
https://github.com/phpbb/phpbb.git
synced 2025-01-17 14:18:24 +01:00
[feature/functional-tests] Implementing functional test framework with goutte
PHPBB3-10414
This commit is contained in:
parent
37d9e7e30c
commit
637d8eabe7
@ -19,6 +19,7 @@
|
||||
|
||||
<groups>
|
||||
<exclude>
|
||||
<group>functional</group>
|
||||
<group>slow</group>
|
||||
</exclude>
|
||||
</groups>
|
||||
|
48
phpunit.xml.functional
Normal file
48
phpunit.xml.functional
Normal file
@ -0,0 +1,48 @@
|
||||
<?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>
|
||||
</testsuite>
|
||||
</testsuites>
|
||||
|
||||
<groups>
|
||||
<include>
|
||||
<group>functional</group>
|
||||
</include>
|
||||
</groups>
|
||||
|
||||
<filter>
|
||||
<blacklist>
|
||||
<directory>./tests/</directory>
|
||||
</blacklist>
|
||||
<whitelist>
|
||||
<directory suffix=".php">./phpBB/includes/</directory>
|
||||
<exclude>
|
||||
<file>./phpBB/includes/db/firebird.php</file>
|
||||
<file>./phpBB/includes/db/mysql.php</file>
|
||||
<file>./phpBB/includes/db/mysqli.php</file>
|
||||
<file>./phpBB/includes/db/mssql.php</file>
|
||||
<file>./phpBB/includes/db/mssql_odbc.php</file>
|
||||
<file>./phpBB/includes/db/mssqlnative.php</file>
|
||||
<file>./phpBB/includes/db/oracle.php</file>
|
||||
<file>./phpBB/includes/db/postgres.php</file>
|
||||
<file>./phpBB/includes/db/sqlite.php</file>
|
||||
<file>./phpBB/includes/search/fulltext_native.php</file>
|
||||
<file>./phpBB/includes/search/fulltext_mysql.php</file>
|
||||
<directory suffix=".php">./phpBB/includes/captcha/</directory>
|
||||
</exclude>
|
||||
</whitelist>
|
||||
</filter>
|
||||
</phpunit>
|
@ -39,3 +39,4 @@ require_once 'test_framework/phpbb_test_case_helpers.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_connection_manager.php';
|
||||
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-license.php GNU Public License
|
||||
*
|
||||
*/
|
||||
|
||||
/**
|
||||
* @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());
|
||||
}
|
||||
}
|
128
tests/test_framework/phpbb_functional_test_case.php
Normal file
128
tests/test_framework/phpbb_functional_test_case.php
Normal file
@ -0,0 +1,128 @@
|
||||
<?php
|
||||
/**
|
||||
*
|
||||
* @package testing
|
||||
* @copyright (c) 2011 phpBB Group
|
||||
* @license http://opensource.org/licenses/gpl-license.php GNU Public License
|
||||
*
|
||||
*/
|
||||
|
||||
require_once __DIR__ . '/../../vendor/goutte.phar';
|
||||
|
||||
class phpbb_functional_test_case extends phpbb_test_case
|
||||
{
|
||||
protected $client;
|
||||
protected $root_url;
|
||||
|
||||
public function setUp()
|
||||
{
|
||||
$this->client = new Goutte\Client();
|
||||
$this->root_url = $_SERVER['PHPBB_FUNCTIONAL_URL'];
|
||||
}
|
||||
|
||||
public function request($method, $path)
|
||||
{
|
||||
return $this->client->request($method, $this->root_url . $path);
|
||||
}
|
||||
|
||||
static public function setUpBeforeClass()
|
||||
{
|
||||
global $phpbb_root_path, $phpEx;
|
||||
|
||||
if (!isset($_SERVER['PHPBB_FUNCTIONAL_URL']))
|
||||
{
|
||||
self::markTestSkipped("The 'PHPBB_FUNCTIONAL_URL' environment variable was not set.");
|
||||
}
|
||||
|
||||
if (!file_exists($phpbb_root_path . "config.$phpEx"))
|
||||
{
|
||||
self::markTestSkipped("config.php does not exist, it is required for running functional tests.");
|
||||
}
|
||||
|
||||
require $phpbb_root_path . "config.$phpEx";
|
||||
|
||||
$db_config = array(
|
||||
'dbhost' => $dbhost,
|
||||
'dbport' => $dbport,
|
||||
'dbname' => $dbname,
|
||||
'dbuser' => $dbuser,
|
||||
'dbpasswd' => $dbpasswd,
|
||||
'dbms' => $dbms,
|
||||
'table_prefix' => 'phpbb_',
|
||||
);
|
||||
self::recreate_database($db_config);
|
||||
|
||||
rename($phpbb_root_path . "config.$phpEx", $phpbb_root_path . "_config.$phpEx");
|
||||
|
||||
// begin data
|
||||
$data = array();
|
||||
|
||||
$data = array_merge($data, $db_config);
|
||||
|
||||
$data = array_merge($data, array(
|
||||
'default_lang' => 'en',
|
||||
'admin_name' => 'admin',
|
||||
'admin_pass1' => 'admin',
|
||||
'admin_pass2' => 'admin',
|
||||
'board_email1' => 'nobody@example.com',
|
||||
'board_email2' => 'nobody@example.com',
|
||||
));
|
||||
|
||||
$parseURL = parse_url($_SERVER['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 = self::do_request('install');
|
||||
self::assertContains('Welcome to Installation', $content);
|
||||
|
||||
self::do_request('config_file', $data);
|
||||
|
||||
rename($phpbb_root_path . "_config.$phpEx", $phpbb_root_path . "config.$phpEx");
|
||||
|
||||
self::do_request('create_table', $data);
|
||||
self::do_request('final', $data);
|
||||
}
|
||||
|
||||
static public function tearDownAfterClass()
|
||||
{
|
||||
}
|
||||
|
||||
static 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($_SERVER['PHPBB_FUNCTIONAL_URL'] . 'install/index.php?mode=install&sub=' . $sub, false, $context);
|
||||
}
|
||||
|
||||
static private function recreate_database($config)
|
||||
{
|
||||
$db_conn_mgr = new phpbb_database_test_connection_manager($config);
|
||||
$db_conn_mgr->recreate_db();
|
||||
}
|
||||
}
|
BIN
vendor/goutte.phar
vendored
Normal file
BIN
vendor/goutte.phar
vendored
Normal file
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user