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.
98 lines
2.6 KiB
PHP
98 lines
2.6 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;
|
|
|
|
/**
|
|
* @psalm-immutable
|
|
*/
|
|
final class LinesOfCode
|
|
{
|
|
/**
|
|
* @var int
|
|
*/
|
|
private $linesOfCode;
|
|
|
|
/**
|
|
* @var int
|
|
*/
|
|
private $commentLinesOfCode;
|
|
|
|
/**
|
|
* @var int
|
|
*/
|
|
private $nonCommentLinesOfCode;
|
|
|
|
/**
|
|
* @var int
|
|
*/
|
|
private $logicalLinesOfCode;
|
|
|
|
/**
|
|
* @throws IllogicalValuesException
|
|
* @throws NegativeValueException
|
|
*/
|
|
public function __construct(int $linesOfCode, int $commentLinesOfCode, int $nonCommentLinesOfCode, int $logicalLinesOfCode)
|
|
{
|
|
if ($linesOfCode < 0) {
|
|
throw new NegativeValueException('$linesOfCode must not be negative');
|
|
}
|
|
|
|
if ($commentLinesOfCode < 0) {
|
|
throw new NegativeValueException('$commentLinesOfCode must not be negative');
|
|
}
|
|
|
|
if ($nonCommentLinesOfCode < 0) {
|
|
throw new NegativeValueException('$nonCommentLinesOfCode must not be negative');
|
|
}
|
|
|
|
if ($logicalLinesOfCode < 0) {
|
|
throw new NegativeValueException('$logicalLinesOfCode must not be negative');
|
|
}
|
|
|
|
if ($linesOfCode - $commentLinesOfCode !== $nonCommentLinesOfCode) {
|
|
throw new IllogicalValuesException('$linesOfCode !== $commentLinesOfCode + $nonCommentLinesOfCode');
|
|
}
|
|
|
|
$this->linesOfCode = $linesOfCode;
|
|
$this->commentLinesOfCode = $commentLinesOfCode;
|
|
$this->nonCommentLinesOfCode = $nonCommentLinesOfCode;
|
|
$this->logicalLinesOfCode = $logicalLinesOfCode;
|
|
}
|
|
|
|
public function linesOfCode(): int
|
|
{
|
|
return $this->linesOfCode;
|
|
}
|
|
|
|
public function commentLinesOfCode(): int
|
|
{
|
|
return $this->commentLinesOfCode;
|
|
}
|
|
|
|
public function nonCommentLinesOfCode(): int
|
|
{
|
|
return $this->nonCommentLinesOfCode;
|
|
}
|
|
|
|
public function logicalLinesOfCode(): int
|
|
{
|
|
return $this->logicalLinesOfCode;
|
|
}
|
|
|
|
public function plus(self $other): self
|
|
{
|
|
return new self(
|
|
$this->linesOfCode() + $other->linesOfCode(),
|
|
$this->commentLinesOfCode() + $other->commentLinesOfCode(),
|
|
$this->nonCommentLinesOfCode() + $other->nonCommentLinesOfCode(),
|
|
$this->logicalLinesOfCode() + $other->logicalLinesOfCode(),
|
|
);
|
|
}
|
|
}
|