addDescription( 'Benchmark the Squid purge functions.' ); } public function execute() { global $wgUseSquid, $wgSquidServers; if ( !$wgUseSquid ) { $this->fatalError( "Squid purge benchmark doesn't do much without squid support on." ); } else { $this->output( "There are " . count( $wgSquidServers ) . " defined squid servers:\n" ); if ( $this->hasOption( 'count' ) ) { $lengths = [ intval( $this->getOption( 'count' ) ) ]; } else { $lengths = [ 1, 10, 100 ]; } foreach ( $lengths as $length ) { $urls = $this->randomUrlList( $length ); $trial = $this->benchSquid( $urls ); $this->output( $trial . "\n" ); } } } /** * Run a bunch of URLs through SquidUpdate::purge() * to benchmark Squid response times. * @param array $urls A bunch of URLs to purge * @param int $trials How many times to run the test? * @return string */ private function benchSquid( $urls, $trials = 1 ) { $start = microtime( true ); for ( $i = 0; $i < $trials; $i++ ) { CdnCacheUpdate::purge( $urls ); } $delta = microtime( true ) - $start; $pertrial = $delta / $trials; $pertitle = $pertrial / count( $urls ); return sprintf( "%4d titles in %6.2fms (%6.2fms each)", count( $urls ), $pertrial * 1000.0, $pertitle * 1000.0 ); } /** * Get an array of randomUrl()'s. * @param int $length How many urls to add to the array * @return array */ private function randomUrlList( $length ) { $list = []; for ( $i = 0; $i < $length; $i++ ) { $list[] = $this->randomUrl(); } return $list; } /** * Return a random URL of the wiki. Not necessarily an actual title in the * database, but at least a URL that looks like one. * @return string */ private function randomUrl() { global $wgServer, $wgArticlePath; return $wgServer . str_replace( '$1', $this->randomTitle(), $wgArticlePath ); } /** * Create a random title string (not necessarily a Title object). * For use with randomUrl(). * @return string */ private function randomTitle() { $str = ''; $length = mt_rand( 1, 20 ); for ( $i = 0; $i < $length; $i++ ) { $str .= chr( mt_rand( ord( 'a' ), ord( 'z' ) ) ); } return ucfirst( $str ); } } $maintClass = BenchmarkPurge::class; require_once RUN_MAINTENANCE_IF_MAIN;