aboutsummaryrefslogtreecommitdiffstats
path: root/tests/config/db_text_test.php
diff options
context:
space:
mode:
authorAndreas Fischer <bantu@phpbb.com>2013-03-05 03:10:57 +0100
committerAndreas Fischer <bantu@phpbb.com>2013-03-05 22:59:57 +0100
commit828c6c01bb3ffff4d58f1bea1aad82663d656f2c (patch)
tree7b439a00639fbb5f7078c5a53621bfabb2337d25 /tests/config/db_text_test.php
parenta73b76cb24bcbde96735d343d2a22e6723de8390 (diff)
downloadforums-828c6c01bb3ffff4d58f1bea1aad82663d656f2c.tar
forums-828c6c01bb3ffff4d58f1bea1aad82663d656f2c.tar.gz
forums-828c6c01bb3ffff4d58f1bea1aad82663d656f2c.tar.bz2
forums-828c6c01bb3ffff4d58f1bea1aad82663d656f2c.tar.xz
forums-828c6c01bb3ffff4d58f1bea1aad82663d656f2c.zip
[ticket/10202] Add tests for phpbb_config_db_text.
PHPBB3-10202
Diffstat (limited to 'tests/config/db_text_test.php')
-rw-r--r--tests/config/db_text_test.php115
1 files changed, 115 insertions, 0 deletions
diff --git a/tests/config/db_text_test.php b/tests/config/db_text_test.php
new file mode 100644
index 0000000000..03e581fead
--- /dev/null
+++ b/tests/config/db_text_test.php
@@ -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_all_empty()
+ {
+ $this->assertEmpty($this->config_text->get_all(array('key1', 'key2')));
+ }
+
+ public function test_get_all_subset()
+ {
+ $expected = array(
+ 'bar' => '42',
+ 'foo' => '23',
+ );
+
+ $actual = $this->config_text->get_all(array_keys($expected));
+ ksort($actual);
+
+ $this->assertSame($expected, $actual);
+ }
+
+ public function test_set_all_get_all_subset()
+ {
+ $set_all_param = array(
+ // New entry
+ 'baby' => 'phpBB',
+ // Entry update
+ 'bar' => '64',
+ );
+
+ $this->config_text->set_all($set_all_param);
+
+ $expected = array_merge($set_all_param, array(
+ 'foo' => '23',
+ ));
+
+ $actual = $this->config_text->get_all(array_keys($expected));
+ ksort($actual);
+
+ $this->assertSame($expected, $actual);
+ }
+
+ public function test_delete_all_get_remaining()
+ {
+ $this->config_text->delete_all(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'));
+ }
+}