Implements automatic creation of required plugin pages (Community Login, Trainer Registration, Trainer Dashboard) upon plugin activation. This addresses E2E test failures caused by missing pages in the test environment. - Adds activation hook in `hvac-community-events.php` to call `hvac_ce_create_required_pages`. - The callback function checks for existing pages by slug and creates them using `wp_insert_post` if missing. Includes debug logging. Also fixes issues identified during E2E test debugging: - Corrects fatal error in `includes/community/class-login-handler.php` by replacing undefined constant `HVAC_COMMUNITY_EVENTS_PATH` with `HVAC_CE_PLUGIN_DIR`. - Updates `tests/e2e/tests/login.spec.ts` to use the correct selector `#wp-submit` for the login form submit button instead of `button[type="submit"]`. Documentation updates: - Adds `docs/automatic-page-creation-plan.md`. - Updates `README.md` regarding automatic page creation. - Updates Memory Bank files (`decisionLog.md`, `progress.md`, `activeContext.md`). Note: Activation hook logging did not appear during WP-CLI activation, requiring further investigation if page creation issues persist. E2E test confirmation pending.
73 lines
2.1 KiB
PHP
73 lines
2.1 KiB
PHP
<?php declare(strict_types=1);
|
|
/*
|
|
* This file is part of phpunit/php-timer.
|
|
*
|
|
* (c) Sebastian Bergmann <sebastian@phpunit.de>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
namespace SebastianBergmann\Timer;
|
|
|
|
use function is_float;
|
|
use function memory_get_peak_usage;
|
|
use function microtime;
|
|
use function sprintf;
|
|
|
|
final class ResourceUsageFormatter
|
|
{
|
|
/**
|
|
* @psalm-var array<string,int>
|
|
*/
|
|
private const SIZES = [
|
|
'GB' => 1073741824,
|
|
'MB' => 1048576,
|
|
'KB' => 1024,
|
|
];
|
|
|
|
public function resourceUsage(Duration $duration): string
|
|
{
|
|
return sprintf(
|
|
'Time: %s, Memory: %s',
|
|
$duration->asString(),
|
|
$this->bytesToString(memory_get_peak_usage(true))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @throws TimeSinceStartOfRequestNotAvailableException
|
|
*/
|
|
public function resourceUsageSinceStartOfRequest(): string
|
|
{
|
|
if (!isset($_SERVER['REQUEST_TIME_FLOAT'])) {
|
|
throw new TimeSinceStartOfRequestNotAvailableException(
|
|
'Cannot determine time at which the request started because $_SERVER[\'REQUEST_TIME_FLOAT\'] is not available'
|
|
);
|
|
}
|
|
|
|
if (!is_float($_SERVER['REQUEST_TIME_FLOAT'])) {
|
|
throw new TimeSinceStartOfRequestNotAvailableException(
|
|
'Cannot determine time at which the request started because $_SERVER[\'REQUEST_TIME_FLOAT\'] is not of type float'
|
|
);
|
|
}
|
|
|
|
return $this->resourceUsage(
|
|
Duration::fromMicroseconds(
|
|
(1000000 * (microtime(true) - $_SERVER['REQUEST_TIME_FLOAT']))
|
|
)
|
|
);
|
|
}
|
|
|
|
private function bytesToString(int $bytes): string
|
|
{
|
|
foreach (self::SIZES as $unit => $value) {
|
|
if ($bytes >= $value) {
|
|
return sprintf('%.2f %s', $bytes >= 1024 ? $bytes / $value : $bytes, $unit);
|
|
}
|
|
}
|
|
|
|
// @codeCoverageIgnoreStart
|
|
return $bytes . ' byte' . ($bytes !== 1 ? 's' : '');
|
|
// @codeCoverageIgnoreEnd
|
|
}
|
|
}
|