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.
115 lines
2.6 KiB
PHP
115 lines
2.6 KiB
PHP
<?php declare(strict_types=1);
|
|
/*
|
|
* This file is part of phpunit/php-file-iterator.
|
|
*
|
|
* (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\FileIterator;
|
|
|
|
use const DIRECTORY_SEPARATOR;
|
|
use function array_unique;
|
|
use function count;
|
|
use function dirname;
|
|
use function explode;
|
|
use function is_file;
|
|
use function is_string;
|
|
use function realpath;
|
|
use function sort;
|
|
|
|
class Facade
|
|
{
|
|
/**
|
|
* @param array|string $paths
|
|
* @param array|string $suffixes
|
|
* @param array|string $prefixes
|
|
*/
|
|
public function getFilesAsArray($paths, $suffixes = '', $prefixes = '', array $exclude = [], bool $commonPath = false): array
|
|
{
|
|
if (is_string($paths)) {
|
|
$paths = [$paths];
|
|
}
|
|
|
|
$iterator = (new Factory)->getFileIterator($paths, $suffixes, $prefixes, $exclude);
|
|
|
|
$files = [];
|
|
|
|
foreach ($iterator as $file) {
|
|
$file = $file->getRealPath();
|
|
|
|
if ($file) {
|
|
$files[] = $file;
|
|
}
|
|
}
|
|
|
|
foreach ($paths as $path) {
|
|
if (is_file($path)) {
|
|
$files[] = realpath($path);
|
|
}
|
|
}
|
|
|
|
$files = array_unique($files);
|
|
sort($files);
|
|
|
|
if ($commonPath) {
|
|
return [
|
|
'commonPath' => $this->getCommonPath($files),
|
|
'files' => $files,
|
|
];
|
|
}
|
|
|
|
return $files;
|
|
}
|
|
|
|
protected function getCommonPath(array $files): string
|
|
{
|
|
$count = count($files);
|
|
|
|
if ($count === 0) {
|
|
return '';
|
|
}
|
|
|
|
if ($count === 1) {
|
|
return dirname($files[0]) . DIRECTORY_SEPARATOR;
|
|
}
|
|
|
|
$_files = [];
|
|
|
|
foreach ($files as $file) {
|
|
$_files[] = $_fileParts = explode(DIRECTORY_SEPARATOR, $file);
|
|
|
|
if (empty($_fileParts[0])) {
|
|
$_fileParts[0] = DIRECTORY_SEPARATOR;
|
|
}
|
|
}
|
|
|
|
$common = '';
|
|
$done = false;
|
|
$j = 0;
|
|
$count--;
|
|
|
|
while (!$done) {
|
|
for ($i = 0; $i < $count; $i++) {
|
|
if ($_files[$i][$j] != $_files[$i + 1][$j]) {
|
|
$done = true;
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!$done) {
|
|
$common .= $_files[0][$j];
|
|
|
|
if ($j > 0) {
|
|
$common .= DIRECTORY_SEPARATOR;
|
|
}
|
|
}
|
|
|
|
$j++;
|
|
}
|
|
|
|
return DIRECTORY_SEPARATOR . $common;
|
|
}
|
|
}
|