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.
84 lines
2.1 KiB
PHP
84 lines
2.1 KiB
PHP
<?php declare(strict_types=1);
|
|
/*
|
|
* This file is part of sebastian/lines-of-code.
|
|
*
|
|
* (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\LinesOfCode;
|
|
|
|
use function substr_count;
|
|
use PhpParser\Error;
|
|
use PhpParser\Node;
|
|
use PhpParser\NodeTraverser;
|
|
use PhpParser\ParserFactory;
|
|
|
|
final class Counter
|
|
{
|
|
/**
|
|
* @throws RuntimeException
|
|
*/
|
|
public function countInSourceFile(string $sourceFile): LinesOfCode
|
|
{
|
|
return $this->countInSourceString(file_get_contents($sourceFile));
|
|
}
|
|
|
|
/**
|
|
* @throws RuntimeException
|
|
*/
|
|
public function countInSourceString(string $source): LinesOfCode
|
|
{
|
|
$linesOfCode = substr_count($source, "\n");
|
|
|
|
if ($linesOfCode === 0 && !empty($source)) {
|
|
$linesOfCode = 1;
|
|
}
|
|
|
|
try {
|
|
$nodes = (new ParserFactory)->createForHostVersion()->parse($source);
|
|
|
|
assert($nodes !== null);
|
|
|
|
return $this->countInAbstractSyntaxTree($linesOfCode, $nodes);
|
|
|
|
// @codeCoverageIgnoreStart
|
|
} catch (Error $error) {
|
|
throw new RuntimeException(
|
|
$error->getMessage(),
|
|
(int) $error->getCode(),
|
|
$error
|
|
);
|
|
}
|
|
// @codeCoverageIgnoreEnd
|
|
}
|
|
|
|
/**
|
|
* @param Node[] $nodes
|
|
*
|
|
* @throws RuntimeException
|
|
*/
|
|
public function countInAbstractSyntaxTree(int $linesOfCode, array $nodes): LinesOfCode
|
|
{
|
|
$traverser = new NodeTraverser;
|
|
$visitor = new LineCountingVisitor($linesOfCode);
|
|
|
|
$traverser->addVisitor($visitor);
|
|
|
|
try {
|
|
/* @noinspection UnusedFunctionResultInspection */
|
|
$traverser->traverse($nodes);
|
|
// @codeCoverageIgnoreStart
|
|
} catch (Error $error) {
|
|
throw new RuntimeException(
|
|
$error->getMessage(),
|
|
(int) $error->getCode(),
|
|
$error
|
|
);
|
|
}
|
|
// @codeCoverageIgnoreEnd
|
|
|
|
return $visitor->result();
|
|
}
|
|
}
|