mirror of
https://github.com/phpbb/phpbb.git
synced 2025-08-09 10:16:36 +02:00
Merge branch 'develop' of https://github.com/phpbb/phpbb3 into feature/softdelete-1-permission
* 'develop' of https://github.com/phpbb/phpbb3: [ticket/11408] user_jabber instead of jabber [ticket/10202] Rename method names _all() to _array(). [ticket/10202] Add migration file for config_db_text. [ticket/10202] Upgrade TEXT to the bigger MTEXT. [ticket/10202] Improve method documentation. [ticket/10202] SQL escape the table name. [ticket/10202] Add $this->db->sql_freeresult($result) to SELECT queries. [ticket/10202] Define phpbb_config_db_text as a service. [ticket/10202] Add tests for phpbb_config_db_text. [ticket/10202] Adjust method names to guidelines. [ticket/10202] Add database schema for phpbb_config_db_text. [ticket/10202] Implementation of config options with arbitrary length values. [ticket/11166] Add ajaxify support to normal ACP confirm_box() [ticket/11166] Fix several custom confirm templates in prosilver [ticket/11166] Add caption to AJAX confirm box default template [ticket/11166] Fix typo in comment [ticket/11166] Use provided custom templates on AJAX confirm box
This commit is contained in:
115
tests/config/db_text_test.php
Normal file
115
tests/config/db_text_test.php
Normal file
@@ -0,0 +1,115 @@
|
||||
<?php
|
||||
/**
|
||||
*
|
||||
* @package testing
|
||||
* @copyright (c) 2013 phpBB Group
|
||||
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
||||
*
|
||||
*/
|
||||
|
||||
class phpbb_config_db_text_test extends phpbb_database_test_case
|
||||
{
|
||||
private $db;
|
||||
private $config_text;
|
||||
|
||||
public function getDataSet()
|
||||
{
|
||||
return $this->createXMLDataSet(dirname(__FILE__) . '/fixtures/config_text.xml');
|
||||
}
|
||||
|
||||
public function setUp()
|
||||
{
|
||||
parent::setUp();
|
||||
|
||||
$this->db = $this->new_dbal();
|
||||
$this->config_text = new phpbb_config_db_text($this->db, 'phpbb_config_text');
|
||||
}
|
||||
|
||||
public function test_get()
|
||||
{
|
||||
$this->assertSame('23', $this->config_text->get('foo'));
|
||||
$this->assertSame('string-de-ding', $this->config_text->get('meh'));
|
||||
}
|
||||
|
||||
public function test_get_nonexisting()
|
||||
{
|
||||
$this->assertNull($this->config_text->get('noooooo'));
|
||||
}
|
||||
|
||||
public function test_set_new_get()
|
||||
{
|
||||
$this->config_text->set('barz', 'phpbb');
|
||||
$this->assertSame('phpbb', $this->config_text->get('barz'));
|
||||
}
|
||||
|
||||
public function test_set_replace_get()
|
||||
{
|
||||
$this->config_text->set('foo', '24');
|
||||
$this->assertSame('24', $this->config_text->get('foo'));
|
||||
}
|
||||
|
||||
public function test_set_get_long_string()
|
||||
{
|
||||
$expected = str_repeat('ABC', 10000);
|
||||
$this->config_text->set('long', $expected);
|
||||
$this->assertSame($expected, $this->config_text->get('long'));
|
||||
}
|
||||
|
||||
public function test_delete_get()
|
||||
{
|
||||
$this->config_text->delete('foo');
|
||||
$this->assertNull($this->config_text->get('foo'));
|
||||
|
||||
$this->assertSame('42', $this->config_text->get('bar'));
|
||||
$this->assertSame('string-de-ding', $this->config_text->get('meh'));
|
||||
}
|
||||
|
||||
public function test_get_array_empty()
|
||||
{
|
||||
$this->assertEmpty($this->config_text->get_array(array('key1', 'key2')));
|
||||
}
|
||||
|
||||
public function test_get_array_subset()
|
||||
{
|
||||
$expected = array(
|
||||
'bar' => '42',
|
||||
'foo' => '23',
|
||||
);
|
||||
|
||||
$actual = $this->config_text->get_array(array_keys($expected));
|
||||
ksort($actual);
|
||||
|
||||
$this->assertSame($expected, $actual);
|
||||
}
|
||||
|
||||
public function test_set_array_get_array_subset()
|
||||
{
|
||||
$set_array_param = array(
|
||||
// New entry
|
||||
'baby' => 'phpBB',
|
||||
// Entry update
|
||||
'bar' => '64',
|
||||
);
|
||||
|
||||
$this->config_text->set_array($set_array_param);
|
||||
|
||||
$expected = array_merge($set_array_param, array(
|
||||
'foo' => '23',
|
||||
));
|
||||
|
||||
$actual = $this->config_text->get_array(array_keys($expected));
|
||||
ksort($actual);
|
||||
|
||||
$this->assertSame($expected, $actual);
|
||||
}
|
||||
|
||||
public function test_delete_array_get_remaining()
|
||||
{
|
||||
$this->config_text->delete_array(array('foo', 'bar'));
|
||||
|
||||
$this->assertNull($this->config_text->get('bar'));
|
||||
$this->assertNull($this->config_text->get('foo'));
|
||||
|
||||
$this->assertSame('string-de-ding', $this->config_text->get('meh'));
|
||||
}
|
||||
}
|
19
tests/config/fixtures/config_text.xml
Normal file
19
tests/config/fixtures/config_text.xml
Normal file
@@ -0,0 +1,19 @@
|
||||
<?xml version="1.0" encoding="UTF-8" ?>
|
||||
<dataset>
|
||||
<table name="phpbb_config_text">
|
||||
<column>config_name</column>
|
||||
<column>config_value</column>
|
||||
<row>
|
||||
<value>foo</value>
|
||||
<value>23</value>
|
||||
</row>
|
||||
<row>
|
||||
<value>bar</value>
|
||||
<value>42</value>
|
||||
</row>
|
||||
<row>
|
||||
<value>meh</value>
|
||||
<value>string-de-ding</value>
|
||||
</row>
|
||||
</table>
|
||||
</dataset>
|
Reference in New Issue
Block a user