aboutsummaryrefslogtreecommitdiffstats
path: root/tests/test_framework
diff options
context:
space:
mode:
authorNils Adermann <naderman@naderman.de>2011-10-14 17:10:21 +0200
committerNils Adermann <naderman@naderman.de>2011-10-14 17:23:31 +0200
commita3928bf82d7fd6a1da074716c08c547afc961346 (patch)
tree0ad5cd4b50869cf6d8100324cf2cc49751b98bac /tests/test_framework
parent0ffe494edd274647ba6694648dba070c63e55d89 (diff)
downloadforums-a3928bf82d7fd6a1da074716c08c547afc961346.tar
forums-a3928bf82d7fd6a1da074716c08c547afc961346.tar.gz
forums-a3928bf82d7fd6a1da074716c08c547afc961346.tar.bz2
forums-a3928bf82d7fd6a1da074716c08c547afc961346.tar.xz
forums-a3928bf82d7fd6a1da074716c08c547afc961346.zip
[feature/functional-tests] Generate config correctly and install only once
PHPBB3-10414
Diffstat (limited to 'tests/test_framework')
-rw-r--r--tests/test_framework/phpbb_functional_test_case.php65
-rw-r--r--tests/test_framework/phpbb_test_case_helpers.php7
2 files changed, 48 insertions, 24 deletions
diff --git a/tests/test_framework/phpbb_functional_test_case.php b/tests/test_framework/phpbb_functional_test_case.php
index 02d51d71de..a8601f346c 100644
--- a/tests/test_framework/phpbb_functional_test_case.php
+++ b/tests/test_framework/phpbb_functional_test_case.php
@@ -8,18 +8,25 @@
*/
require_once __DIR__ . '/../../vendor/goutte.phar';
+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;
+ static protected $config = array();
+ static protected $already_installed = false;
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 = $_SERVER['PHPBB_FUNCTIONAL_URL'];
+ $this->root_url = self::$config['phpbb_functional_url'];
}
public function request($method, $path)
@@ -27,7 +34,29 @@ class phpbb_functional_test_case extends phpbb_test_case
return $this->client->request($method, $this->root_url . $path);
}
- static public function setUpBeforeClass()
+ public function __construct($name = NULL, array $data = array(), $dataName = '')
+ {
+ parent::__construct($name, $data, $dataName);
+
+ $this->backupStaticAttributesBlacklist += array(
+ 'PHP_CodeCoverage' => array('instance'),
+ 'PHP_CodeCoverage_Filter' => array('instance'),
+ 'PHP_CodeCoverage_Util' => array('ignoredLines', 'templateMethods'),
+ 'PHP_Timer' => array('startTimes',),
+ 'PHP_Token_Stream' => array('customTokens'),
+ 'PHP_Token_Stream_CachingFactory' => array('cache'),
+
+ 'phpbb_functional_test_case' => array('config', 'already_installed'),
+ );
+
+ if (!self::$already_installed)
+ {
+ $this->install_board();
+ self::$already_installed = true;
+ }
+ }
+
+ protected function install_board()
{
global $phpbb_root_path, $phpEx;
@@ -35,11 +64,11 @@ class phpbb_functional_test_case extends phpbb_test_case
if (!isset(self::$config['phpbb_functional_url']))
{
- self::markTestSkipped('phpbb_functional_url was not set in test_config and wasn\'t set as PHPBB_FUNCTIONAL_URL environment variable either.');
+ return;
}
self::$config['table_prefix'] = 'phpbb_';
- self::recreate_database(self::$config);
+ $this->recreate_database(self::$config);
if (file_exists($phpbb_root_path . "config.$phpEx"))
{
@@ -85,29 +114,21 @@ class phpbb_functional_test_case extends phpbb_test_case
));
// end data
- $content = self::do_request('install');
- self::assertContains('Welcome to Installation', $content);
+ $content = $this->do_request('install');
+ $this->assertContains('Welcome to Installation', $content);
- self::do_request('create_table', $data);
+ $this->do_request('create_table', $data);
- self::do_request('config_file', $data);
+ file_put_contents($phpbb_root_path . "config.$phpEx", phpbb_create_config_file_data($data, self::$config['dbms'], array(), true));
- if (file_exists($phpbb_root_path . "config.$phpEx"))
- {
- copy($phpbb_root_path . "config.$phpEx", $phpbb_root_path . "config_test.$phpEx");
- }
+ $this->do_request('config_file', $data);
- self::do_request('final', $data);
- }
-
- static public function tearDownAfterClass()
- {
- global $phpbb_root_path, $phpEx;
+ copy($phpbb_root_path . "config.$phpEx", $phpbb_root_path . "config_test.$phpEx");
- copy($phpbb_root_path . "config_dev.$phpEx", $phpbb_root_path . "config.$phpEx");
+ $this->do_request('final', $data);
}
- static private function do_request($sub, $post_data = null)
+ private function do_request($sub, $post_data = null)
{
$context = null;
@@ -126,7 +147,7 @@ class phpbb_functional_test_case extends phpbb_test_case
return file_get_contents(self::$config['phpbb_functional_url'] . 'install/index.php?mode=install&sub=' . $sub, false, $context);
}
- static private function recreate_database($config)
+ private function recreate_database($config)
{
$db_conn_mgr = new phpbb_database_test_connection_manager($config);
$db_conn_mgr->recreate_db();
diff --git a/tests/test_framework/phpbb_test_case_helpers.php b/tests/test_framework/phpbb_test_case_helpers.php
index cbfb2540c2..9177a443ab 100644
--- a/tests/test_framework/phpbb_test_case_helpers.php
+++ b/tests/test_framework/phpbb_test_case_helpers.php
@@ -58,7 +58,6 @@ class phpbb_test_case_helpers
'dbname' => '',
'dbuser' => '',
'dbpasswd' => '',
- 'phpbb_functional_url' => 'http://localhost/',
);
}
@@ -73,8 +72,12 @@ class phpbb_test_case_helpers
'dbname' => $dbname,
'dbuser' => $dbuser,
'dbpasswd' => $dbpasswd,
- 'phpbb_functional_url' => isset($phpbb_functional_url) ? $phpbb_functional_url : 'http://localhost/',
));
+
+ if (isset($phpbb_functional_url))
+ {
+ $config['phpbb_functional_url'] = $phpbb_functional_url;
+ }
}
if (isset($_SERVER['PHPBB_TEST_DBMS']))