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.
47 lines
1.4 KiB
PHP
47 lines
1.4 KiB
PHP
<?php declare(strict_types = 1);
|
|
/*
|
|
* This file is part of PharIo\Manifest.
|
|
*
|
|
* Copyright (c) Arne Blankerts <arne@blankerts.de>, Sebastian Heuer <sebastian@phpeople.de>, Sebastian Bergmann <sebastian@phpunit.de> and contributors
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*
|
|
*/
|
|
namespace PharIo\Manifest;
|
|
|
|
use function sprintf;
|
|
|
|
class ManifestLoader {
|
|
public static function fromFile(string $filename): Manifest {
|
|
try {
|
|
return (new ManifestDocumentMapper())->map(
|
|
ManifestDocument::fromFile($filename)
|
|
);
|
|
} catch (Exception $e) {
|
|
throw new ManifestLoaderException(
|
|
sprintf('Loading %s failed.', $filename),
|
|
(int)$e->getCode(),
|
|
$e
|
|
);
|
|
}
|
|
}
|
|
|
|
public static function fromPhar(string $filename): Manifest {
|
|
return self::fromFile('phar://' . $filename . '/manifest.xml');
|
|
}
|
|
|
|
public static function fromString(string $manifest): Manifest {
|
|
try {
|
|
return (new ManifestDocumentMapper())->map(
|
|
ManifestDocument::fromString($manifest)
|
|
);
|
|
} catch (Exception $e) {
|
|
throw new ManifestLoaderException(
|
|
'Processing string failed',
|
|
(int)$e->getCode(),
|
|
$e
|
|
);
|
|
}
|
|
}
|
|
}
|