summaryrefslogtreecommitdiff
path: root/ext/sysvmsg/tests
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@baserock.org>2013-03-14 05:42:27 +0000
committer <>2013-04-03 16:25:08 +0000
commitc4dd7a1a684490673e25aaf4fabec5df138854c4 (patch)
tree4d57c44caae4480efff02b90b9be86f44bf25409 /ext/sysvmsg/tests
downloadphp2-master.tar.gz
Imported from /home/lorry/working-area/delta_php2/php-5.4.13.tar.bz2.HEADphp-5.4.13master
Diffstat (limited to 'ext/sysvmsg/tests')
-rw-r--r--ext/sysvmsg/tests/001.phpt22
-rw-r--r--ext/sysvmsg/tests/002.phpt23
-rw-r--r--ext/sysvmsg/tests/003.phpt25
-rw-r--r--ext/sysvmsg/tests/004.phpt59
-rw-r--r--ext/sysvmsg/tests/005.phpt71
-rw-r--r--ext/sysvmsg/tests/006.phpt69
6 files changed, 269 insertions, 0 deletions
diff --git a/ext/sysvmsg/tests/001.phpt b/ext/sysvmsg/tests/001.phpt
new file mode 100644
index 0000000..d3a5b1e
--- /dev/null
+++ b/ext/sysvmsg/tests/001.phpt
@@ -0,0 +1,22 @@
+--TEST--
+send/receive serialized message.
+--SKIPIF--
+<?php // vim600:syn=php
+if (!extension_loaded("sysvmsg")) print "skip"; ?>
+--FILE--
+<?php
+$key = ftok(dirname(__FILE__) . "/001.phpt", "p");
+$q = msg_get_queue($key);
+msg_send($q, 1, "hello") or print "FAIL\n";
+$type = null;
+if (msg_receive($q, 0, $type, 1024, $message)) {
+ echo "TYPE: $type\n";
+ echo "DATA: $message\n";
+}
+if (!msg_remove_queue($q)) {
+ echo "BAD: queue removal failed\n";
+}
+?>
+--EXPECT--
+TYPE: 1
+DATA: hello
diff --git a/ext/sysvmsg/tests/002.phpt b/ext/sysvmsg/tests/002.phpt
new file mode 100644
index 0000000..e603ed0
--- /dev/null
+++ b/ext/sysvmsg/tests/002.phpt
@@ -0,0 +1,23 @@
+--TEST--
+msg_receive() should return false when unserialize() failed
+--SKIPIF--
+<?php if (!extension_loaded("sysvmsg")) die("skip sysvmsg extenions is not available")?>
+--FILE--
+<?php
+
+$queue = msg_get_queue (ftok(__FILE__, 'r'), 0600);
+if (!msg_send ($queue, 1, 'Hi', false /* ! no_ser*/, true/*block*/, $msg_err)) {
+ die("error\n");
+}
+var_dump($res = msg_receive ($queue, 1, $msg_type, 16384, $msg, true, 0, $msg_error));
+
+if (!msg_remove_queue($queue)) {
+ echo "BAD: queue removal failed\n";
+}
+
+echo "Done\n";
+?>
+--EXPECTF--
+Warning: msg_receive(): message corrupted in %s002.php on line %d
+bool(false)
+Done
diff --git a/ext/sysvmsg/tests/003.phpt b/ext/sysvmsg/tests/003.phpt
new file mode 100644
index 0000000..66ff046
--- /dev/null
+++ b/ext/sysvmsg/tests/003.phpt
@@ -0,0 +1,25 @@
+--TEST--
+msg_queue_exists()
+--SKIPIF--
+<?php if (!extension_loaded("sysvmsg")) die("skip sysvmsg extension is not available")?>
+--FILE--
+<?php
+$id = ftok(__FILE__, 'r');
+
+msg_remove_queue(msg_get_queue($id, 0600));
+
+var_dump(msg_queue_exists($id));
+$res = msg_get_queue($id, 0600);
+var_dump($res);
+var_dump(msg_queue_exists($id));
+var_dump(msg_remove_queue($res));
+var_dump(msg_queue_exists($id));
+echo "Done\n";
+?>
+--EXPECTF--
+bool(false)
+resource(%d) of type (sysvmsg queue)
+bool(true)
+bool(true)
+bool(false)
+Done
diff --git a/ext/sysvmsg/tests/004.phpt b/ext/sysvmsg/tests/004.phpt
new file mode 100644
index 0000000..39467d7
--- /dev/null
+++ b/ext/sysvmsg/tests/004.phpt
@@ -0,0 +1,59 @@
+--TEST--
+msg_set_queue() and msg_stat_queue()
+--SKIPIF--
+<?php if (!extension_loaded("sysvmsg")) die("skip sysvmsg extension is not available")?>
+--FILE--
+<?php
+$id = ftok(__FILE__, 'r');
+
+$q = msg_get_queue($id);
+
+echo "Set mode:\n";
+$arr = array('msg_perm.mode' => 0600);
+var_dump(msg_set_queue($q, $arr));
+echo "Did really work:\n";
+var_dump(count(array_diff_assoc($arr, msg_stat_queue($q))) == 0);
+
+echo "Set uid:\n"; // same as the running user to make it succeed
+$arr = array('msg_perm.uid' => getmyuid());
+var_dump(msg_set_queue($q, $arr));
+echo "Did really work:\n";
+var_dump(count(array_diff_assoc($arr, msg_stat_queue($q))) == 0);
+
+echo "Set gid:\n"; // same as the running user to make it succeed
+$arr = array('msg_perm.gid' => getmygid());
+var_dump(msg_set_queue($q, $arr));
+echo "Did really work:\n";
+var_dump(count(array_diff_assoc($arr, msg_stat_queue($q))) == 0);
+
+echo "Set smaller qbytes:\n";
+$res = msg_stat_queue($q);
+$arr = array('msg_qbytes' => ($res['msg_qbytes'] -1));
+var_dump(msg_set_queue($q, $arr));
+echo "Did really work:\n";
+var_dump(count(array_diff_assoc($arr, msg_stat_queue($q))) == 0);
+
+if (!msg_remove_queue($q)) {
+ echo "BAD: queue removal failed\n";
+}
+
+echo "Done\n";
+?>
+--EXPECTF--
+Set mode:
+bool(true)
+Did really work:
+bool(true)
+Set uid:
+bool(true)
+Did really work:
+bool(true)
+Set gid:
+bool(true)
+Did really work:
+bool(true)
+Set smaller qbytes:
+bool(true)
+Did really work:
+bool(true)
+Done
diff --git a/ext/sysvmsg/tests/005.phpt b/ext/sysvmsg/tests/005.phpt
new file mode 100644
index 0000000..d9437c6
--- /dev/null
+++ b/ext/sysvmsg/tests/005.phpt
@@ -0,0 +1,71 @@
+--TEST--
+sysvmsg functions on non-existing queue
+--SKIPIF--
+<?php if (!extension_loaded("sysvmsg")) die("skip sysvmsg extension is not available")?>
+--FILE--
+<?php
+
+$tests = array(null, 'foo');
+
+foreach ($tests as $q) {
+
+ if ($q === null) {
+ do {
+ $id = ftok(__FILE__, chr(mt_rand(0, 255)));
+ } while (msg_queue_exists($id));
+
+ $q = msg_get_queue($id) or die("Failed to create queue");
+ msg_remove_queue($q) or die("Failed to close queue");
+ }
+
+ echo "Using '$q' as queue resource:\n";
+
+ $errno = 0;
+
+ var_dump(msg_set_queue($q, array('msg_qbytes' => 1)));
+
+ var_dump(msg_stat_queue($q));
+
+ var_dump(msg_receive($q, 0, $null, 1, $msg, true, 0, $errno));
+ var_dump($errno != 0);
+ // again, but triggering an E_WARNING
+ var_dump(msg_receive($q, 0, $null, 0, $msg));
+
+ var_dump(msg_send($q, 1, 'foo', true, true, $errno));
+ var_dump($errno != 0);
+}
+
+echo "Done\n";
+?>
+--EXPECTF--
+Using 'Resource id #4' as queue resource:
+bool(false)
+bool(false)
+bool(false)
+bool(true)
+
+Warning: msg_receive(): maximum size of the message has to be greater than zero in %s on line %d
+bool(false)
+
+Warning: msg_send(): msgsnd failed: Invalid argument in %s on line %d
+bool(false)
+bool(true)
+Using 'foo' as queue resource:
+
+Warning: msg_set_queue() expects parameter 1 to be resource, string given in %s on line %d
+bool(false)
+
+Warning: msg_stat_queue() expects parameter 1 to be resource, string given in %s on line %d
+bool(false)
+
+Warning: msg_receive() expects parameter 1 to be resource, string given in %s on line %d
+bool(false)
+bool(false)
+
+Warning: msg_receive() expects parameter 1 to be resource, string given in %s on line %d
+bool(false)
+
+Warning: msg_send() expects parameter 1 to be resource, string given in %s on line %d
+bool(false)
+bool(false)
+Done
diff --git a/ext/sysvmsg/tests/006.phpt b/ext/sysvmsg/tests/006.phpt
new file mode 100644
index 0000000..cb4fd24
--- /dev/null
+++ b/ext/sysvmsg/tests/006.phpt
@@ -0,0 +1,69 @@
+--TEST--
+msg_send() data types when not serializing
+--SKIPIF--
+<?php if (!extension_loaded("sysvmsg")) die("skip sysvmsg extenions is not available")?>
+--FILE--
+<?php
+
+$queue = msg_get_queue (ftok(__FILE__, 'r'), 0600);
+
+$tests = array('foo', 123, PHP_INT_MAX +1, true, 1.01, null, array('bar'));
+
+foreach ($tests as $elem) {
+ echo @"Sending/receiving '$elem':\n";
+ var_dump(msg_send($queue, 1, $elem, false));
+
+ unset($msg);
+ var_dump(msg_receive($queue, 1, $msg_type, 1024, $msg, false, MSG_IPC_NOWAIT));
+
+ var_dump($elem == $msg);
+ var_dump($elem === $msg);
+}
+
+if (!msg_remove_queue($queue)) {
+ echo "BAD: queue removal failed\n";
+}
+
+echo "Done\n";
+?>
+--EXPECTF--
+Sending/receiving 'foo':
+bool(true)
+bool(true)
+bool(true)
+bool(true)
+Sending/receiving '123':
+bool(true)
+bool(true)
+bool(true)
+bool(false)
+Sending/receiving '%s':
+bool(true)
+bool(true)
+bool(true)
+bool(false)
+Sending/receiving '1':
+bool(true)
+bool(true)
+bool(true)
+bool(false)
+Sending/receiving '1.01':
+bool(true)
+bool(true)
+bool(true)
+bool(false)
+Sending/receiving '':
+
+Warning: msg_send(): Message parameter must be either a string or a number. in %s on line %d
+bool(false)
+bool(false)
+bool(true)
+bool(false)
+Sending/receiving 'Array':
+
+Warning: msg_send(): Message parameter must be either a string or a number. in %s on line %d
+bool(false)
+bool(false)
+bool(false)
+bool(false)
+Done