aboutsummaryrefslogtreecommitdiffstats
path: root/tests/dbal
diff options
context:
space:
mode:
authorJoas Schilling <nickvergessen@gmx.de>2012-11-19 13:49:04 +0100
committerJoas Schilling <nickvergessen@gmx.de>2012-11-19 14:27:26 +0100
commita7404409a8376e7db9f295e5cf598ccee59523b5 (patch)
treeeb49cfa649f5bc8868ffe87ff6f26c8d2903602f /tests/dbal
parent41a95d2c646aba8d6a66ee046c532a51a9022784 (diff)
downloadforums-a7404409a8376e7db9f295e5cf598ccee59523b5.tar
forums-a7404409a8376e7db9f295e5cf598ccee59523b5.tar.gz
forums-a7404409a8376e7db9f295e5cf598ccee59523b5.tar.bz2
forums-a7404409a8376e7db9f295e5cf598ccee59523b5.tar.xz
forums-a7404409a8376e7db9f295e5cf598ccee59523b5.zip
[ticket/11219] Add unit test for inserting into a sequence column
PHPBB3-11219
Diffstat (limited to 'tests/dbal')
-rw-r--r--tests/dbal/write_sequence_test.php55
1 files changed, 55 insertions, 0 deletions
diff --git a/tests/dbal/write_sequence_test.php b/tests/dbal/write_sequence_test.php
new file mode 100644
index 0000000000..d2c30b4e89
--- /dev/null
+++ b/tests/dbal/write_sequence_test.php
@@ -0,0 +1,55 @@
+<?php
+/**
+*
+* @package testing
+* @copyright (c) 2012 phpBB Group
+* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
+*
+*/
+
+require_once dirname(__FILE__) . '/../../phpBB/includes/functions.php';
+
+class phpbb_dbal_write_sequence_test extends phpbb_database_test_case
+{
+ public function getDataSet()
+ {
+ return $this->createXMLDataSet(dirname(__FILE__).'/fixtures/three_users.xml');
+ }
+
+ static public function write_sequence_data()
+ {
+ return array(
+ array(
+ 'ticket/11219',
+ 4,
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider write_sequence_data
+ */
+ public function test_write_sequence($username, $expected)
+ {
+ $db = $this->new_dbal();
+
+ $sql = 'INSERT INTO phpbb_users ' . $db->sql_build_array('INSERT', array(
+ 'username' => $username,
+ 'username_clean' => $username,
+ 'user_permissions' => '',
+ 'user_sig' => '',
+ 'user_occ' => '',
+ 'user_interests' => '',
+ ));
+ $db->sql_query($sql);
+
+ $this->assertEquals($expected, $db->sql_nextid());
+
+ $sql = "SELECT user_id
+ FROM phpbb_users
+ WHERE username_clean = '" . $db->sql_escape($username) . "'";
+ $result = $db->sql_query_limit($sql, 1);
+
+ $this->assertEquals($expected, $db->sql_fetchfield('user_id'));
+ }
+}