addDescription( 'Benchmark the CDN purge functions.' ); } public function execute() { global $wgUseCdn, $wgCdnServers; if ( !$wgUseCdn ) { $this->error( "CDN purge benchmark doesn't do much without CDN support on." ); } else { $this->output( "There are " . count( $wgCdnServers ) . " defined CDN 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->benchCdn( $urls ); $this->output( $trial . "\n" ); } } } /** * Run a bunch of URLs through CdnCacheUpdate::purge() * to benchmark CDN 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 benchCdn( $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;