@@ -1,19 +1,19 @@ |
||
| 1 | 1 | <?php |
| 2 | 2 | class AuthorPage extends WP_UnitTestCase |
| 3 | 3 | { |
| 4 | - public function setUp() |
|
| 5 | - { |
|
| 6 | - parent::setUp(); |
|
| 7 | - } |
|
| 4 | + public function setUp() |
|
| 5 | + { |
|
| 6 | + parent::setUp(); |
|
| 7 | + } |
|
| 8 | 8 | |
| 9 | - public function testAuthorPage() |
|
| 10 | - { |
|
| 9 | + public function testAuthorPage() |
|
| 10 | + { |
|
| 11 | 11 | |
| 12 | - } |
|
| 12 | + } |
|
| 13 | 13 | |
| 14 | - public function tearDown() |
|
| 15 | - { |
|
| 16 | - parent::tearDown(); |
|
| 17 | - } |
|
| 14 | + public function tearDown() |
|
| 15 | + { |
|
| 16 | + parent::tearDown(); |
|
| 17 | + } |
|
| 18 | 18 | } |
| 19 | 19 | ?> |
| 20 | 20 | \ No newline at end of file |
@@ -1,16 +1,16 @@ discard block |
||
| 1 | 1 | <?php |
| 2 | 2 | |
| 3 | 3 | /* Path to the WordPress codebase you'd like to test. Add a backslash in the end. */ |
| 4 | -define( 'ABSPATH', getenv( 'WP_CORE_DIR' ) . '/' ); |
|
| 4 | +define('ABSPATH', getenv('WP_CORE_DIR') . '/'); |
|
| 5 | 5 | |
| 6 | 6 | // Test with multisite enabled |
| 7 | -define( 'WP_TESTS_MULTISITE', (bool) getenv( 'WP_MULTISITE' ) ); |
|
| 7 | +define('WP_TESTS_MULTISITE', (bool) getenv('WP_MULTISITE')); |
|
| 8 | 8 | |
| 9 | 9 | // Force known bugs |
| 10 | 10 | // define( 'WP_TESTS_FORCE_KNOWN_BUGS', true ); |
| 11 | 11 | |
| 12 | 12 | // Test with WordPress debug mode on |
| 13 | -define( 'WP_DEBUG', true ); |
|
| 13 | +define('WP_DEBUG', true); |
|
| 14 | 14 | |
| 15 | 15 | // ** MySQL settings ** // |
| 16 | 16 | |
@@ -21,18 +21,18 @@ discard block |
||
| 21 | 21 | // These tests will DROP ALL TABLES in the database with the prefix named below. |
| 22 | 22 | // DO NOT use a production database or one that is shared with something else. |
| 23 | 23 | |
| 24 | -define( 'DB_NAME', 'wordpress_test' ); |
|
| 25 | -define( 'DB_USER', 'root' ); |
|
| 26 | -define( 'DB_PASSWORD', 'root' ); |
|
| 27 | -define( 'DB_HOST', 'localhost' ); |
|
| 28 | -define( 'DB_CHARSET', 'utf8' ); |
|
| 29 | -define( 'DB_COLLATE', '' ); |
|
| 24 | +define('DB_NAME', 'wordpress_test'); |
|
| 25 | +define('DB_USER', 'root'); |
|
| 26 | +define('DB_PASSWORD', 'root'); |
|
| 27 | +define('DB_HOST', 'localhost'); |
|
| 28 | +define('DB_CHARSET', 'utf8'); |
|
| 29 | +define('DB_COLLATE', ''); |
|
| 30 | 30 | |
| 31 | -define( 'WP_TESTS_DOMAIN', 'example.org' ); |
|
| 32 | -define( 'WP_TESTS_EMAIL', '[email protected]' ); |
|
| 33 | -define( 'WP_TESTS_TITLE', 'Test Blog' ); |
|
| 31 | +define('WP_TESTS_DOMAIN', 'example.org'); |
|
| 32 | +define('WP_TESTS_EMAIL', '[email protected]'); |
|
| 33 | +define('WP_TESTS_TITLE', 'Test Blog'); |
|
| 34 | 34 | |
| 35 | -define( 'WP_PHP_BINARY', 'php' ); |
|
| 35 | +define('WP_PHP_BINARY', 'php'); |
|
| 36 | 36 | |
| 37 | -define( 'WPLANG', '' ); |
|
| 38 | -$table_prefix = 'wptests_'; |
|
| 39 | 37 | \ No newline at end of file |
| 38 | +define('WPLANG', ''); |
|
| 39 | +$table_prefix = 'wptests_'; |
|
| 40 | 40 | \ No newline at end of file |
@@ -40,7 +40,7 @@ discard block |
||
| 40 | 40 | // reset the wpdb queries log, storing it on the profile stack if necessary |
| 41 | 41 | global $wpdb; |
| 42 | 42 | if ($this->stack) { |
| 43 | - $this->stack[count($this->stack)-1]['queries'] = $wpdb->queries; |
|
| 43 | + $this->stack[count($this->stack) - 1]['queries'] = $wpdb->queries; |
|
| 44 | 44 | } |
| 45 | 45 | $wpdb->queries = array(); |
| 46 | 46 | |
@@ -74,14 +74,14 @@ discard block |
||
| 74 | 74 | |
| 75 | 75 | if (isset($this->profile[$name])) { |
| 76 | 76 | $this->profile[$name]['time'] += $time; |
| 77 | - $this->profile[$name]['calls'] ++; |
|
| 77 | + $this->profile[$name]['calls']++; |
|
| 78 | 78 | $this->profile[$name]['cache_cold_hits'] += ($wp_object_cache->cold_cache_hits - $item['cache_cold_hits']); |
| 79 | 79 | $this->profile[$name]['cache_warm_hits'] += ($wp_object_cache->warm_cache_hits - $item['cache_warm_hits']); |
| 80 | 80 | $this->profile[$name]['cache_misses'] += ($wp_object_cache->cache_misses - $item['cache_misses']); |
| 81 | - $this->profile[$name]['cache_dirty_objects'] = array_add( $this->profile[$name]['cache_dirty_objects'], $cache_dirty_delta) ; |
|
| 82 | - $this->profile[$name]['actions'] = array_add( $this->profile[$name]['actions'], $item['actions'] ); |
|
| 83 | - $this->profile[$name]['filters'] = array_add( $this->profile[$name]['filters'], $item['filters'] ); |
|
| 84 | - $this->profile[$name]['queries'] = array_add( $this->profile[$name]['queries'], $item['queries'] ); |
|
| 81 | + $this->profile[$name]['cache_dirty_objects'] = array_add($this->profile[$name]['cache_dirty_objects'], $cache_dirty_delta); |
|
| 82 | + $this->profile[$name]['actions'] = array_add($this->profile[$name]['actions'], $item['actions']); |
|
| 83 | + $this->profile[$name]['filters'] = array_add($this->profile[$name]['filters'], $item['filters']); |
|
| 84 | + $this->profile[$name]['queries'] = array_add($this->profile[$name]['queries'], $item['queries']); |
|
| 85 | 85 | #$this->_query_summary($item['queries'], $this->profile[$name]['queries']); |
| 86 | 86 | |
| 87 | 87 | } |
@@ -109,28 +109,28 @@ discard block |
||
| 109 | 109 | |
| 110 | 110 | function microtime($since = 0.0) { |
| 111 | 111 | list($usec, $sec) = explode(' ', microtime()); |
| 112 | - return (float)$sec + (float)$usec - $since; |
|
| 112 | + return (float) $sec + (float) $usec - $since; |
|
| 113 | 113 | } |
| 114 | 114 | |
| 115 | 115 | function log_filter($tag) { |
| 116 | 116 | if ($this->stack) { |
| 117 | 117 | global $wp_actions; |
| 118 | 118 | if ($tag == end($wp_actions)) |
| 119 | - @$this->stack[count($this->stack)-1]['actions'][$tag] ++; |
|
| 119 | + @$this->stack[count($this->stack) - 1]['actions'][$tag]++; |
|
| 120 | 120 | else |
| 121 | - @$this->stack[count($this->stack)-1]['filters'][$tag] ++; |
|
| 121 | + @$this->stack[count($this->stack) - 1]['filters'][$tag]++; |
|
| 122 | 122 | } |
| 123 | 123 | return $arg; |
| 124 | 124 | } |
| 125 | 125 | |
| 126 | 126 | function log_action($tag) { |
| 127 | 127 | if ($this->stack) |
| 128 | - @$this->stack[count($this->stack)-1]['actions'][$tag] ++; |
|
| 128 | + @$this->stack[count($this->stack) - 1]['actions'][$tag]++; |
|
| 129 | 129 | } |
| 130 | 130 | |
| 131 | 131 | function _current_action() { |
| 132 | 132 | global $wp_actions; |
| 133 | - return $wp_actions[count($wp_actions)-1]; |
|
| 133 | + return $wp_actions[count($wp_actions) - 1]; |
|
| 134 | 134 | } |
| 135 | 135 | |
| 136 | 136 | function results() { |
@@ -143,7 +143,7 @@ discard block |
||
| 143 | 143 | $sql = preg_replace('/(WHERE \w+ =) \d+/', '$1 x', $sql); |
| 144 | 144 | $sql = preg_replace('/(WHERE \w+ =) \'\[-\w]+\'/', '$1 \'xxx\'', $sql); |
| 145 | 145 | |
| 146 | - @$out[$sql] ++; |
|
| 146 | + @$out[$sql]++; |
|
| 147 | 147 | } |
| 148 | 148 | asort($out); |
| 149 | 149 | return; |
@@ -154,9 +154,9 @@ discard block |
||
| 154 | 154 | $out = array(); |
| 155 | 155 | foreach ($queries as $q) { |
| 156 | 156 | if (empty($q[2])) |
| 157 | - @$out['unknown'] ++; |
|
| 157 | + @$out['unknown']++; |
|
| 158 | 158 | else |
| 159 | - @$out[$q[2]] ++; |
|
| 159 | + @$out[$q[2]]++; |
|
| 160 | 160 | } |
| 161 | 161 | return $out; |
| 162 | 162 | } |
@@ -84,8 +84,7 @@ discard block |
||
| 84 | 84 | $this->profile[$name]['queries'] = array_add( $this->profile[$name]['queries'], $item['queries'] ); |
| 85 | 85 | #$this->_query_summary($item['queries'], $this->profile[$name]['queries']); |
| 86 | 86 | |
| 87 | - } |
|
| 88 | - else { |
|
| 87 | + } else { |
|
| 89 | 88 | $queries = array(); |
| 90 | 89 | $this->_query_summary($item['queries'], $queries); |
| 91 | 90 | $this->profile[$name] = array( |
@@ -115,17 +114,19 @@ discard block |
||
| 115 | 114 | function log_filter($tag) { |
| 116 | 115 | if ($this->stack) { |
| 117 | 116 | global $wp_actions; |
| 118 | - if ($tag == end($wp_actions)) |
|
| 119 | - @$this->stack[count($this->stack)-1]['actions'][$tag] ++; |
|
| 120 | - else |
|
| 121 | - @$this->stack[count($this->stack)-1]['filters'][$tag] ++; |
|
| 117 | + if ($tag == end($wp_actions)) { |
|
| 118 | + @$this->stack[count($this->stack)-1]['actions'][$tag] ++; |
|
| 119 | + } else { |
|
| 120 | + @$this->stack[count($this->stack)-1]['filters'][$tag] ++; |
|
| 121 | + } |
|
| 122 | 122 | } |
| 123 | 123 | return $arg; |
| 124 | 124 | } |
| 125 | 125 | |
| 126 | 126 | function log_action($tag) { |
| 127 | - if ($this->stack) |
|
| 128 | - @$this->stack[count($this->stack)-1]['actions'][$tag] ++; |
|
| 127 | + if ($this->stack) { |
|
| 128 | + @$this->stack[count($this->stack)-1]['actions'][$tag] ++; |
|
| 129 | + } |
|
| 129 | 130 | } |
| 130 | 131 | |
| 131 | 132 | function _current_action() { |
@@ -153,36 +154,41 @@ discard block |
||
| 153 | 154 | // this requires the savequeries patch at https://core.trac.wordpress.org/ticket/5218 |
| 154 | 155 | $out = array(); |
| 155 | 156 | foreach ($queries as $q) { |
| 156 | - if (empty($q[2])) |
|
| 157 | - @$out['unknown'] ++; |
|
| 158 | - else |
|
| 159 | - @$out[$q[2]] ++; |
|
| 157 | + if (empty($q[2])) { |
|
| 158 | + @$out['unknown'] ++; |
|
| 159 | + } else { |
|
| 160 | + @$out[$q[2]] ++; |
|
| 161 | + } |
|
| 160 | 162 | } |
| 161 | 163 | return $out; |
| 162 | 164 | } |
| 163 | 165 | |
| 164 | 166 | function _dirty_objects_count($dirty_objects) { |
| 165 | 167 | $out = array(); |
| 166 | - foreach (array_keys($dirty_objects) as $group) |
|
| 167 | - $out[$group] = count($dirty_objects[$group]); |
|
| 168 | + foreach (array_keys($dirty_objects) as $group) { |
|
| 169 | + $out[$group] = count($dirty_objects[$group]); |
|
| 170 | + } |
|
| 168 | 171 | return $out; |
| 169 | 172 | } |
| 170 | 173 | |
| 171 | 174 | function array_add($a, $b) { |
| 172 | 175 | $out = $a; |
| 173 | - foreach (array_keys($b) as $key) |
|
| 174 | - if (array_key_exists($key, $out)) |
|
| 176 | + foreach (array_keys($b) as $key) { |
|
| 177 | + if (array_key_exists($key, $out)) |
|
| 175 | 178 | $out[$key] += $b[$key]; |
| 176 | - else |
|
| 177 | - $out[$key] = $b[$key]; |
|
| 179 | + } |
|
| 180 | + else { |
|
| 181 | + $out[$key] = $b[$key]; |
|
| 182 | + } |
|
| 178 | 183 | return $out; |
| 179 | 184 | } |
| 180 | 185 | |
| 181 | 186 | function array_sub($a, $b) { |
| 182 | 187 | $out = $a; |
| 183 | - foreach (array_keys($b) as $key) |
|
| 184 | - if (array_key_exists($key, $b)) |
|
| 188 | + foreach (array_keys($b) as $key) { |
|
| 189 | + if (array_key_exists($key, $b)) |
|
| 185 | 190 | $out[$key] -= $b[$key]; |
| 191 | + } |
|
| 186 | 192 | return $out; |
| 187 | 193 | } |
| 188 | 194 | |
@@ -6,321 +6,321 @@ |
||
| 6 | 6 | */ |
| 7 | 7 | class SpeedTrapListener implements PHPUnit_Framework_TestListener |
| 8 | 8 | { |
| 9 | - /** |
|
| 10 | - * Internal tracking for test suites. |
|
| 11 | - * |
|
| 12 | - * Increments as more suites are run, then decremented as they finish. All |
|
| 13 | - * suites have been run when returns to 0. |
|
| 14 | - * |
|
| 15 | - * @var integer |
|
| 16 | - */ |
|
| 17 | - protected $suites = 0; |
|
| 18 | - |
|
| 19 | - /** |
|
| 20 | - * Time in milliseconds at which a test will be considered "slow" and be |
|
| 21 | - * reported by this listener. |
|
| 22 | - * |
|
| 23 | - * @var int |
|
| 24 | - */ |
|
| 25 | - protected $slowThreshold; |
|
| 26 | - |
|
| 27 | - /** |
|
| 28 | - * Number of tests to report on for slowness. |
|
| 29 | - * |
|
| 30 | - * @var int |
|
| 31 | - */ |
|
| 32 | - protected $reportLength; |
|
| 33 | - |
|
| 34 | - /** |
|
| 35 | - * Collection of slow tests. |
|
| 36 | - * |
|
| 37 | - * @var array |
|
| 38 | - */ |
|
| 39 | - protected $slow = array(); |
|
| 40 | - |
|
| 41 | - /** |
|
| 42 | - * Construct a new instance. |
|
| 43 | - * |
|
| 44 | - * @param array $options |
|
| 45 | - */ |
|
| 46 | - public function __construct(array $options = array()) |
|
| 47 | - { |
|
| 48 | - $this->loadOptions($options); |
|
| 49 | - } |
|
| 50 | - |
|
| 51 | - /** |
|
| 52 | - * An error occurred. |
|
| 53 | - * |
|
| 54 | - * @param PHPUnit_Framework_Test $test |
|
| 55 | - * @param Exception $e |
|
| 56 | - * @param float $time |
|
| 57 | - */ |
|
| 58 | - public function addError(PHPUnit_Framework_Test $test, Exception $e, $time) |
|
| 59 | - { |
|
| 60 | - } |
|
| 61 | - |
|
| 62 | - /** |
|
| 63 | - * A warning occurred. |
|
| 64 | - * |
|
| 65 | - * @param PHPUnit_Framework_Test $test |
|
| 66 | - * @param PHPUnit_Framework_Warning $e |
|
| 67 | - * @param float $time |
|
| 68 | - * @since Method available since Release 5.1.0 |
|
| 69 | - */ |
|
| 70 | - public function addWarning(PHPUnit_Framework_Test $test, PHPUnit_Framework_Warning $e, $time) |
|
| 71 | - { |
|
| 72 | - } |
|
| 73 | - |
|
| 74 | - /** |
|
| 75 | - * A failure occurred. |
|
| 76 | - * |
|
| 77 | - * @param PHPUnit_Framework_Test $test |
|
| 78 | - * @param PHPUnit_Framework_AssertionFailedError $e |
|
| 79 | - * @param float $time |
|
| 80 | - */ |
|
| 81 | - public function addFailure(PHPUnit_Framework_Test $test, PHPUnit_Framework_AssertionFailedError $e, $time) |
|
| 82 | - { |
|
| 83 | - } |
|
| 84 | - |
|
| 85 | - /** |
|
| 86 | - * Incomplete test. |
|
| 87 | - * |
|
| 88 | - * @param PHPUnit_Framework_Test $test |
|
| 89 | - * @param Exception $e |
|
| 90 | - * @param float $time |
|
| 91 | - */ |
|
| 92 | - public function addIncompleteTest(PHPUnit_Framework_Test $test, Exception $e, $time) |
|
| 93 | - { |
|
| 94 | - } |
|
| 95 | - |
|
| 96 | - /** |
|
| 97 | - * Risky test. |
|
| 98 | - * |
|
| 99 | - * @param PHPUnit_Framework_Test $test |
|
| 100 | - * @param Exception $e |
|
| 101 | - * @param float $time |
|
| 102 | - * @since Method available since Release 4.0.0 |
|
| 103 | - */ |
|
| 104 | - public function addRiskyTest(PHPUnit_Framework_Test $test, Exception $e, $time) |
|
| 105 | - { |
|
| 106 | - } |
|
| 107 | - |
|
| 108 | - /** |
|
| 109 | - * Skipped test. |
|
| 110 | - * |
|
| 111 | - * @param PHPUnit_Framework_Test $test |
|
| 112 | - * @param Exception $e |
|
| 113 | - * @param float $time |
|
| 114 | - */ |
|
| 115 | - public function addSkippedTest(PHPUnit_Framework_Test $test, Exception $e, $time) |
|
| 116 | - { |
|
| 117 | - } |
|
| 118 | - |
|
| 119 | - /** |
|
| 120 | - * A test started. |
|
| 121 | - * |
|
| 122 | - * @param PHPUnit_Framework_Test $test |
|
| 123 | - */ |
|
| 124 | - public function startTest(PHPUnit_Framework_Test $test) |
|
| 125 | - { |
|
| 126 | - } |
|
| 127 | - |
|
| 128 | - /** |
|
| 129 | - * A test ended. |
|
| 130 | - * |
|
| 131 | - * @param PHPUnit_Framework_Test $test |
|
| 132 | - * @param float $time |
|
| 133 | - */ |
|
| 134 | - public function endTest(PHPUnit_Framework_Test $test, $time) |
|
| 135 | - { |
|
| 136 | - if (!$test instanceof PHPUnit_Framework_TestCase) return; |
|
| 137 | - |
|
| 138 | - $time = $this->toMilliseconds($time); |
|
| 139 | - $threshold = $this->getSlowThreshold($test); |
|
| 140 | - |
|
| 141 | - if ($this->isSlow($time, $threshold)) { |
|
| 142 | - $this->addSlowTest($test, $time); |
|
| 143 | - } |
|
| 144 | - } |
|
| 145 | - |
|
| 146 | - /** |
|
| 147 | - * A test suite started. |
|
| 148 | - * |
|
| 149 | - * @param PHPUnit_Framework_TestSuite $suite |
|
| 150 | - */ |
|
| 151 | - public function startTestSuite(PHPUnit_Framework_TestSuite $suite) |
|
| 152 | - { |
|
| 153 | - $this->suites++; |
|
| 154 | - } |
|
| 155 | - |
|
| 156 | - /** |
|
| 157 | - * A test suite ended. |
|
| 158 | - * |
|
| 159 | - * @param PHPUnit_Framework_TestSuite $suite |
|
| 160 | - */ |
|
| 161 | - public function endTestSuite(PHPUnit_Framework_TestSuite $suite) |
|
| 162 | - { |
|
| 163 | - $this->suites--; |
|
| 164 | - |
|
| 165 | - if (0 === $this->suites && $this->hasSlowTests()) { |
|
| 166 | - arsort($this->slow); // Sort longest running tests to the top |
|
| 167 | - |
|
| 168 | - $this->renderHeader(); |
|
| 169 | - $this->renderBody(); |
|
| 170 | - $this->renderFooter(); |
|
| 171 | - } |
|
| 172 | - } |
|
| 173 | - |
|
| 174 | - /** |
|
| 175 | - * Whether the given test execution time is considered slow. |
|
| 176 | - * |
|
| 177 | - * @param int $time Test execution time in milliseconds |
|
| 178 | - * @param int $slowThreshold Test execution time at which a test should be considered slow (milliseconds) |
|
| 179 | - * @return bool |
|
| 180 | - */ |
|
| 181 | - protected function isSlow($time, $slowThreshold) |
|
| 182 | - { |
|
| 183 | - return $time >= $slowThreshold; |
|
| 184 | - } |
|
| 185 | - |
|
| 186 | - /** |
|
| 187 | - * Stores a test as slow. |
|
| 188 | - * |
|
| 189 | - * @param PHPUnit_Framework_TestCase $test |
|
| 190 | - * @param int $time Test execution time in milliseconds |
|
| 191 | - */ |
|
| 192 | - protected function addSlowTest(PHPUnit_Framework_TestCase $test, $time) |
|
| 193 | - { |
|
| 194 | - $label = $this->makeLabel($test); |
|
| 195 | - |
|
| 196 | - $this->slow[$label] = $time; |
|
| 197 | - } |
|
| 198 | - |
|
| 199 | - /** |
|
| 200 | - * Whether at least one test has been considered slow. |
|
| 201 | - * |
|
| 202 | - * @return bool |
|
| 203 | - */ |
|
| 204 | - protected function hasSlowTests() |
|
| 205 | - { |
|
| 206 | - return !empty($this->slow); |
|
| 207 | - } |
|
| 208 | - |
|
| 209 | - /** |
|
| 210 | - * Convert PHPUnit's reported test time (microseconds) to milliseconds. |
|
| 211 | - * |
|
| 212 | - * @param float $time |
|
| 213 | - * @return int |
|
| 214 | - */ |
|
| 215 | - protected function toMilliseconds($time) |
|
| 216 | - { |
|
| 217 | - return (int) round($time * 1000); |
|
| 218 | - } |
|
| 219 | - |
|
| 220 | - /** |
|
| 221 | - * Label for describing a test. |
|
| 222 | - * |
|
| 223 | - * @param PHPUnit_Framework_TestCase $test |
|
| 224 | - * @return string |
|
| 225 | - */ |
|
| 226 | - protected function makeLabel(PHPUnit_Framework_TestCase $test) |
|
| 227 | - { |
|
| 228 | - return sprintf('%s:%s', get_class($test), $test->getName()); |
|
| 229 | - } |
|
| 230 | - |
|
| 231 | - /** |
|
| 232 | - * Calculate number of slow tests to report about. |
|
| 233 | - * |
|
| 234 | - * @return int |
|
| 235 | - */ |
|
| 236 | - protected function getReportLength() |
|
| 237 | - { |
|
| 238 | - return min(count($this->slow), $this->reportLength); |
|
| 239 | - } |
|
| 240 | - |
|
| 241 | - /** |
|
| 242 | - * Find how many slow tests occurred that won't be shown due to list length. |
|
| 243 | - * |
|
| 244 | - * @return int Number of hidden slow tests |
|
| 245 | - */ |
|
| 246 | - protected function getHiddenCount() |
|
| 247 | - { |
|
| 248 | - $total = count($this->slow); |
|
| 249 | - $showing = $this->getReportLength($this->slow); |
|
| 250 | - |
|
| 251 | - $hidden = 0; |
|
| 252 | - if ($total > $showing) { |
|
| 253 | - $hidden = $total - $showing; |
|
| 254 | - } |
|
| 255 | - |
|
| 256 | - return $hidden; |
|
| 257 | - } |
|
| 258 | - |
|
| 259 | - /** |
|
| 260 | - * Renders slow test report header. |
|
| 261 | - */ |
|
| 262 | - protected function renderHeader() |
|
| 263 | - { |
|
| 264 | - echo sprintf("\n\nYou should really fix these slow tests (>%sms)...\n", $this->slowThreshold); |
|
| 265 | - } |
|
| 266 | - |
|
| 267 | - /** |
|
| 268 | - * Renders slow test report body. |
|
| 269 | - */ |
|
| 270 | - protected function renderBody() |
|
| 271 | - { |
|
| 272 | - $slowTests = $this->slow; |
|
| 273 | - |
|
| 274 | - $length = $this->getReportLength($slowTests); |
|
| 275 | - for ($i = 1; $i <= $length; ++$i) { |
|
| 276 | - $label = key($slowTests); |
|
| 277 | - $time = array_shift($slowTests); |
|
| 278 | - |
|
| 279 | - echo sprintf(" %s. %sms to run %s\n", $i, $time, $label); |
|
| 280 | - } |
|
| 281 | - } |
|
| 282 | - |
|
| 283 | - /** |
|
| 284 | - * Renders slow test report footer. |
|
| 285 | - */ |
|
| 286 | - protected function renderFooter() |
|
| 287 | - { |
|
| 288 | - if ($hidden = $this->getHiddenCount($this->slow)) { |
|
| 289 | - echo sprintf("...and there %s %s more above your threshold hidden from view", $hidden == 1 ? 'is' : 'are', $hidden); |
|
| 290 | - } |
|
| 291 | - } |
|
| 292 | - |
|
| 293 | - /** |
|
| 294 | - * Populate options into class internals. |
|
| 295 | - * |
|
| 296 | - * @param array $options |
|
| 297 | - */ |
|
| 298 | - protected function loadOptions(array $options) |
|
| 299 | - { |
|
| 300 | - $this->slowThreshold = isset($options['slowThreshold']) ? $options['slowThreshold'] : 500; |
|
| 301 | - $this->reportLength = isset($options['reportLength']) ? $options['reportLength'] : 10; |
|
| 302 | - } |
|
| 303 | - |
|
| 304 | - /** |
|
| 305 | - * Get slow test threshold for given test. A TestCase can override the |
|
| 306 | - * suite-wide slow threshold by using the annotation @slowThreshold with |
|
| 307 | - * the threshold value in milliseconds. |
|
| 308 | - * |
|
| 309 | - * The following test will only be considered slow when its execution time |
|
| 310 | - * reaches 5000ms (5 seconds): |
|
| 311 | - * |
|
| 312 | - * <code> |
|
| 313 | - * @slowThreshold 5000 |
|
| 314 | - * public function testLongRunningProcess() {} |
|
| 315 | - * </code> |
|
| 316 | - * |
|
| 317 | - * @param PHPUnit_Framework_TestCase $test |
|
| 318 | - * @return int |
|
| 319 | - */ |
|
| 320 | - protected function getSlowThreshold(PHPUnit_Framework_TestCase $test) |
|
| 321 | - { |
|
| 322 | - $ann = $test->getAnnotations(); |
|
| 323 | - |
|
| 324 | - return isset($ann['method']['slowThreshold'][0]) ? $ann['method']['slowThreshold'][0] : $this->slowThreshold; |
|
| 325 | - } |
|
| 9 | + /** |
|
| 10 | + * Internal tracking for test suites. |
|
| 11 | + * |
|
| 12 | + * Increments as more suites are run, then decremented as they finish. All |
|
| 13 | + * suites have been run when returns to 0. |
|
| 14 | + * |
|
| 15 | + * @var integer |
|
| 16 | + */ |
|
| 17 | + protected $suites = 0; |
|
| 18 | + |
|
| 19 | + /** |
|
| 20 | + * Time in milliseconds at which a test will be considered "slow" and be |
|
| 21 | + * reported by this listener. |
|
| 22 | + * |
|
| 23 | + * @var int |
|
| 24 | + */ |
|
| 25 | + protected $slowThreshold; |
|
| 26 | + |
|
| 27 | + /** |
|
| 28 | + * Number of tests to report on for slowness. |
|
| 29 | + * |
|
| 30 | + * @var int |
|
| 31 | + */ |
|
| 32 | + protected $reportLength; |
|
| 33 | + |
|
| 34 | + /** |
|
| 35 | + * Collection of slow tests. |
|
| 36 | + * |
|
| 37 | + * @var array |
|
| 38 | + */ |
|
| 39 | + protected $slow = array(); |
|
| 40 | + |
|
| 41 | + /** |
|
| 42 | + * Construct a new instance. |
|
| 43 | + * |
|
| 44 | + * @param array $options |
|
| 45 | + */ |
|
| 46 | + public function __construct(array $options = array()) |
|
| 47 | + { |
|
| 48 | + $this->loadOptions($options); |
|
| 49 | + } |
|
| 50 | + |
|
| 51 | + /** |
|
| 52 | + * An error occurred. |
|
| 53 | + * |
|
| 54 | + * @param PHPUnit_Framework_Test $test |
|
| 55 | + * @param Exception $e |
|
| 56 | + * @param float $time |
|
| 57 | + */ |
|
| 58 | + public function addError(PHPUnit_Framework_Test $test, Exception $e, $time) |
|
| 59 | + { |
|
| 60 | + } |
|
| 61 | + |
|
| 62 | + /** |
|
| 63 | + * A warning occurred. |
|
| 64 | + * |
|
| 65 | + * @param PHPUnit_Framework_Test $test |
|
| 66 | + * @param PHPUnit_Framework_Warning $e |
|
| 67 | + * @param float $time |
|
| 68 | + * @since Method available since Release 5.1.0 |
|
| 69 | + */ |
|
| 70 | + public function addWarning(PHPUnit_Framework_Test $test, PHPUnit_Framework_Warning $e, $time) |
|
| 71 | + { |
|
| 72 | + } |
|
| 73 | + |
|
| 74 | + /** |
|
| 75 | + * A failure occurred. |
|
| 76 | + * |
|
| 77 | + * @param PHPUnit_Framework_Test $test |
|
| 78 | + * @param PHPUnit_Framework_AssertionFailedError $e |
|
| 79 | + * @param float $time |
|
| 80 | + */ |
|
| 81 | + public function addFailure(PHPUnit_Framework_Test $test, PHPUnit_Framework_AssertionFailedError $e, $time) |
|
| 82 | + { |
|
| 83 | + } |
|
| 84 | + |
|
| 85 | + /** |
|
| 86 | + * Incomplete test. |
|
| 87 | + * |
|
| 88 | + * @param PHPUnit_Framework_Test $test |
|
| 89 | + * @param Exception $e |
|
| 90 | + * @param float $time |
|
| 91 | + */ |
|
| 92 | + public function addIncompleteTest(PHPUnit_Framework_Test $test, Exception $e, $time) |
|
| 93 | + { |
|
| 94 | + } |
|
| 95 | + |
|
| 96 | + /** |
|
| 97 | + * Risky test. |
|
| 98 | + * |
|
| 99 | + * @param PHPUnit_Framework_Test $test |
|
| 100 | + * @param Exception $e |
|
| 101 | + * @param float $time |
|
| 102 | + * @since Method available since Release 4.0.0 |
|
| 103 | + */ |
|
| 104 | + public function addRiskyTest(PHPUnit_Framework_Test $test, Exception $e, $time) |
|
| 105 | + { |
|
| 106 | + } |
|
| 107 | + |
|
| 108 | + /** |
|
| 109 | + * Skipped test. |
|
| 110 | + * |
|
| 111 | + * @param PHPUnit_Framework_Test $test |
|
| 112 | + * @param Exception $e |
|
| 113 | + * @param float $time |
|
| 114 | + */ |
|
| 115 | + public function addSkippedTest(PHPUnit_Framework_Test $test, Exception $e, $time) |
|
| 116 | + { |
|
| 117 | + } |
|
| 118 | + |
|
| 119 | + /** |
|
| 120 | + * A test started. |
|
| 121 | + * |
|
| 122 | + * @param PHPUnit_Framework_Test $test |
|
| 123 | + */ |
|
| 124 | + public function startTest(PHPUnit_Framework_Test $test) |
|
| 125 | + { |
|
| 126 | + } |
|
| 127 | + |
|
| 128 | + /** |
|
| 129 | + * A test ended. |
|
| 130 | + * |
|
| 131 | + * @param PHPUnit_Framework_Test $test |
|
| 132 | + * @param float $time |
|
| 133 | + */ |
|
| 134 | + public function endTest(PHPUnit_Framework_Test $test, $time) |
|
| 135 | + { |
|
| 136 | + if (!$test instanceof PHPUnit_Framework_TestCase) return; |
|
| 137 | + |
|
| 138 | + $time = $this->toMilliseconds($time); |
|
| 139 | + $threshold = $this->getSlowThreshold($test); |
|
| 140 | + |
|
| 141 | + if ($this->isSlow($time, $threshold)) { |
|
| 142 | + $this->addSlowTest($test, $time); |
|
| 143 | + } |
|
| 144 | + } |
|
| 145 | + |
|
| 146 | + /** |
|
| 147 | + * A test suite started. |
|
| 148 | + * |
|
| 149 | + * @param PHPUnit_Framework_TestSuite $suite |
|
| 150 | + */ |
|
| 151 | + public function startTestSuite(PHPUnit_Framework_TestSuite $suite) |
|
| 152 | + { |
|
| 153 | + $this->suites++; |
|
| 154 | + } |
|
| 155 | + |
|
| 156 | + /** |
|
| 157 | + * A test suite ended. |
|
| 158 | + * |
|
| 159 | + * @param PHPUnit_Framework_TestSuite $suite |
|
| 160 | + */ |
|
| 161 | + public function endTestSuite(PHPUnit_Framework_TestSuite $suite) |
|
| 162 | + { |
|
| 163 | + $this->suites--; |
|
| 164 | + |
|
| 165 | + if (0 === $this->suites && $this->hasSlowTests()) { |
|
| 166 | + arsort($this->slow); // Sort longest running tests to the top |
|
| 167 | + |
|
| 168 | + $this->renderHeader(); |
|
| 169 | + $this->renderBody(); |
|
| 170 | + $this->renderFooter(); |
|
| 171 | + } |
|
| 172 | + } |
|
| 173 | + |
|
| 174 | + /** |
|
| 175 | + * Whether the given test execution time is considered slow. |
|
| 176 | + * |
|
| 177 | + * @param int $time Test execution time in milliseconds |
|
| 178 | + * @param int $slowThreshold Test execution time at which a test should be considered slow (milliseconds) |
|
| 179 | + * @return bool |
|
| 180 | + */ |
|
| 181 | + protected function isSlow($time, $slowThreshold) |
|
| 182 | + { |
|
| 183 | + return $time >= $slowThreshold; |
|
| 184 | + } |
|
| 185 | + |
|
| 186 | + /** |
|
| 187 | + * Stores a test as slow. |
|
| 188 | + * |
|
| 189 | + * @param PHPUnit_Framework_TestCase $test |
|
| 190 | + * @param int $time Test execution time in milliseconds |
|
| 191 | + */ |
|
| 192 | + protected function addSlowTest(PHPUnit_Framework_TestCase $test, $time) |
|
| 193 | + { |
|
| 194 | + $label = $this->makeLabel($test); |
|
| 195 | + |
|
| 196 | + $this->slow[$label] = $time; |
|
| 197 | + } |
|
| 198 | + |
|
| 199 | + /** |
|
| 200 | + * Whether at least one test has been considered slow. |
|
| 201 | + * |
|
| 202 | + * @return bool |
|
| 203 | + */ |
|
| 204 | + protected function hasSlowTests() |
|
| 205 | + { |
|
| 206 | + return !empty($this->slow); |
|
| 207 | + } |
|
| 208 | + |
|
| 209 | + /** |
|
| 210 | + * Convert PHPUnit's reported test time (microseconds) to milliseconds. |
|
| 211 | + * |
|
| 212 | + * @param float $time |
|
| 213 | + * @return int |
|
| 214 | + */ |
|
| 215 | + protected function toMilliseconds($time) |
|
| 216 | + { |
|
| 217 | + return (int) round($time * 1000); |
|
| 218 | + } |
|
| 219 | + |
|
| 220 | + /** |
|
| 221 | + * Label for describing a test. |
|
| 222 | + * |
|
| 223 | + * @param PHPUnit_Framework_TestCase $test |
|
| 224 | + * @return string |
|
| 225 | + */ |
|
| 226 | + protected function makeLabel(PHPUnit_Framework_TestCase $test) |
|
| 227 | + { |
|
| 228 | + return sprintf('%s:%s', get_class($test), $test->getName()); |
|
| 229 | + } |
|
| 230 | + |
|
| 231 | + /** |
|
| 232 | + * Calculate number of slow tests to report about. |
|
| 233 | + * |
|
| 234 | + * @return int |
|
| 235 | + */ |
|
| 236 | + protected function getReportLength() |
|
| 237 | + { |
|
| 238 | + return min(count($this->slow), $this->reportLength); |
|
| 239 | + } |
|
| 240 | + |
|
| 241 | + /** |
|
| 242 | + * Find how many slow tests occurred that won't be shown due to list length. |
|
| 243 | + * |
|
| 244 | + * @return int Number of hidden slow tests |
|
| 245 | + */ |
|
| 246 | + protected function getHiddenCount() |
|
| 247 | + { |
|
| 248 | + $total = count($this->slow); |
|
| 249 | + $showing = $this->getReportLength($this->slow); |
|
| 250 | + |
|
| 251 | + $hidden = 0; |
|
| 252 | + if ($total > $showing) { |
|
| 253 | + $hidden = $total - $showing; |
|
| 254 | + } |
|
| 255 | + |
|
| 256 | + return $hidden; |
|
| 257 | + } |
|
| 258 | + |
|
| 259 | + /** |
|
| 260 | + * Renders slow test report header. |
|
| 261 | + */ |
|
| 262 | + protected function renderHeader() |
|
| 263 | + { |
|
| 264 | + echo sprintf("\n\nYou should really fix these slow tests (>%sms)...\n", $this->slowThreshold); |
|
| 265 | + } |
|
| 266 | + |
|
| 267 | + /** |
|
| 268 | + * Renders slow test report body. |
|
| 269 | + */ |
|
| 270 | + protected function renderBody() |
|
| 271 | + { |
|
| 272 | + $slowTests = $this->slow; |
|
| 273 | + |
|
| 274 | + $length = $this->getReportLength($slowTests); |
|
| 275 | + for ($i = 1; $i <= $length; ++$i) { |
|
| 276 | + $label = key($slowTests); |
|
| 277 | + $time = array_shift($slowTests); |
|
| 278 | + |
|
| 279 | + echo sprintf(" %s. %sms to run %s\n", $i, $time, $label); |
|
| 280 | + } |
|
| 281 | + } |
|
| 282 | + |
|
| 283 | + /** |
|
| 284 | + * Renders slow test report footer. |
|
| 285 | + */ |
|
| 286 | + protected function renderFooter() |
|
| 287 | + { |
|
| 288 | + if ($hidden = $this->getHiddenCount($this->slow)) { |
|
| 289 | + echo sprintf("...and there %s %s more above your threshold hidden from view", $hidden == 1 ? 'is' : 'are', $hidden); |
|
| 290 | + } |
|
| 291 | + } |
|
| 292 | + |
|
| 293 | + /** |
|
| 294 | + * Populate options into class internals. |
|
| 295 | + * |
|
| 296 | + * @param array $options |
|
| 297 | + */ |
|
| 298 | + protected function loadOptions(array $options) |
|
| 299 | + { |
|
| 300 | + $this->slowThreshold = isset($options['slowThreshold']) ? $options['slowThreshold'] : 500; |
|
| 301 | + $this->reportLength = isset($options['reportLength']) ? $options['reportLength'] : 10; |
|
| 302 | + } |
|
| 303 | + |
|
| 304 | + /** |
|
| 305 | + * Get slow test threshold for given test. A TestCase can override the |
|
| 306 | + * suite-wide slow threshold by using the annotation @slowThreshold with |
|
| 307 | + * the threshold value in milliseconds. |
|
| 308 | + * |
|
| 309 | + * The following test will only be considered slow when its execution time |
|
| 310 | + * reaches 5000ms (5 seconds): |
|
| 311 | + * |
|
| 312 | + * <code> |
|
| 313 | + * @slowThreshold 5000 |
|
| 314 | + * public function testLongRunningProcess() {} |
|
| 315 | + * </code> |
|
| 316 | + * |
|
| 317 | + * @param PHPUnit_Framework_TestCase $test |
|
| 318 | + * @return int |
|
| 319 | + */ |
|
| 320 | + protected function getSlowThreshold(PHPUnit_Framework_TestCase $test) |
|
| 321 | + { |
|
| 322 | + $ann = $test->getAnnotations(); |
|
| 323 | + |
|
| 324 | + return isset($ann['method']['slowThreshold'][0]) ? $ann['method']['slowThreshold'][0] : $this->slowThreshold; |
|
| 325 | + } |
|
| 326 | 326 | } |
@@ -133,7 +133,9 @@ |
||
| 133 | 133 | */ |
| 134 | 134 | public function endTest(PHPUnit_Framework_Test $test, $time) |
| 135 | 135 | { |
| 136 | - if (!$test instanceof PHPUnit_Framework_TestCase) return; |
|
| 136 | + if (!$test instanceof PHPUnit_Framework_TestCase) { |
|
| 137 | + return; |
|
| 138 | + } |
|
| 137 | 139 | |
| 138 | 140 | $time = $this->toMilliseconds($time); |
| 139 | 141 | $threshold = $this->getSlowThreshold($test); |
@@ -9,21 +9,21 @@ |
||
| 9 | 9 | function setUp() { |
| 10 | 10 | parent::setUp(); |
| 11 | 11 | |
| 12 | - add_filter( 'pre_option_enable_xmlrpc', '__return_true' ); |
|
| 12 | + add_filter('pre_option_enable_xmlrpc', '__return_true'); |
|
| 13 | 13 | |
| 14 | 14 | $this->myxmlrpcserver = new wp_xmlrpc_server(); |
| 15 | 15 | } |
| 16 | 16 | |
| 17 | 17 | function tearDown() { |
| 18 | - remove_filter( 'pre_option_enable_xmlrpc', '__return_true' ); |
|
| 18 | + remove_filter('pre_option_enable_xmlrpc', '__return_true'); |
|
| 19 | 19 | |
| 20 | 20 | $this->remove_added_uploads(); |
| 21 | 21 | |
| 22 | 22 | parent::tearDown(); |
| 23 | 23 | } |
| 24 | 24 | |
| 25 | - protected function make_user_by_role( $role ) { |
|
| 26 | - return self::factory()->user->create( array( |
|
| 25 | + protected function make_user_by_role($role) { |
|
| 26 | + return self::factory()->user->create(array( |
|
| 27 | 27 | 'user_login' => $role, |
| 28 | 28 | 'user_pass' => $role, |
| 29 | 29 | 'role' => $role |
@@ -1,6 +1,6 @@ discard block |
||
| 1 | 1 | <?php |
| 2 | 2 | |
| 3 | -if (class_exists( 'WP_Image_Editor' ) ) : |
|
| 3 | +if (class_exists('WP_Image_Editor')) : |
|
| 4 | 4 | |
| 5 | 5 | class WP_Image_Editor_Mock extends WP_Image_Editor { |
| 6 | 6 | |
@@ -9,38 +9,38 @@ discard block |
||
| 9 | 9 | public static $save_return = array(); |
| 10 | 10 | |
| 11 | 11 | // Allow testing of jpeg_quality filter. |
| 12 | - public function set_mime_type( $mime_type = null ) { |
|
| 12 | + public function set_mime_type($mime_type = null) { |
|
| 13 | 13 | $this->mime_type = $mime_type; |
| 14 | 14 | } |
| 15 | 15 | |
| 16 | 16 | public function load() { |
| 17 | 17 | return self::$load_return; |
| 18 | 18 | } |
| 19 | - public static function test( $args = array() ) { |
|
| 19 | + public static function test($args = array()) { |
|
| 20 | 20 | return self::$test_return; |
| 21 | 21 | } |
| 22 | - public static function supports_mime_type( $mime_type ) { |
|
| 22 | + public static function supports_mime_type($mime_type) { |
|
| 23 | 23 | return true; |
| 24 | 24 | } |
| 25 | - public function resize( $max_w, $max_h, $crop = false ) { |
|
| 25 | + public function resize($max_w, $max_h, $crop = false) { |
|
| 26 | 26 | |
| 27 | 27 | } |
| 28 | - public function multi_resize( $sizes ) { |
|
| 28 | + public function multi_resize($sizes) { |
|
| 29 | 29 | |
| 30 | 30 | } |
| 31 | - public function crop( $src_x, $src_y, $src_w, $src_h, $dst_w = null, $dst_h = null, $src_abs = false ) { |
|
| 31 | + public function crop($src_x, $src_y, $src_w, $src_h, $dst_w = null, $dst_h = null, $src_abs = false) { |
|
| 32 | 32 | |
| 33 | 33 | } |
| 34 | - public function rotate( $angle ) { |
|
| 34 | + public function rotate($angle) { |
|
| 35 | 35 | |
| 36 | 36 | } |
| 37 | - public function flip( $horz, $vert ) { |
|
| 37 | + public function flip($horz, $vert) { |
|
| 38 | 38 | |
| 39 | 39 | } |
| 40 | - public function save( $destfilename = null, $mime_type = null ) { |
|
| 40 | + public function save($destfilename = null, $mime_type = null) { |
|
| 41 | 41 | return self::$save_return; |
| 42 | 42 | } |
| 43 | - public function stream( $mime_type = null ) { |
|
| 43 | + public function stream($mime_type = null) { |
|
| 44 | 44 | |
| 45 | 45 | } |
| 46 | 46 | } |
@@ -1,19 +1,19 @@ |
||
| 1 | 1 | <?php |
| 2 | 2 | |
| 3 | 3 | abstract class WP_Test_REST_TestCase extends WP_UnitTestCase { |
| 4 | - protected function assertErrorResponse( $code, $response, $status = null ) { |
|
| 4 | + protected function assertErrorResponse($code, $response, $status = null) { |
|
| 5 | 5 | |
| 6 | - if ( is_a( $response, 'WP_REST_Response' ) ) { |
|
| 6 | + if (is_a($response, 'WP_REST_Response')) { |
|
| 7 | 7 | $response = $response->as_error(); |
| 8 | 8 | } |
| 9 | 9 | |
| 10 | - $this->assertInstanceOf( 'WP_Error', $response ); |
|
| 11 | - $this->assertEquals( $code, $response->get_error_code() ); |
|
| 10 | + $this->assertInstanceOf('WP_Error', $response); |
|
| 11 | + $this->assertEquals($code, $response->get_error_code()); |
|
| 12 | 12 | |
| 13 | - if ( null !== $status ) { |
|
| 13 | + if (null !== $status) { |
|
| 14 | 14 | $data = $response->get_error_data(); |
| 15 | - $this->assertArrayHasKey( 'status', $data ); |
|
| 16 | - $this->assertEquals( $status, $data['status'] ); |
|
| 15 | + $this->assertArrayHasKey('status', $data); |
|
| 16 | + $this->assertEquals($status, $data['status']); |
|
| 17 | 17 | } |
| 18 | 18 | } |
| 19 | 19 | } |
@@ -1,9 +1,9 @@ |
||
| 1 | 1 | <?php |
| 2 | 2 | /** |
| 3 | - * Installs WordPress for the purpose of the unit-tests |
|
| 4 | - * |
|
| 5 | - * @todo Reuse the init/load code in init.php |
|
| 6 | - */ |
|
| 3 | + * Installs WordPress for the purpose of the unit-tests |
|
| 4 | + * |
|
| 5 | + * @todo Reuse the init/load code in init.php |
|
| 6 | + */ |
|
| 7 | 7 | error_reporting( E_ALL & ~E_DEPRECATED & ~E_STRICT ); |
| 8 | 8 | |
| 9 | 9 | $config_file_path = $argv[1]; |
@@ -4,14 +4,14 @@ discard block |
||
| 4 | 4 | * |
| 5 | 5 | * @todo Reuse the init/load code in init.php |
| 6 | 6 | */ |
| 7 | -error_reporting( E_ALL & ~E_DEPRECATED & ~E_STRICT ); |
|
| 7 | +error_reporting(E_ALL & ~E_DEPRECATED & ~E_STRICT); |
|
| 8 | 8 | |
| 9 | 9 | $config_file_path = $argv[1]; |
| 10 | -$multisite = ! empty( $argv[2] ); |
|
| 10 | +$multisite = !empty($argv[2]); |
|
| 11 | 11 | |
| 12 | -define( 'WP_INSTALLING', true ); |
|
| 12 | +define('WP_INSTALLING', true); |
|
| 13 | 13 | require_once $config_file_path; |
| 14 | -require_once dirname( __FILE__ ) . '/functions.php'; |
|
| 14 | +require_once dirname(__FILE__) . '/functions.php'; |
|
| 15 | 15 | |
| 16 | 16 | $_SERVER['SERVER_PROTOCOL'] = 'HTTP/1.1'; |
| 17 | 17 | $_SERVER['HTTP_HOST'] = WP_TESTS_DOMAIN; |
@@ -28,46 +28,46 @@ discard block |
||
| 28 | 28 | |
| 29 | 29 | // Override the PHPMailer |
| 30 | 30 | global $phpmailer; |
| 31 | -require_once( dirname( __FILE__ ) . '/mock-mailer.php' ); |
|
| 31 | +require_once(dirname(__FILE__) . '/mock-mailer.php'); |
|
| 32 | 32 | $phpmailer = new MockPHPMailer(); |
| 33 | 33 | |
| 34 | -$wpdb->query( 'SET storage_engine = INNODB' ); |
|
| 35 | -$wpdb->select( DB_NAME, $wpdb->dbh ); |
|
| 34 | +$wpdb->query('SET storage_engine = INNODB'); |
|
| 35 | +$wpdb->select(DB_NAME, $wpdb->dbh); |
|
| 36 | 36 | |
| 37 | 37 | echo "Installing..." . PHP_EOL; |
| 38 | 38 | |
| 39 | -foreach ( $wpdb->tables() as $table => $prefixed_table ) { |
|
| 40 | - $wpdb->query( "DROP TABLE IF EXISTS $prefixed_table" ); |
|
| 39 | +foreach ($wpdb->tables() as $table => $prefixed_table) { |
|
| 40 | + $wpdb->query("DROP TABLE IF EXISTS $prefixed_table"); |
|
| 41 | 41 | } |
| 42 | 42 | |
| 43 | -foreach ( $wpdb->tables( 'ms_global' ) as $table => $prefixed_table ) { |
|
| 44 | - $wpdb->query( "DROP TABLE IF EXISTS $prefixed_table" ); |
|
| 43 | +foreach ($wpdb->tables('ms_global') as $table => $prefixed_table) { |
|
| 44 | + $wpdb->query("DROP TABLE IF EXISTS $prefixed_table"); |
|
| 45 | 45 | |
| 46 | 46 | // We need to create references to ms global tables. |
| 47 | - if ( $multisite ) |
|
| 47 | + if ($multisite) |
|
| 48 | 48 | $wpdb->$table = $prefixed_table; |
| 49 | 49 | } |
| 50 | 50 | |
| 51 | 51 | // Prefill a permalink structure so that WP doesn't try to determine one itself. |
| 52 | -add_action( 'populate_options', '_set_default_permalink_structure_for_tests' ); |
|
| 52 | +add_action('populate_options', '_set_default_permalink_structure_for_tests'); |
|
| 53 | 53 | |
| 54 | -wp_install( WP_TESTS_TITLE, 'admin', WP_TESTS_EMAIL, true, null, 'password' ); |
|
| 54 | +wp_install(WP_TESTS_TITLE, 'admin', WP_TESTS_EMAIL, true, null, 'password'); |
|
| 55 | 55 | |
| 56 | 56 | // Delete dummy permalink structure, as prefilled above. |
| 57 | -if ( ! is_multisite() ) { |
|
| 58 | - delete_option( 'permalink_structure' ); |
|
| 57 | +if (!is_multisite()) { |
|
| 58 | + delete_option('permalink_structure'); |
|
| 59 | 59 | } |
| 60 | -remove_action( 'populate_options', '_set_default_permalink_structure_for_tests' ); |
|
| 60 | +remove_action('populate_options', '_set_default_permalink_structure_for_tests'); |
|
| 61 | 61 | |
| 62 | -if ( $multisite ) { |
|
| 62 | +if ($multisite) { |
|
| 63 | 63 | echo "Installing network..." . PHP_EOL; |
| 64 | 64 | |
| 65 | - define( 'WP_INSTALLING_NETWORK', true ); |
|
| 65 | + define('WP_INSTALLING_NETWORK', true); |
|
| 66 | 66 | |
| 67 | 67 | $title = WP_TESTS_TITLE . ' Network'; |
| 68 | 68 | $subdomain_install = false; |
| 69 | 69 | |
| 70 | 70 | install_network(); |
| 71 | - populate_network( 1, WP_TESTS_DOMAIN, WP_TESTS_EMAIL, $title, '/', $subdomain_install ); |
|
| 72 | - $wp_rewrite->set_permalink_structure( '' ); |
|
| 71 | + populate_network(1, WP_TESTS_DOMAIN, WP_TESTS_EMAIL, $title, '/', $subdomain_install); |
|
| 72 | + $wp_rewrite->set_permalink_structure(''); |
|
| 73 | 73 | } |
@@ -44,9 +44,10 @@ |
||
| 44 | 44 | $wpdb->query( "DROP TABLE IF EXISTS $prefixed_table" ); |
| 45 | 45 | |
| 46 | 46 | // We need to create references to ms global tables. |
| 47 | - if ( $multisite ) |
|
| 48 | - $wpdb->$table = $prefixed_table; |
|
| 49 | -} |
|
| 47 | + if ( $multisite ) { |
|
| 48 | + $wpdb->$table = $prefixed_table; |
|
| 49 | + } |
|
| 50 | + } |
|
| 50 | 51 | |
| 51 | 52 | // Prefill a permalink structure so that WP doesn't try to determine one itself. |
| 52 | 53 | add_action( 'populate_options', '_set_default_permalink_structure_for_tests' ); |
@@ -1,7 +1,7 @@ discard block |
||
| 1 | 1 | <?php |
| 2 | 2 | /** |
| 3 | - * Installs WordPress for running the tests and loads WordPress and the test libraries |
|
| 4 | - */ |
|
| 3 | + * Installs WordPress for running the tests and loads WordPress and the test libraries |
|
| 4 | + */ |
|
| 5 | 5 | |
| 6 | 6 | |
| 7 | 7 | $config_file_path = dirname( dirname( __FILE__ ) ); |
@@ -175,6 +175,6 @@ discard block |
||
| 175 | 175 | echo 'If this changeset includes changes to HTTP, make sure there are no timeouts.' . PHP_EOL; |
| 176 | 176 | echo PHP_EOL; |
| 177 | 177 | } |
| 178 | - } |
|
| 178 | + } |
|
| 179 | 179 | } |
| 180 | 180 | new WP_PHPUnit_Util_Getopt( $_SERVER['argv'] ); |
@@ -4,11 +4,11 @@ discard block |
||
| 4 | 4 | */ |
| 5 | 5 | |
| 6 | 6 | |
| 7 | -$config_file_path = dirname( dirname( __FILE__ ) ); |
|
| 8 | -if ( ! file_exists( $config_file_path . '/wp-tests-config.php' ) ) { |
|
| 7 | +$config_file_path = dirname(dirname(__FILE__)); |
|
| 8 | +if (!file_exists($config_file_path . '/wp-tests-config.php')) { |
|
| 9 | 9 | // Support the config file from the root of the develop repository. |
| 10 | - if ( basename( $config_file_path ) === 'phpunit' && basename( dirname( $config_file_path ) ) === 'tests' ) |
|
| 11 | - $config_file_path = dirname( dirname( $config_file_path ) ); |
|
| 10 | + if (basename($config_file_path) === 'phpunit' && basename(dirname($config_file_path)) === 'tests') |
|
| 11 | + $config_file_path = dirname(dirname($config_file_path)); |
|
| 12 | 12 | } |
| 13 | 13 | $config_file_path .= '/wp-tests-config.php'; |
| 14 | 14 | |
@@ -18,22 +18,22 @@ discard block |
||
| 18 | 18 | */ |
| 19 | 19 | global $wpdb, $current_site, $current_blog, $wp_rewrite, $shortcode_tags, $wp, $phpmailer; |
| 20 | 20 | |
| 21 | -if ( !is_readable( $config_file_path ) ) { |
|
| 22 | - die( "ERROR: wp-tests-config.php is missing! Please use wp-tests-config-sample.php to create a config file.\n" ); |
|
| 21 | +if (!is_readable($config_file_path)) { |
|
| 22 | + die("ERROR: wp-tests-config.php is missing! Please use wp-tests-config-sample.php to create a config file.\n"); |
|
| 23 | 23 | } |
| 24 | 24 | require_once $config_file_path; |
| 25 | 25 | |
| 26 | -define( 'WP_TESTS_TABLE_PREFIX', $table_prefix ); |
|
| 27 | -define( 'DIR_TESTDATA', dirname( __FILE__ ) . '/../data' ); |
|
| 26 | +define('WP_TESTS_TABLE_PREFIX', $table_prefix); |
|
| 27 | +define('DIR_TESTDATA', dirname(__FILE__) . '/../data'); |
|
| 28 | 28 | |
| 29 | -if ( ! defined( 'WP_TESTS_FORCE_KNOWN_BUGS' ) ) |
|
| 30 | - define( 'WP_TESTS_FORCE_KNOWN_BUGS', false ); |
|
| 29 | +if (!defined('WP_TESTS_FORCE_KNOWN_BUGS')) |
|
| 30 | + define('WP_TESTS_FORCE_KNOWN_BUGS', false); |
|
| 31 | 31 | |
| 32 | 32 | // Cron tries to make an HTTP request to the blog, which always fails, because tests are run in CLI mode only |
| 33 | -define( 'DISABLE_WP_CRON', true ); |
|
| 33 | +define('DISABLE_WP_CRON', true); |
|
| 34 | 34 | |
| 35 | -define( 'WP_MEMORY_LIMIT', -1 ); |
|
| 36 | -define( 'WP_MAX_MEMORY_LIMIT', -1 ); |
|
| 35 | +define('WP_MEMORY_LIMIT', -1); |
|
| 36 | +define('WP_MAX_MEMORY_LIMIT', -1); |
|
| 37 | 37 | |
| 38 | 38 | $_SERVER['SERVER_PROTOCOL'] = 'HTTP/1.1'; |
| 39 | 39 | $_SERVER['HTTP_HOST'] = WP_TESTS_DOMAIN; |
@@ -43,45 +43,45 @@ discard block |
||
| 43 | 43 | |
| 44 | 44 | $PHP_SELF = $GLOBALS['PHP_SELF'] = $_SERVER['PHP_SELF'] = '/index.php'; |
| 45 | 45 | |
| 46 | -if ( "1" == getenv( 'WP_MULTISITE' ) || |
|
| 47 | - ( defined( 'WP_TESTS_MULTISITE') && WP_TESTS_MULTISITE ) ) { |
|
| 46 | +if ("1" == getenv('WP_MULTISITE') || |
|
| 47 | + (defined('WP_TESTS_MULTISITE') && WP_TESTS_MULTISITE)) { |
|
| 48 | 48 | $multisite = true; |
| 49 | 49 | } else { |
| 50 | 50 | $multisite = false; |
| 51 | 51 | } |
| 52 | 52 | |
| 53 | 53 | // Override the PHPMailer |
| 54 | -require_once( dirname( __FILE__ ) . '/mock-mailer.php' ); |
|
| 54 | +require_once(dirname(__FILE__) . '/mock-mailer.php'); |
|
| 55 | 55 | $phpmailer = new MockPHPMailer(); |
| 56 | 56 | |
| 57 | -system( WP_PHP_BINARY . ' ' . escapeshellarg( dirname( __FILE__ ) . '/install.php' ) . ' ' . escapeshellarg( $config_file_path ) . ' ' . $multisite ); |
|
| 57 | +system(WP_PHP_BINARY . ' ' . escapeshellarg(dirname(__FILE__) . '/install.php') . ' ' . escapeshellarg($config_file_path) . ' ' . $multisite); |
|
| 58 | 58 | |
| 59 | -if ( $multisite ) { |
|
| 59 | +if ($multisite) { |
|
| 60 | 60 | echo "Running as multisite..." . PHP_EOL; |
| 61 | - define( 'MULTISITE', true ); |
|
| 62 | - define( 'SUBDOMAIN_INSTALL', false ); |
|
| 61 | + define('MULTISITE', true); |
|
| 62 | + define('SUBDOMAIN_INSTALL', false); |
|
| 63 | 63 | $GLOBALS['base'] = '/'; |
| 64 | 64 | } else { |
| 65 | 65 | echo "Running as single site... To run multisite, use -c tests/phpunit/multisite.xml" . PHP_EOL; |
| 66 | 66 | } |
| 67 | -unset( $multisite ); |
|
| 67 | +unset($multisite); |
|
| 68 | 68 | |
| 69 | -require_once dirname( __FILE__ ) . '/functions.php'; |
|
| 69 | +require_once dirname(__FILE__) . '/functions.php'; |
|
| 70 | 70 | |
| 71 | 71 | $GLOBALS['_wp_die_disabled'] = false; |
| 72 | 72 | // Allow tests to override wp_die |
| 73 | -tests_add_filter( 'wp_die_handler', '_wp_die_handler_filter' ); |
|
| 73 | +tests_add_filter('wp_die_handler', '_wp_die_handler_filter'); |
|
| 74 | 74 | |
| 75 | 75 | // Preset WordPress options defined in bootstrap file. |
| 76 | 76 | // Used to activate themes, plugins, as well as other settings. |
| 77 | -if(isset($GLOBALS['wp_tests_options'])) { |
|
| 78 | - function wp_tests_options( $value ) { |
|
| 79 | - $key = substr( current_filter(), strlen( 'pre_option_' ) ); |
|
| 77 | +if (isset($GLOBALS['wp_tests_options'])) { |
|
| 78 | + function wp_tests_options($value) { |
|
| 79 | + $key = substr(current_filter(), strlen('pre_option_')); |
|
| 80 | 80 | return $GLOBALS['wp_tests_options'][$key]; |
| 81 | 81 | } |
| 82 | 82 | |
| 83 | - foreach ( array_keys( $GLOBALS['wp_tests_options'] ) as $key ) { |
|
| 84 | - tests_add_filter( 'pre_option_'.$key, 'wp_tests_options' ); |
|
| 83 | + foreach (array_keys($GLOBALS['wp_tests_options']) as $key) { |
|
| 84 | + tests_add_filter('pre_option_' . $key, 'wp_tests_options'); |
|
| 85 | 85 | } |
| 86 | 86 | } |
| 87 | 87 | |
@@ -91,14 +91,14 @@ discard block |
||
| 91 | 91 | // Delete any default posts & related data |
| 92 | 92 | _delete_all_posts(); |
| 93 | 93 | |
| 94 | -require dirname( __FILE__ ) . '/testcase.php'; |
|
| 95 | -require dirname( __FILE__ ) . '/testcase-rest-api.php'; |
|
| 96 | -require dirname( __FILE__ ) . '/testcase-xmlrpc.php'; |
|
| 97 | -require dirname( __FILE__ ) . '/testcase-ajax.php'; |
|
| 98 | -require dirname( __FILE__ ) . '/testcase-canonical.php'; |
|
| 99 | -require dirname( __FILE__ ) . '/exceptions.php'; |
|
| 100 | -require dirname( __FILE__ ) . '/utils.php'; |
|
| 101 | -require dirname( __FILE__ ) . '/spy-rest-server.php'; |
|
| 94 | +require dirname(__FILE__) . '/testcase.php'; |
|
| 95 | +require dirname(__FILE__) . '/testcase-rest-api.php'; |
|
| 96 | +require dirname(__FILE__) . '/testcase-xmlrpc.php'; |
|
| 97 | +require dirname(__FILE__) . '/testcase-ajax.php'; |
|
| 98 | +require dirname(__FILE__) . '/testcase-canonical.php'; |
|
| 99 | +require dirname(__FILE__) . '/exceptions.php'; |
|
| 100 | +require dirname(__FILE__) . '/utils.php'; |
|
| 101 | +require dirname(__FILE__) . '/spy-rest-server.php'; |
|
| 102 | 102 | |
| 103 | 103 | /** |
| 104 | 104 | * A child class of the PHP test runner. |
@@ -118,16 +118,16 @@ discard block |
||
| 118 | 118 | 'exclude-group=', |
| 119 | 119 | 'group=', |
| 120 | 120 | ); |
| 121 | - function __construct( $argv ) { |
|
| 122 | - array_shift( $argv ); |
|
| 121 | + function __construct($argv) { |
|
| 122 | + array_shift($argv); |
|
| 123 | 123 | $options = array(); |
| 124 | - while ( list( $i, $arg ) = each( $argv ) ) { |
|
| 124 | + while (list($i, $arg) = each($argv)) { |
|
| 125 | 125 | try { |
| 126 | - if ( strlen( $arg ) > 1 && $arg[0] === '-' && $arg[1] === '-' ) { |
|
| 127 | - PHPUnit_Util_Getopt::parseLongOption( substr( $arg, 2 ), $this->longOptions, $options, $argv ); |
|
| 126 | + if (strlen($arg) > 1 && $arg[0] === '-' && $arg[1] === '-') { |
|
| 127 | + PHPUnit_Util_Getopt::parseLongOption(substr($arg, 2), $this->longOptions, $options, $argv); |
|
| 128 | 128 | } |
| 129 | 129 | } |
| 130 | - catch ( PHPUnit_Framework_Exception $e ) { |
|
| 130 | + catch (PHPUnit_Framework_Exception $e) { |
|
| 131 | 131 | // Enforcing recognized arguments or correctly formed arguments is |
| 132 | 132 | // not really the concern here. |
| 133 | 133 | continue; |
@@ -140,36 +140,36 @@ discard block |
||
| 140 | 140 | 'external-http' => true, |
| 141 | 141 | ); |
| 142 | 142 | |
| 143 | - foreach ( $options as $option ) { |
|
| 144 | - switch ( $option[0] ) { |
|
| 143 | + foreach ($options as $option) { |
|
| 144 | + switch ($option[0]) { |
|
| 145 | 145 | case '--exclude-group' : |
| 146 | - foreach ( $skipped_groups as $group_name => $skipped ) { |
|
| 147 | - $skipped_groups[ $group_name ] = false; |
|
| 146 | + foreach ($skipped_groups as $group_name => $skipped) { |
|
| 147 | + $skipped_groups[$group_name] = false; |
|
| 148 | 148 | } |
| 149 | 149 | continue 2; |
| 150 | 150 | case '--group' : |
| 151 | - $groups = explode( ',', $option[1] ); |
|
| 152 | - foreach ( $groups as $group ) { |
|
| 153 | - if ( is_numeric( $group ) || preg_match( '/^(UT|Plugin)\d+$/', $group ) ) { |
|
| 154 | - WP_UnitTestCase::forceTicket( $group ); |
|
| 151 | + $groups = explode(',', $option[1]); |
|
| 152 | + foreach ($groups as $group) { |
|
| 153 | + if (is_numeric($group) || preg_match('/^(UT|Plugin)\d+$/', $group)) { |
|
| 154 | + WP_UnitTestCase::forceTicket($group); |
|
| 155 | 155 | } |
| 156 | 156 | } |
| 157 | 157 | |
| 158 | - foreach ( $skipped_groups as $group_name => $skipped ) { |
|
| 159 | - if ( in_array( $group_name, $groups ) ) { |
|
| 160 | - $skipped_groups[ $group_name ] = false; |
|
| 158 | + foreach ($skipped_groups as $group_name => $skipped) { |
|
| 159 | + if (in_array($group_name, $groups)) { |
|
| 160 | + $skipped_groups[$group_name] = false; |
|
| 161 | 161 | } |
| 162 | 162 | } |
| 163 | 163 | continue 2; |
| 164 | 164 | } |
| 165 | 165 | } |
| 166 | 166 | |
| 167 | - $skipped_groups = array_filter( $skipped_groups ); |
|
| 168 | - foreach ( $skipped_groups as $group_name => $skipped ) { |
|
| 169 | - echo sprintf( 'Not running %1$s tests. To execute these, use --group %1$s.', $group_name ) . PHP_EOL; |
|
| 167 | + $skipped_groups = array_filter($skipped_groups); |
|
| 168 | + foreach ($skipped_groups as $group_name => $skipped) { |
|
| 169 | + echo sprintf('Not running %1$s tests. To execute these, use --group %1$s.', $group_name) . PHP_EOL; |
|
| 170 | 170 | } |
| 171 | 171 | |
| 172 | - if ( ! isset( $skipped_groups['external-http'] ) ) { |
|
| 172 | + if (!isset($skipped_groups['external-http'])) { |
|
| 173 | 173 | echo PHP_EOL; |
| 174 | 174 | echo 'External HTTP skipped tests can be caused by timeouts.' . PHP_EOL; |
| 175 | 175 | echo 'If this changeset includes changes to HTTP, make sure there are no timeouts.' . PHP_EOL; |
@@ -177,4 +177,4 @@ discard block |
||
| 177 | 177 | } |
| 178 | 178 | } |
| 179 | 179 | } |
| 180 | -new WP_PHPUnit_Util_Getopt( $_SERVER['argv'] ); |
|
| 180 | +new WP_PHPUnit_Util_Getopt($_SERVER['argv']); |
|
@@ -7,9 +7,10 @@ discard block |
||
| 7 | 7 | $config_file_path = dirname( dirname( __FILE__ ) ); |
| 8 | 8 | if ( ! file_exists( $config_file_path . '/wp-tests-config.php' ) ) { |
| 9 | 9 | // Support the config file from the root of the develop repository. |
| 10 | - if ( basename( $config_file_path ) === 'phpunit' && basename( dirname( $config_file_path ) ) === 'tests' ) |
|
| 11 | - $config_file_path = dirname( dirname( $config_file_path ) ); |
|
| 12 | -} |
|
| 10 | + if ( basename( $config_file_path ) === 'phpunit' && basename( dirname( $config_file_path ) ) === 'tests' ) { |
|
| 11 | + $config_file_path = dirname( dirname( $config_file_path ) ); |
|
| 12 | + } |
|
| 13 | + } |
|
| 13 | 14 | $config_file_path .= '/wp-tests-config.php'; |
| 14 | 15 | |
| 15 | 16 | /* |
@@ -26,8 +27,9 @@ discard block |
||
| 26 | 27 | define( 'WP_TESTS_TABLE_PREFIX', $table_prefix ); |
| 27 | 28 | define( 'DIR_TESTDATA', dirname( __FILE__ ) . '/../data' ); |
| 28 | 29 | |
| 29 | -if ( ! defined( 'WP_TESTS_FORCE_KNOWN_BUGS' ) ) |
|
| 30 | +if ( ! defined( 'WP_TESTS_FORCE_KNOWN_BUGS' ) ) { |
|
| 30 | 31 | define( 'WP_TESTS_FORCE_KNOWN_BUGS', false ); |
| 32 | +} |
|
| 31 | 33 | |
| 32 | 34 | // Cron tries to make an HTTP request to the blog, which always fails, because tests are run in CLI mode only |
| 33 | 35 | define( 'DISABLE_WP_CRON', true ); |
@@ -126,8 +128,7 @@ discard block |
||
| 126 | 128 | if ( strlen( $arg ) > 1 && $arg[0] === '-' && $arg[1] === '-' ) { |
| 127 | 129 | PHPUnit_Util_Getopt::parseLongOption( substr( $arg, 2 ), $this->longOptions, $options, $argv ); |
| 128 | 130 | } |
| 129 | - } |
|
| 130 | - catch ( PHPUnit_Framework_Exception $e ) { |
|
| 131 | + } catch ( PHPUnit_Framework_Exception $e ) { |
|
| 131 | 132 | // Enforcing recognized arguments or correctly formed arguments is |
| 132 | 133 | // not really the concern here. |
| 133 | 134 | continue; |