summaryrefslogtreecommitdiff
path: root/ext/sqlite
diff options
context:
space:
mode:
authorWez Furlong <wez@php.net>2003-04-20 13:08:40 +0000
committerWez Furlong <wez@php.net>2003-04-20 13:08:40 +0000
commit7360c5dfdd7ca8339d9b6fdaa76df544a12f6c3c (patch)
tree385dba4e62c80c12c42ee5840c7027fa29d04ed5 /ext/sqlite
parent4a468826484894fc56e0e475f3447e261e5a8692 (diff)
downloadphp-git-7360c5dfdd7ca8339d9b6fdaa76df544a12f6c3c.tar.gz
Add test for aggregates
Diffstat (limited to 'ext/sqlite')
-rw-r--r--ext/sqlite/tests/sqlite_005.phpt45
1 files changed, 45 insertions, 0 deletions
diff --git a/ext/sqlite/tests/sqlite_005.phpt b/ext/sqlite/tests/sqlite_005.phpt
new file mode 100644
index 0000000000..4f37c943c7
--- /dev/null
+++ b/ext/sqlite/tests/sqlite_005.phpt
@@ -0,0 +1,45 @@
+--TEST--
+sqlite: aggregate functions
+--SKIPIF--
+<?php # vim:ft=php
+if (!extension_loaded("sqlite")) print "skip"; ?>
+--FILE--
+<?php
+include "blankdb.inc";
+
+$data = array(
+ "one",
+ "two",
+ "three"
+ );
+
+sqlite_query("CREATE TABLE strings(a)", $db);
+
+foreach ($data as $str) {
+ sqlite_query("INSERT INTO strings VALUES('" . sqlite_escape_string($str) . "')", $db);
+}
+
+function cat_step(&$context, $string)
+{
+ $context .= $string;
+}
+
+function cat_fin(&$context)
+{
+ return $context;
+}
+
+sqlite_create_aggregate($db, "cat", "cat_step", "cat_fin");
+
+$r = sqlite_query("SELECT cat(a) from strings", $db);
+while ($row = sqlite_fetch_array($r, SQLITE_NUM)) {
+ var_dump($row);
+}
+echo "DONE!\n";
+?>
+--EXPECT--
+array(1) {
+ [0]=>
+ string(11) "onetwothree"
+}
+DONE!