Was never committed to HEAD for some reason
authorTim Starling <tstarling@users.mediawiki.org>
Sat, 28 Jan 2006 08:22:24 +0000 (08:22 +0000)
committerTim Starling <tstarling@users.mediawiki.org>
Sat, 28 Jan 2006 08:22:24 +0000 (08:22 +0000)
maintenance/mctest.php [new file with mode: 0644]

diff --git a/maintenance/mctest.php b/maintenance/mctest.php
new file mode 100644 (file)
index 0000000..7deaa07
--- /dev/null
@@ -0,0 +1,59 @@
+<?php
+/* $Id$ */
+
+$optionsWithArgs = array( 'i' );
+
+require_once('commandLine.inc');
+
+#$wgDebugLogFile = '/dev/stdout';
+
+if ( isset( $args[0] ) ) {
+       $wgMemCachedServers = array( $args[0] );
+} else {
+       $wgMemCachedServers[] = 'localhost';
+}
+if ( isset( $options['i'] ) ) {
+       $iterations = $options['i'];
+} else {
+       $iterations = 100;
+}
+
+foreach ( $wgMemCachedServers as $server ) {
+        print "$server ";
+       $mcc = new MemCachedClientforWiki( array('persistant' => true) );
+       $mcc->set_servers( array( $server ) );
+       $set = 0;
+       $incr = 0;
+       $get = 0;
+        $time_start=microtime_float();
+       for ( $i=1; $i<=$iterations; $i++ ) {
+               if ( !is_null( $mcc->set( "test$i", $i ) ) ) {
+                       $set++;
+               }
+       }
+
+       for ( $i=1; $i<=$iterations; $i++ ) {
+               if ( !is_null( $mcc->incr( "test$i", $i ) ) ) {
+                       $incr++;
+               }
+       }
+
+       for ( $i=1; $i<=$iterations; $i++ ) {
+               $value = $mcc->get( "test$i" );
+               if ( $value == $i*2 ) {
+                       $get++;
+               }
+       }
+        $exectime=microtime_float()-$time_start;
+
+       print "set: $set   incr: $incr   get: $get time: $exectime\n";
+}
+
+function microtime_float()
+{
+   list($usec, $sec) = explode(" ", microtime());
+   return ((float)$usec + (float)$sec);
+}
+
+
+?>