mirror of
https://github.com/Karaka-Management/phpOMS.git
synced 2026-02-12 06:48:41 +00:00
unit tests and bug fixes
This commit is contained in:
parent
894604c406
commit
fa7fb0f188
|
|
@ -18,6 +18,7 @@ use phpOMS\Config\SettingsInterface;
|
||||||
use phpOMS\DataStorage\Database\DatabasePool;
|
use phpOMS\DataStorage\Database\DatabasePool;
|
||||||
use phpOMS\DataStorage\Database\Schema\Builder as SchemaBuilder;
|
use phpOMS\DataStorage\Database\Schema\Builder as SchemaBuilder;
|
||||||
use phpOMS\System\File\Local\Directory;
|
use phpOMS\System\File\Local\Directory;
|
||||||
|
use phpOMS\Autoloader;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Installer abstract class.
|
* Installer abstract class.
|
||||||
|
|
@ -132,6 +133,11 @@ abstract class InstallerAbstract
|
||||||
$classPath = \substr(\realpath(static::PATH) . '/Status', \strlen(\realpath(__DIR__ . '/../../')));
|
$classPath = \substr(\realpath(static::PATH) . '/Status', \strlen(\realpath(__DIR__ . '/../../')));
|
||||||
|
|
||||||
$class = \str_replace('/', '\\', $classPath);
|
$class = \str_replace('/', '\\', $classPath);
|
||||||
|
|
||||||
|
if (!Autoloader::exists($class)) {
|
||||||
|
throw new \UnexpectedValueException($class); // @codeCoverageIgnore
|
||||||
|
}
|
||||||
|
|
||||||
$class::activate($dbPool, $info);
|
$class::activate($dbPool, $info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -150,6 +156,10 @@ abstract class InstallerAbstract
|
||||||
|
|
||||||
$class = \str_replace('/', '\\', $classPath);
|
$class = \str_replace('/', '\\', $classPath);
|
||||||
|
|
||||||
|
if (!Autoloader::exists($class)) {
|
||||||
|
throw new \UnexpectedValueException($class); // @codeCoverageIgnore
|
||||||
|
}
|
||||||
|
|
||||||
$class::clearRoutes();
|
$class::clearRoutes();
|
||||||
$class::clearHooks();
|
$class::clearHooks();
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -84,7 +84,6 @@ final class PostgresConnection extends ConnectionAbstract
|
||||||
} catch (\PDOException $e) {
|
} catch (\PDOException $e) {
|
||||||
$this->con = new NullPDO();
|
$this->con = new NullPDO();
|
||||||
$this->status = DatabaseStatus::MISSING_DATABASE;
|
$this->status = DatabaseStatus::MISSING_DATABASE;
|
||||||
throw new InvalidConnectionConfigException((string) \json_encode($this->dbdata));
|
|
||||||
} finally {
|
} finally {
|
||||||
$this->dbdata['password'] = '****';
|
$this->dbdata['password'] = '****';
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -84,7 +84,6 @@ final class SqlServerConnection extends ConnectionAbstract
|
||||||
} catch (\PDOException $e) {
|
} catch (\PDOException $e) {
|
||||||
$this->con = new NullPDO();
|
$this->con = new NullPDO();
|
||||||
$this->status = DatabaseStatus::MISSING_DATABASE;
|
$this->status = DatabaseStatus::MISSING_DATABASE;
|
||||||
throw new InvalidConnectionConfigException((string) \json_encode($this->dbdata));
|
|
||||||
} finally {
|
} finally {
|
||||||
$this->dbdata['password'] = '****';
|
$this->dbdata['password'] = '****';
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -352,18 +352,6 @@ class Builder extends BuilderAbstract
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Creating new.
|
|
||||||
*
|
|
||||||
* @return Builder
|
|
||||||
*
|
|
||||||
* @since 1.0.0
|
|
||||||
*/
|
|
||||||
public function newQuery() : self
|
|
||||||
{
|
|
||||||
return new self($this->connection, $this->isReadOnly);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Parsing to sql string.
|
* Parsing to sql string.
|
||||||
*
|
*
|
||||||
|
|
|
||||||
|
|
@ -202,17 +202,19 @@ final class HttpResponse extends ResponseAbstract implements RenderableInterface
|
||||||
*
|
*
|
||||||
* This is helpful in case the output buffering should be stopped for streamed/chunked responses (e.g. large data)
|
* This is helpful in case the output buffering should be stopped for streamed/chunked responses (e.g. large data)
|
||||||
*
|
*
|
||||||
|
* @param int $levels Levels to close
|
||||||
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
public function endAllOutputBuffering() : void
|
public function endAllOutputBuffering(int $levels = 0) : void
|
||||||
{
|
{
|
||||||
if (!$this->header->isLocked()) {
|
if (!$this->header->isLocked()) {
|
||||||
$this->header->push();
|
$this->header->push();
|
||||||
}
|
}
|
||||||
|
|
||||||
$levels = \ob_get_level();
|
$levels = $levels === 0 ? \ob_get_level() : $levels;
|
||||||
for ($i = 0; $i < $levels; ++$i) {
|
for ($i = 0; $i < $levels; ++$i) {
|
||||||
\ob_end_clean();
|
\ob_end_clean();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -461,6 +461,14 @@ class Email implements MessageInterface
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getFrom() : array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
$this->from,
|
||||||
|
$this->fromName,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets message type to html or plain.
|
* Sets message type to html or plain.
|
||||||
*
|
*
|
||||||
|
|
@ -475,6 +483,16 @@ class Email implements MessageInterface
|
||||||
$this->contentType = $isHtml ? MimeType::M_HTML : MimeType::M_TEXT;
|
$this->contentType = $isHtml ? MimeType::M_HTML : MimeType::M_TEXT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getContentType() : string
|
||||||
|
{
|
||||||
|
return $this->contentType;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function isHtml() : bool
|
||||||
|
{
|
||||||
|
return $this->contentType === MimeType::M_HTML;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a "To" address.
|
* Add a "To" address.
|
||||||
*
|
*
|
||||||
|
|
@ -903,7 +921,7 @@ class Email implements MessageInterface
|
||||||
$bytes = \random_bytes($len);
|
$bytes = \random_bytes($len);
|
||||||
|
|
||||||
if ($bytes === '') {
|
if ($bytes === '') {
|
||||||
$bytes = \hash('sha256', \uniqid((string) \mt_rand(), true), true);
|
$bytes = \hash('sha256', \uniqid((string) \mt_rand(), true), true); // @codeCoverageIgnore
|
||||||
}
|
}
|
||||||
|
|
||||||
return \str_replace(['=', '+', '/'], '', \base64_encode(\hash('sha256', $bytes, true)));
|
return \str_replace(['=', '+', '/'], '', \base64_encode(\hash('sha256', $bytes, true)));
|
||||||
|
|
@ -1804,7 +1822,7 @@ class Email implements MessageInterface
|
||||||
*/
|
*/
|
||||||
public function addStringAttachment(
|
public function addStringAttachment(
|
||||||
string $string,
|
string $string,
|
||||||
string $filename ,
|
string $filename,
|
||||||
string $encoding = EncodingType::E_BASE64,
|
string $encoding = EncodingType::E_BASE64,
|
||||||
string $type = '',
|
string $type = '',
|
||||||
string $disposition = 'attachment'
|
string $disposition = 'attachment'
|
||||||
|
|
@ -2090,7 +2108,7 @@ class Email implements MessageInterface
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
private static function normalizeBreaks($text, $breaktype) : string
|
private static function normalizeBreaks(string $text, string $breaktype) : string
|
||||||
{
|
{
|
||||||
$text = \str_replace(["\r\n", "\r"], "\n", $text);
|
$text = \str_replace(["\r\n", "\r"], "\n", $text);
|
||||||
|
|
||||||
|
|
@ -2259,7 +2277,7 @@ class Email implements MessageInterface
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
public function dkimAdd($headersLine, $subject, $body) : string
|
public function dkimAdd(string $headersLine, string $subject, string $body) : string
|
||||||
{
|
{
|
||||||
$DKIMsignatureType = 'rsa-sha256';
|
$DKIMsignatureType = 'rsa-sha256';
|
||||||
$DKIMcanonicalization = 'relaxed/simple';
|
$DKIMcanonicalization = 'relaxed/simple';
|
||||||
|
|
|
||||||
|
|
@ -18,6 +18,7 @@ use phpOMS\Application\ApplicationInfo;
|
||||||
use phpOMS\Config\SettingsInterface;
|
use phpOMS\Config\SettingsInterface;
|
||||||
use phpOMS\DataStorage\Database\DatabasePool;
|
use phpOMS\DataStorage\Database\DatabasePool;
|
||||||
use phpOMS\DataStorage\Database\Schema\Builder as SchemaBuilder;
|
use phpOMS\DataStorage\Database\Schema\Builder as SchemaBuilder;
|
||||||
|
use phpOMS\Autoloader;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Installer abstract class.
|
* Installer abstract class.
|
||||||
|
|
@ -98,6 +99,11 @@ abstract class InstallerAbstract
|
||||||
|
|
||||||
/** @var StatusAbstract $class */
|
/** @var StatusAbstract $class */
|
||||||
$class = \str_replace('/', '\\', $classPath);
|
$class = \str_replace('/', '\\', $classPath);
|
||||||
|
|
||||||
|
if (!Autoloader::exists($class)) {
|
||||||
|
throw new \UnexpectedValueException($class); // @codeCoverageIgnore
|
||||||
|
}
|
||||||
|
|
||||||
$class::activate($dbPool, $info);
|
$class::activate($dbPool, $info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -117,6 +123,11 @@ abstract class InstallerAbstract
|
||||||
|
|
||||||
/** @var StatusAbstract $class */
|
/** @var StatusAbstract $class */
|
||||||
$class = \str_replace('/', '\\', $classPath);
|
$class = \str_replace('/', '\\', $classPath);
|
||||||
|
|
||||||
|
if (!Autoloader::exists($class)) {
|
||||||
|
throw new \UnexpectedValueException($class); // @codeCoverageIgnore
|
||||||
|
}
|
||||||
|
|
||||||
$class::activateRoutes($info, $appInfo);
|
$class::activateRoutes($info, $appInfo);
|
||||||
$class::activateHooks($info, $appInfo);
|
$class::activateHooks($info, $appInfo);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -249,7 +249,7 @@ abstract class ModuleAbstract
|
||||||
*
|
*
|
||||||
* @param int $account Account id
|
* @param int $account Account id
|
||||||
* @param mixed $obj Response object
|
* @param mixed $obj Response object
|
||||||
* @param string $mapper Object mapper
|
* @param string | \Closure $mapper Object mapper
|
||||||
* @param string $trigger Trigger for the event manager
|
* @param string $trigger Trigger for the event manager
|
||||||
* @param string $ip Ip
|
* @param string $ip Ip
|
||||||
*
|
*
|
||||||
|
|
@ -257,17 +257,24 @@ abstract class ModuleAbstract
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
protected function createModel(int $account, mixed $obj, string $mapper, string $trigger, string $ip) : void
|
protected function createModel(int $account, mixed $obj, string | \Closure $mapper, string $trigger, string $ip) : void
|
||||||
{
|
{
|
||||||
$trigger = static::NAME . '-' . $trigger . '-create';
|
$trigger = static::NAME . '-' . $trigger . '-create';
|
||||||
|
|
||||||
$this->app->eventManager->triggerSimilar('PRE:Module:' . $trigger, '', $obj);
|
$this->app->eventManager->triggerSimilar('PRE:Module:' . $trigger, '', $obj);
|
||||||
$id = $mapper::create($obj);
|
$id = 0;
|
||||||
|
|
||||||
|
if (\is_string($mapper)) {
|
||||||
|
$id = $mapper::create($obj);
|
||||||
|
} else {
|
||||||
|
$mapper();
|
||||||
|
}
|
||||||
|
|
||||||
$this->app->eventManager->triggerSimilar('POST:Module:' . $trigger, '',
|
$this->app->eventManager->triggerSimilar('POST:Module:' . $trigger, '',
|
||||||
[
|
[
|
||||||
$account,
|
$account,
|
||||||
null, $obj,
|
null, $obj,
|
||||||
StringUtils::intHash($mapper), $trigger,
|
StringUtils::intHash(\is_string($mapper) ? $mapper : \get_class($mapper)), $trigger,
|
||||||
static::NAME,
|
static::NAME,
|
||||||
(string) $id,
|
(string) $id,
|
||||||
'',
|
'',
|
||||||
|
|
@ -281,7 +288,7 @@ abstract class ModuleAbstract
|
||||||
*
|
*
|
||||||
* @param int $account Account id
|
* @param int $account Account id
|
||||||
* @param array $objs Response object
|
* @param array $objs Response object
|
||||||
* @param string $mapper Object mapper
|
* @param string | \Closure $mapper Object mapper
|
||||||
* @param string $trigger Trigger for the event manager
|
* @param string $trigger Trigger for the event manager
|
||||||
* @param string $ip Ip
|
* @param string $ip Ip
|
||||||
*
|
*
|
||||||
|
|
@ -289,18 +296,25 @@ abstract class ModuleAbstract
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
protected function createModels(int $account, array $objs, string $mapper, string $trigger, string $ip) : void
|
protected function createModels(int $account, array $objs, string | \Closure $mapper, string $trigger, string $ip) : void
|
||||||
{
|
{
|
||||||
$trigger = static::NAME . '-' . $trigger . '-create';
|
$trigger = static::NAME . '-' . $trigger . '-create';
|
||||||
|
|
||||||
foreach ($objs as $obj) {
|
foreach ($objs as $obj) {
|
||||||
$this->app->eventManager->triggerSimilar('PRE:Module:' . $trigger, '', $obj);
|
$this->app->eventManager->triggerSimilar('PRE:Module:' . $trigger, '', $obj);
|
||||||
$id = $mapper::create($obj);
|
$id = 0;
|
||||||
|
|
||||||
|
if (\is_string($mapper)) {
|
||||||
|
$id = $mapper::create($obj);
|
||||||
|
} else {
|
||||||
|
$mapper();
|
||||||
|
}
|
||||||
|
|
||||||
$this->app->eventManager->triggerSimilar('POST:Module:' . $trigger, '',
|
$this->app->eventManager->triggerSimilar('POST:Module:' . $trigger, '',
|
||||||
[
|
[
|
||||||
$account,
|
$account,
|
||||||
null, $obj,
|
null, $obj,
|
||||||
StringUtils::intHash($mapper), $trigger,
|
StringUtils::intHash(\is_string($mapper) ? $mapper : \get_class($mapper)), $trigger,
|
||||||
static::NAME,
|
static::NAME,
|
||||||
(string) $id,
|
(string) $id,
|
||||||
'',
|
'',
|
||||||
|
|
@ -316,7 +330,7 @@ abstract class ModuleAbstract
|
||||||
* @param int $account Account id
|
* @param int $account Account id
|
||||||
* @param mixed $old Response object old
|
* @param mixed $old Response object old
|
||||||
* @param mixed $new Response object new
|
* @param mixed $new Response object new
|
||||||
* @param \Closure|string $mapper Object mapper
|
* @param string | \Closure $mapper Object mapper
|
||||||
* @param string $trigger Trigger for the event manager
|
* @param string $trigger Trigger for the event manager
|
||||||
* @param string $ip Ip
|
* @param string $ip Ip
|
||||||
*
|
*
|
||||||
|
|
@ -353,7 +367,7 @@ abstract class ModuleAbstract
|
||||||
*
|
*
|
||||||
* @param int $account Account id
|
* @param int $account Account id
|
||||||
* @param mixed $obj Response object
|
* @param mixed $obj Response object
|
||||||
* @param string $mapper Object mapper
|
* @param string | \Closure $mapper Object mapper
|
||||||
* @param string $trigger Trigger for the event manager
|
* @param string $trigger Trigger for the event manager
|
||||||
* @param string $ip Ip
|
* @param string $ip Ip
|
||||||
*
|
*
|
||||||
|
|
@ -361,17 +375,24 @@ abstract class ModuleAbstract
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
protected function deleteModel(int $account, mixed $obj, string $mapper, string $trigger, string $ip) : void
|
protected function deleteModel(int $account, mixed $obj, string | \Closure $mapper, string $trigger, string $ip) : void
|
||||||
{
|
{
|
||||||
$trigger = static::NAME . '-' . $trigger . '-delete';
|
$trigger = static::NAME . '-' . $trigger . '-delete';
|
||||||
|
|
||||||
$this->app->eventManager->triggerSimilar('PRE:Module:' . $trigger, '', $obj);
|
$this->app->eventManager->triggerSimilar('PRE:Module:' . $trigger, '', $obj);
|
||||||
$id = $mapper::delete($obj);
|
$id = 0;
|
||||||
|
|
||||||
|
if (\is_string($mapper)) {
|
||||||
|
$id = $mapper::delete($obj);
|
||||||
|
} else {
|
||||||
|
$mapper();
|
||||||
|
}
|
||||||
|
|
||||||
$this->app->eventManager->triggerSimilar('POST:Module:' . $trigger, '',
|
$this->app->eventManager->triggerSimilar('POST:Module:' . $trigger, '',
|
||||||
[
|
[
|
||||||
$account,
|
$account,
|
||||||
$obj, null,
|
$obj, null,
|
||||||
StringUtils::intHash($mapper), $trigger,
|
StringUtils::intHash(\is_string($mapper) ? $mapper : \get_class($mapper)), $trigger,
|
||||||
static::NAME,
|
static::NAME,
|
||||||
(string) $id,
|
(string) $id,
|
||||||
'',
|
'',
|
||||||
|
|
|
||||||
|
|
@ -266,10 +266,6 @@ final class ModuleManager
|
||||||
\chdir($this->modulePath);
|
\chdir($this->modulePath);
|
||||||
$files = \glob('*', \GLOB_ONLYDIR);
|
$files = \glob('*', \GLOB_ONLYDIR);
|
||||||
|
|
||||||
if ($files === false) {
|
|
||||||
return [];
|
|
||||||
}
|
|
||||||
|
|
||||||
$c = $files === false ? 0 : \count($files);
|
$c = $files === false ? 0 : \count($files);
|
||||||
for ($i = 0; $i < $c; ++$i) {
|
for ($i = 0; $i < $c; ++$i) {
|
||||||
$info = $this->loadInfo($files[$i]);
|
$info = $this->loadInfo($files[$i]);
|
||||||
|
|
@ -368,14 +364,13 @@ final class ModuleManager
|
||||||
try {
|
try {
|
||||||
$info = $this->loadInfo($module);
|
$info = $this->loadInfo($module);
|
||||||
if ($info === null) {
|
if ($info === null) {
|
||||||
return false;
|
return false; // @codeCoverageIgnore
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->deactivateModule($info);
|
$this->deactivateModule($info);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
echo $e->getMessage();
|
|
||||||
return false; // @codeCoverageIgnore
|
return false; // @codeCoverageIgnore
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -421,7 +416,7 @@ final class ModuleManager
|
||||||
try {
|
try {
|
||||||
$info = $this->loadInfo($module);
|
$info = $this->loadInfo($module);
|
||||||
if ($info === null) {
|
if ($info === null) {
|
||||||
return false;
|
return false; // @codeCoverageIgnore
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->activateModule($info);
|
$this->activateModule($info);
|
||||||
|
|
@ -506,7 +501,7 @@ final class ModuleManager
|
||||||
try {
|
try {
|
||||||
$info = $this->loadInfo($module);
|
$info = $this->loadInfo($module);
|
||||||
if ($info === null) {
|
if ($info === null) {
|
||||||
return false;
|
return false; // @codeCoverageIgnore
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->installed[$module] = $info;
|
$this->installed[$module] = $info;
|
||||||
|
|
@ -554,7 +549,7 @@ final class ModuleManager
|
||||||
try {
|
try {
|
||||||
$info = $this->loadInfo($module);
|
$info = $this->loadInfo($module);
|
||||||
if ($info === null) {
|
if ($info === null) {
|
||||||
return false;
|
return false; // @codeCoverageIgnore
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->installed[$module] = $info;
|
$this->installed[$module] = $info;
|
||||||
|
|
|
||||||
|
|
@ -300,9 +300,9 @@ final class PackageManager
|
||||||
|
|
||||||
if (StringUtils::endsWith($component, '.php')) {
|
if (StringUtils::endsWith($component, '.php')) {
|
||||||
$cmd = 'php ' . $path;
|
$cmd = 'php ' . $path;
|
||||||
} elseif (StringUtils::endsWith($component, '.sh') && OperatingSystem::getSystem() === SystemType::LINUX && \is_executable($path)) {
|
} elseif ((StringUtils::endsWith($component, '.sh') && OperatingSystem::getSystem() === SystemType::LINUX && \is_executable($path))
|
||||||
$cmd = $path;
|
|| (StringUtils::endsWith($component, '.batch') && OperatingSystem::getSystem() === SystemType::WIN && \is_executable($path))
|
||||||
} elseif (StringUtils::endsWith($component, '.batch') && OperatingSystem::getSystem() === SystemType::WIN && \is_executable($path)) {
|
) {
|
||||||
$cmd = $path;
|
$cmd = $path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -73,30 +73,7 @@ abstract class StatusAbstract
|
||||||
*/
|
*/
|
||||||
public static function activateRoutes(ModuleInfo $info, ApplicationInfo $appInfo = null) : void
|
public static function activateRoutes(ModuleInfo $info, ApplicationInfo $appInfo = null) : void
|
||||||
{
|
{
|
||||||
$directories = new Directory(static::PATH . '/Routes');
|
self::activateRoutesHooks($info, $appInfo, 'Routes');
|
||||||
|
|
||||||
/** @var Directory|File $child */
|
|
||||||
foreach ($directories as $child) {
|
|
||||||
if ($child instanceof Directory) {
|
|
||||||
foreach ($child as $file) {
|
|
||||||
if (!\is_dir(__DIR__ . '/../../' . $child->getName() . '/' . \basename($file->getName(), '.php'))
|
|
||||||
|| ($appInfo !== null && \basename($file->getName(), '.php') !== $appInfo->getInternalName())
|
|
||||||
) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
self::installRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/' . \basename($file->getName(), '.php') . '/Routes.php', $file->getPath());
|
|
||||||
}
|
|
||||||
} elseif ($child instanceof File) {
|
|
||||||
if (!\is_dir(__DIR__ . '/../../' . $child->getName())
|
|
||||||
|| ($appInfo !== null && \basename($child->getName(), '.php') !== $appInfo->getInternalName())
|
|
||||||
) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
self::installRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/Routes.php', $child->getPath());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -153,7 +130,24 @@ abstract class StatusAbstract
|
||||||
*/
|
*/
|
||||||
public static function activateHooks(ModuleInfo $info, ApplicationInfo $appInfo = null) : void
|
public static function activateHooks(ModuleInfo $info, ApplicationInfo $appInfo = null) : void
|
||||||
{
|
{
|
||||||
$directories = new Directory(static::PATH . '/Hooks');
|
self::activateRoutesHooks($info, $appInfo, 'Hooks');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Init routes and hooks.
|
||||||
|
*
|
||||||
|
* @param ModuleInfo $info Module info
|
||||||
|
* @param null|ApplicationInfo $appInfo Application info
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*
|
||||||
|
* @throws PermissionException
|
||||||
|
*
|
||||||
|
* @since 1.0.0
|
||||||
|
*/
|
||||||
|
public static function activateRoutesHooks(ModuleInfo $info, ApplicationInfo $appInfo = null, string $type) : void
|
||||||
|
{
|
||||||
|
$directories = new Directory(static::PATH . '/' . $type);
|
||||||
|
|
||||||
/** @var Directory|File $child */
|
/** @var Directory|File $child */
|
||||||
foreach ($directories as $child) {
|
foreach ($directories as $child) {
|
||||||
|
|
@ -165,7 +159,7 @@ abstract class StatusAbstract
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
self::installRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/' . \basename($file->getName(), '.php') . '/Hooks.php', $file->getPath());
|
self::installRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/' . \basename($file->getName(), '.php') . '/' . $type . '.php', $file->getPath());
|
||||||
}
|
}
|
||||||
} elseif ($child instanceof File) {
|
} elseif ($child instanceof File) {
|
||||||
if (!\is_dir(__DIR__ . '/../../' . $child->getName())
|
if (!\is_dir(__DIR__ . '/../../' . $child->getName())
|
||||||
|
|
@ -174,7 +168,7 @@ abstract class StatusAbstract
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
self::installRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/Hooks.php', $child->getPath());
|
self::installRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/' . $type . '.php', $child->getPath());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -207,7 +201,22 @@ abstract class StatusAbstract
|
||||||
*/
|
*/
|
||||||
public static function deactivateRoutes(ModuleInfo $info, ApplicationInfo $appInfo = null) : void
|
public static function deactivateRoutes(ModuleInfo $info, ApplicationInfo $appInfo = null) : void
|
||||||
{
|
{
|
||||||
$directories = new Directory(static::PATH . '/Routes');
|
self::deactivateRoutesHooks($info, $appInfo, 'Routes');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deactivate routes and hooks.
|
||||||
|
*
|
||||||
|
* @param ModuleInfo $info Module info
|
||||||
|
* @param null|ApplicationInfo $appInfo Application info
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*
|
||||||
|
* @since 1.0.0
|
||||||
|
*/
|
||||||
|
public static function deactivateRoutesHooks(ModuleInfo $info, ApplicationInfo $appInfo = null, string $type) : void
|
||||||
|
{
|
||||||
|
$directories = new Directory(static::PATH . '/'. $type);
|
||||||
|
|
||||||
/** @var Directory|File $child */
|
/** @var Directory|File $child */
|
||||||
foreach ($directories as $child) {
|
foreach ($directories as $child) {
|
||||||
|
|
@ -219,7 +228,7 @@ abstract class StatusAbstract
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
self::uninstallRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/' . \basename($file->getName(), '.php') . '/Routes.php', $file->getPath());
|
self::uninstallRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/' . \basename($file->getName(), '.php') . '/'. $type . '.php', $file->getPath());
|
||||||
}
|
}
|
||||||
} elseif ($child instanceof File) {
|
} elseif ($child instanceof File) {
|
||||||
if (!\is_dir(__DIR__ . '/../../' . $child->getName())
|
if (!\is_dir(__DIR__ . '/../../' . $child->getName())
|
||||||
|
|
@ -228,7 +237,7 @@ abstract class StatusAbstract
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
self::uninstallRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/Routes.php', $child->getPath());
|
self::uninstallRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/'. $type . '.php', $child->getPath());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -245,7 +254,7 @@ abstract class StatusAbstract
|
||||||
*
|
*
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
public static function uninstallRoutesHooks(string $destRoutePath, string $srcRoutePath) : void
|
protected static function uninstallRoutesHooks(string $destRoutePath, string $srcRoutePath) : void
|
||||||
{
|
{
|
||||||
if (!\is_file($destRoutePath)
|
if (!\is_file($destRoutePath)
|
||||||
|| !\is_file($srcRoutePath)
|
|| !\is_file($srcRoutePath)
|
||||||
|
|
@ -283,29 +292,6 @@ abstract class StatusAbstract
|
||||||
*/
|
*/
|
||||||
public static function deactivateHooks(ModuleInfo $info, ApplicationInfo $appInfo = null) : void
|
public static function deactivateHooks(ModuleInfo $info, ApplicationInfo $appInfo = null) : void
|
||||||
{
|
{
|
||||||
$directories = new Directory(static::PATH . '/Hooks');
|
self::deactivateRoutesHooks($info, $appInfo, 'Hooks');
|
||||||
|
|
||||||
/** @var Directory|File $child */
|
|
||||||
foreach ($directories as $child) {
|
|
||||||
if ($child instanceof Directory) {
|
|
||||||
foreach ($child as $file) {
|
|
||||||
if (!\is_dir(__DIR__ . '/../../' . $child->getName() . '/' . \basename($file->getName(), '.php'))
|
|
||||||
|| ($appInfo !== null && \basename($file->getName(), '.php') !== $appInfo->getInternalName())
|
|
||||||
) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
self::uninstallRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/' . \basename($file->getName(), '.php') . '/Hooks.php', $file->getPath());
|
|
||||||
}
|
|
||||||
} elseif ($child instanceof File) {
|
|
||||||
if (!\is_dir(__DIR__ . '/../../' . $child->getName())
|
|
||||||
|| ($appInfo !== null && \basename($child->getName(), '.php') !== $appInfo->getInternalName())
|
|
||||||
) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
self::uninstallRoutesHooks(__DIR__ . '/../../' . $child->getName() . '/Hooks.php', $child->getPath());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -529,6 +529,8 @@ class Graph
|
||||||
/**
|
/**
|
||||||
* Find all reachable nodes with depth first traversal (iterative)
|
* Find all reachable nodes with depth first traversal (iterative)
|
||||||
*
|
*
|
||||||
|
* Includes the node itself
|
||||||
|
*
|
||||||
* @param int|string|Node $node1 Graph node
|
* @param int|string|Node $node1 Graph node
|
||||||
*
|
*
|
||||||
* @return Node[]
|
* @return Node[]
|
||||||
|
|
@ -548,20 +550,20 @@ class Graph
|
||||||
}
|
}
|
||||||
|
|
||||||
$visited = [];
|
$visited = [];
|
||||||
$stack = [];
|
$stack = [$node1];
|
||||||
$stack[] = $node1;
|
|
||||||
|
|
||||||
while (!empty($stack)) {
|
while (!empty($stack)) {
|
||||||
$cNode = \array_pop($stack);
|
$cNode = \array_pop($stack);
|
||||||
$nodes[] = $cNode;
|
if (isset($visited[$cNode->getId()]) && $visited[$cNode->getId()] === true) {
|
||||||
|
continue;
|
||||||
if (!isset($visited[$cNode->getId()]) || $visited[$cNode->getId()] === false) {
|
|
||||||
$visited[$cNode->getId()] = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$nodes[] = $cNode;
|
||||||
|
$visited[$cNode->getId()] = true;
|
||||||
|
|
||||||
$neighbors = $cNode->getNeighbors();
|
$neighbors = $cNode->getNeighbors();
|
||||||
foreach ($neighbors as $neighbor) {
|
foreach ($neighbors as $neighbor) {
|
||||||
if (!isset($visited[$cNode->getId()]) || $visited[$cNode->getId()] === false) {
|
if (!isset($visited[$neighbor->getId()]) || $visited[$neighbor->getId()] === false) {
|
||||||
$stack[] = $neighbor;
|
$stack[] = $neighbor;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -596,6 +598,7 @@ class Graph
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get all paths between two nodes
|
* Get all paths between two nodes
|
||||||
|
* Inclides end node, but not start node in the paths
|
||||||
*
|
*
|
||||||
* @param int|string|Node $node1 Graph node
|
* @param int|string|Node $node1 Graph node
|
||||||
* @param int|string|Node $node2 Graph node
|
* @param int|string|Node $node2 Graph node
|
||||||
|
|
@ -672,16 +675,33 @@ class Graph
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$mostNodes = 0;
|
||||||
|
$mostNodesCount = 0;
|
||||||
foreach ($paths as $key => $path) {
|
foreach ($paths as $key => $path) {
|
||||||
$edges[$key] = 0;
|
$edges[$key] = 0;
|
||||||
|
$nodeCount = 0;
|
||||||
foreach ($path as $node) {
|
foreach ($path as $node) {
|
||||||
|
if ($node1->getEdgeByNeighbor($node) === null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
$edges[$key] += $node1->getEdgeByNeighbor($node)->getWeight();
|
$edges[$key] += $node1->getEdgeByNeighbor($node)->getWeight();
|
||||||
|
++$nodeCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($nodeCount > $mostNodesCount) {
|
||||||
|
$mostNodesCount = $nodeCount;
|
||||||
|
$mostNodes = $key;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
\arsort($edges);
|
if (\array_sum($edges) > 0.0) {
|
||||||
|
\arsort($edges);
|
||||||
|
|
||||||
return $paths[\array_key_first($edges)];
|
return $paths[\array_key_first($edges)];
|
||||||
|
}
|
||||||
|
|
||||||
|
return $paths[$mostNodes];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -711,20 +731,33 @@ class Graph
|
||||||
$paths = $this->getAllPathsBetweenNodes($node1, $node2);
|
$paths = $this->getAllPathsBetweenNodes($node1, $node2);
|
||||||
|
|
||||||
$edges = [];
|
$edges = [];
|
||||||
|
$leastNodes = 0;
|
||||||
|
$leastNodesCount = \PHP_INT_MAX;
|
||||||
foreach ($paths as $key => $path) {
|
foreach ($paths as $key => $path) {
|
||||||
$edges[$key] = 0;
|
$edges[$key] = 0;
|
||||||
|
$nodeCount = 0;
|
||||||
foreach ($path as $node) {
|
foreach ($path as $node) {
|
||||||
|
if ($node1->getEdgeByNeighbor($node) === null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
$edges[$key] += $node1->getEdgeByNeighbor($node)->getWeight();
|
$edges[$key] += $node1->getEdgeByNeighbor($node)->getWeight();
|
||||||
|
++$nodeCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($nodeCount < $leastNodesCount && $nodeCount > 0) {
|
||||||
|
$leastNodesCount = $nodeCount;
|
||||||
|
$leastNodes = $key;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($edges === []) {
|
if (\array_sum($edges) > 0.0) {
|
||||||
return [];
|
\asort($edges);
|
||||||
|
|
||||||
|
return $paths[\array_key_first($edges)];
|
||||||
}
|
}
|
||||||
|
|
||||||
\asort($edges);
|
return $paths[$leastNodes];
|
||||||
|
|
||||||
return $paths[\array_key_first($edges)];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
58
tests/Application/UninstallerAbstractTest.php
Normal file
58
tests/Application/UninstallerAbstractTest.php
Normal file
|
|
@ -0,0 +1,58 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Orange Management
|
||||||
|
*
|
||||||
|
* PHP Version 8.0
|
||||||
|
*
|
||||||
|
* @package tests
|
||||||
|
* @copyright Dennis Eichhorn
|
||||||
|
* @license OMS License 1.0
|
||||||
|
* @version 1.0.0
|
||||||
|
* @link https://orange-management.org
|
||||||
|
*/
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace phpOMS\tests\Application;
|
||||||
|
|
||||||
|
require_once __DIR__ . '/../Autoloader.php';
|
||||||
|
|
||||||
|
use phpOMS\Application\UninstallerAbstract;
|
||||||
|
use phpOMS\DataStorage\Database\DatabasePool;
|
||||||
|
use phpOMS\Application\ApplicationInfo;
|
||||||
|
use Model\CoreSettings;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @testdox phpOMS\tests\Application\UninstallerAbstractTest: Abstract module
|
||||||
|
*
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
class UninstallerAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
|
{
|
||||||
|
protected UninstallerAbstract $uninstaller;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function setUp() : void
|
||||||
|
{
|
||||||
|
|
||||||
|
$this->uninstaller = new class() extends UninstallerAbstract
|
||||||
|
{
|
||||||
|
public const PATH = __DIR__ . '/invalid';
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @covers phpOMS\Application\UninstallerAbstract
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testMissingDbFileUninstall() : void
|
||||||
|
{
|
||||||
|
$this->uninstaller::dropTables(
|
||||||
|
new DatabasePool(),
|
||||||
|
new ApplicationInfo(__DIR__)
|
||||||
|
);
|
||||||
|
|
||||||
|
self::assertFalse(\file_exists($this->uninstaller::PATH . '/Install/db.json'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -30,6 +30,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'insert' => [
|
'insert' => [
|
||||||
'db' => 'mysql', /* db type */
|
'db' => 'mysql', /* db type */
|
||||||
|
|
@ -39,6 +40,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'select' => [
|
'select' => [
|
||||||
'db' => 'mysql', /* db type */
|
'db' => 'mysql', /* db type */
|
||||||
|
|
@ -48,6 +50,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'update' => [
|
'update' => [
|
||||||
'db' => 'mysql', /* db type */
|
'db' => 'mysql', /* db type */
|
||||||
|
|
@ -57,6 +60,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'delete' => [
|
'delete' => [
|
||||||
'db' => 'mysql', /* db type */
|
'db' => 'mysql', /* db type */
|
||||||
|
|
@ -66,6 +70,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'schema' => [
|
'schema' => [
|
||||||
'db' => 'mysql', /* db type */
|
'db' => 'mysql', /* db type */
|
||||||
|
|
@ -75,6 +80,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
'postgresql' => [
|
'postgresql' => [
|
||||||
|
|
@ -86,6 +92,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'insert' => [
|
'insert' => [
|
||||||
'db' => 'pgsql', /* db type */
|
'db' => 'pgsql', /* db type */
|
||||||
|
|
@ -95,6 +102,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'select' => [
|
'select' => [
|
||||||
'db' => 'pgsql', /* db type */
|
'db' => 'pgsql', /* db type */
|
||||||
|
|
@ -104,6 +112,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'update' => [
|
'update' => [
|
||||||
'db' => 'pgsql', /* db type */
|
'db' => 'pgsql', /* db type */
|
||||||
|
|
@ -113,6 +122,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'delete' => [
|
'delete' => [
|
||||||
'db' => 'pgsql', /* db type */
|
'db' => 'pgsql', /* db type */
|
||||||
|
|
@ -122,6 +132,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'schema' => [
|
'schema' => [
|
||||||
'db' => 'pgsql', /* db type */
|
'db' => 'pgsql', /* db type */
|
||||||
|
|
@ -131,6 +142,7 @@ $CONFIG = [
|
||||||
'password' => 'root', /* db login password */
|
'password' => 'root', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
'sqlite' => [
|
'sqlite' => [
|
||||||
|
|
@ -138,31 +150,37 @@ $CONFIG = [
|
||||||
'db' => 'sqlite', /* db type */
|
'db' => 'sqlite', /* db type */
|
||||||
'database' => __DIR__ . '/test.sqlite', /* db name */
|
'database' => __DIR__ . '/test.sqlite', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'insert' => [
|
'insert' => [
|
||||||
'db' => 'sqlite', /* db type */
|
'db' => 'sqlite', /* db type */
|
||||||
'database' => __DIR__ . '/test.sqlite', /* db name */
|
'database' => __DIR__ . '/test.sqlite', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'select' => [
|
'select' => [
|
||||||
'db' => 'sqlite', /* db type */
|
'db' => 'sqlite', /* db type */
|
||||||
'database' => __DIR__ . '/test.sqlite', /* db name */
|
'database' => __DIR__ . '/test.sqlite', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'update' => [
|
'update' => [
|
||||||
'db' => 'sqlite', /* db type */
|
'db' => 'sqlite', /* db type */
|
||||||
'database' => __DIR__ . '/test.sqlite', /* db name */
|
'database' => __DIR__ . '/test.sqlite', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'delete' => [
|
'delete' => [
|
||||||
'db' => 'sqlite', /* db type */
|
'db' => 'sqlite', /* db type */
|
||||||
'database' => __DIR__ . '/test.sqlite', /* db name */
|
'database' => __DIR__ . '/test.sqlite', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'schema' => [
|
'schema' => [
|
||||||
'db' => 'sqlite', /* db type */
|
'db' => 'sqlite', /* db type */
|
||||||
'database' => __DIR__ . '/test.sqlite', /* db name */
|
'database' => __DIR__ . '/test.sqlite', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
'mssql' => [
|
'mssql' => [
|
||||||
|
|
@ -174,6 +192,7 @@ $CONFIG = [
|
||||||
'password' => 'R00troot', /* db login password */
|
'password' => 'R00troot', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'insert' => [
|
'insert' => [
|
||||||
'db' => 'mssql', /* db type */
|
'db' => 'mssql', /* db type */
|
||||||
|
|
@ -183,6 +202,7 @@ $CONFIG = [
|
||||||
'password' => 'R00troot', /* db login password */
|
'password' => 'R00troot', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'select' => [
|
'select' => [
|
||||||
'db' => 'mssql', /* db type */
|
'db' => 'mssql', /* db type */
|
||||||
|
|
@ -192,6 +212,7 @@ $CONFIG = [
|
||||||
'password' => 'R00troot', /* db login password */
|
'password' => 'R00troot', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'update' => [
|
'update' => [
|
||||||
'db' => 'mssql', /* db type */
|
'db' => 'mssql', /* db type */
|
||||||
|
|
@ -201,6 +222,7 @@ $CONFIG = [
|
||||||
'password' => 'R00troot', /* db login password */
|
'password' => 'R00troot', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'delete' => [
|
'delete' => [
|
||||||
'db' => 'mssql', /* db type */
|
'db' => 'mssql', /* db type */
|
||||||
|
|
@ -210,6 +232,7 @@ $CONFIG = [
|
||||||
'password' => 'R00troot', /* db login password */
|
'password' => 'R00troot', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
'schema' => [
|
'schema' => [
|
||||||
'db' => 'mssql', /* db type */
|
'db' => 'mssql', /* db type */
|
||||||
|
|
@ -219,6 +242,7 @@ $CONFIG = [
|
||||||
'password' => 'R00troot', /* db login password */
|
'password' => 'R00troot', /* db login password */
|
||||||
'database' => 'oms', /* db name */
|
'database' => 'oms', /* db name */
|
||||||
'weight' => 1000, /* db table prefix */
|
'weight' => 1000, /* db table prefix */
|
||||||
|
'datetimeformat' => 'Y-m-d H:i:s'
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
|
|
|
||||||
|
|
@ -148,4 +148,19 @@ class PostgresConnectionTest extends \PHPUnit\Framework\TestCase
|
||||||
$psql->connect();
|
$psql->connect();
|
||||||
self::assertEquals(DatabaseStatus::FAILURE, $psql->getStatus());
|
self::assertEquals(DatabaseStatus::FAILURE, $psql->getStatus());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @testdox A invalid database returns a failure
|
||||||
|
* @covers phpOMS\DataStorage\Database\Connection\PostgresConnection
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testInvalidDatabaseName() : void
|
||||||
|
{
|
||||||
|
$db = $GLOBALS['CONFIG']['db']['core']['masters']['admin'];
|
||||||
|
$db['database'] = 'invalid';
|
||||||
|
|
||||||
|
$mysql = new PostgresConnection($db);
|
||||||
|
$mysql->connect();
|
||||||
|
self::assertEquals(DatabaseStatus::MISSING_DATABASE, $mysql->getStatus());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -76,6 +76,21 @@ class SQLiteConnectionTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertEquals(DatabaseStatus::FAILURE, $sqlite->getStatus());
|
self::assertEquals(DatabaseStatus::FAILURE, $sqlite->getStatus());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @testdox A invalid database returns a failure
|
||||||
|
* @covers phpOMS\DataStorage\Database\Connection\SQLiteConnection
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testInvalidDatabaseName() : void
|
||||||
|
{
|
||||||
|
$db = $GLOBALS['CONFIG']['db']['core']['masters']['admin'];
|
||||||
|
$db['database'] = 'invalid';
|
||||||
|
|
||||||
|
$mysql = new SQLiteConnection($db);
|
||||||
|
$mysql->connect();
|
||||||
|
self::assertEquals(DatabaseStatus::MISSING_DATABASE, $mysql->getStatus());
|
||||||
|
}
|
||||||
|
|
||||||
public static function tearDownAfterClass() : void
|
public static function tearDownAfterClass() : void
|
||||||
{
|
{
|
||||||
if (\is_file($GLOBALS['CONFIG']['db']['core']['sqlite']['admin']['database'])) {
|
if (\is_file($GLOBALS['CONFIG']['db']['core']['sqlite']['admin']['database'])) {
|
||||||
|
|
|
||||||
|
|
@ -14,10 +14,13 @@ declare(strict_types=1);
|
||||||
namespace phpOMS\tests\DataStorage\Database;
|
namespace phpOMS\tests\DataStorage\Database;
|
||||||
|
|
||||||
use phpOMS\tests\DataStorage\Database\TestModel\BaseModel;
|
use phpOMS\tests\DataStorage\Database\TestModel\BaseModel;
|
||||||
|
use phpOMS\tests\DataStorage\Database\TestModel\NullBaseModel;
|
||||||
use phpOMS\tests\DataStorage\Database\TestModel\BaseModelMapper;
|
use phpOMS\tests\DataStorage\Database\TestModel\BaseModelMapper;
|
||||||
use phpOMS\tests\DataStorage\Database\TestModel\Conditional;
|
use phpOMS\tests\DataStorage\Database\TestModel\Conditional;
|
||||||
use phpOMS\tests\DataStorage\Database\TestModel\ConditionalMapper;
|
use phpOMS\tests\DataStorage\Database\TestModel\ConditionalMapper;
|
||||||
use phpOMS\tests\DataStorage\Database\TestModel\ManyToManyDirectModelMapper;
|
use phpOMS\tests\DataStorage\Database\TestModel\ManyToManyDirectModelMapper;
|
||||||
|
use phpOMS\tests\DataStorage\Database\TestModel\ManyToManyRelModel;
|
||||||
|
use phpOMS\tests\DataStorage\Database\TestModel\ManyToManyRelModelMapper;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @testdox phpOMS\tests\DataStorage\Database\DataMapperAbstractTest: Datamapper for database models
|
* @testdox phpOMS\tests\DataStorage\Database\DataMapperAbstractTest: Datamapper for database models
|
||||||
|
|
@ -158,6 +161,7 @@ class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
|
|
||||||
protected function tearDown() : void
|
protected function tearDown() : void
|
||||||
{
|
{
|
||||||
|
BaseModelMapper::clearCache();
|
||||||
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_conditional')->execute();
|
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_conditional')->execute();
|
||||||
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_base')->execute();
|
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_base')->execute();
|
||||||
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_belongs_to_one')->execute();
|
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_belongs_to_one')->execute();
|
||||||
|
|
@ -187,7 +191,24 @@ class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
public function testCreate() : void
|
public function testCreate() : void
|
||||||
{
|
{
|
||||||
self::assertGreaterThan(0, BaseModelMapper::create($this->model));
|
self::assertGreaterThan(0, BaseModelMapper::create($this->model));
|
||||||
self::assertGreaterThan(0, $this->model->id);
|
self::assertGreaterThan(0, $this->model->getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreateNullModel() : void
|
||||||
|
{
|
||||||
|
$nullModel1 = new NullBaseModel();
|
||||||
|
self::assertEquals(null, BaseModelMapper::create($nullModel1));
|
||||||
|
|
||||||
|
$nullModel2 = new NullBaseModel(77);
|
||||||
|
self::assertEquals(77, BaseModelMapper::create($nullModel2));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCreateAlreadyCreatedModel() : void
|
||||||
|
{
|
||||||
|
self::assertGreaterThan(0, $id = BaseModelMapper::create($this->model));
|
||||||
|
self::assertGreaterThan(0, $this->model->getId());
|
||||||
|
self::assertEquals($id, BaseModelMapper::create($this->model));
|
||||||
|
self::assertEquals($id, $this->model->getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -201,6 +222,23 @@ class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertGreaterThan(0, $this->modelArray['id']);
|
self::assertGreaterThan(0, $this->modelArray['id']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testCreateHasManyRelation() : void
|
||||||
|
{
|
||||||
|
$id1 = BaseModelMapper::create($this->model);
|
||||||
|
|
||||||
|
$count1 = \count($this->model->hasManyRelations);
|
||||||
|
|
||||||
|
$hasMany = new ManyToManyRelModel();
|
||||||
|
$id2 = ManyToManyRelModelMapper::create($hasMany);
|
||||||
|
|
||||||
|
BaseModelMapper::createRelation('hasManyRelations', $id1, $id2);
|
||||||
|
|
||||||
|
BaseModelMapper::clearCache();
|
||||||
|
|
||||||
|
$base = BaseModelMapper::get($id1);
|
||||||
|
self::assertCount($count1 + 1, $base->hasManyRelations);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @testdox The datamapper successfully returns a database entry as model
|
* @testdox The datamapper successfully returns a database entry as model
|
||||||
* @covers phpOMS\DataStorage\Database\DataMapperAbstract
|
* @covers phpOMS\DataStorage\Database\DataMapperAbstract
|
||||||
|
|
@ -211,7 +249,7 @@ class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
$id = BaseModelMapper::create($this->model);
|
$id = BaseModelMapper::create($this->model);
|
||||||
$modelR = BaseModelMapper::get($id);
|
$modelR = BaseModelMapper::get($id);
|
||||||
|
|
||||||
self::assertEquals($this->model->id, $modelR->id);
|
self::assertEquals($this->model->getId(), $modelR->getId());
|
||||||
self::assertEquals($this->model->string, $modelR->string);
|
self::assertEquals($this->model->string, $modelR->string);
|
||||||
self::assertEquals($this->model->int, $modelR->int);
|
self::assertEquals($this->model->int, $modelR->int);
|
||||||
self::assertEquals($this->model->bool, $modelR->bool);
|
self::assertEquals($this->model->bool, $modelR->bool);
|
||||||
|
|
@ -221,8 +259,7 @@ class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertNull($modelR->datetime_null);
|
self::assertNull($modelR->datetime_null);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @todo Orange-Management/phpOMS#227
|
* @todo Serializable and JsonSerializable data can be inserted and updated in the database but it's not possible to correctly populate a model with the data in its original format.
|
||||||
* Serializable and JsonSerializable data can be inserted and updated in the database but it's not possible to correctly populate a model with the data in its original format.
|
|
||||||
*/
|
*/
|
||||||
//self::assertEquals('123', $modelR->serializable);
|
//self::assertEquals('123', $modelR->serializable);
|
||||||
//self::assertEquals($this->model->json, $modelR->json);
|
//self::assertEquals($this->model->json, $modelR->json);
|
||||||
|
|
@ -234,15 +271,66 @@ class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertEquals(\reset($this->model->hasManyRelations)->string, \reset($modelR->hasManyRelations)->string);
|
self::assertEquals(\reset($this->model->hasManyRelations)->string, \reset($modelR->hasManyRelations)->string);
|
||||||
self::assertEquals($this->model->ownsOneSelf->string, $modelR->ownsOneSelf->string);
|
self::assertEquals($this->model->ownsOneSelf->string, $modelR->ownsOneSelf->string);
|
||||||
self::assertEquals($this->model->belongsToOne->string, $modelR->belongsToOne->string);
|
self::assertEquals($this->model->belongsToOne->string, $modelR->belongsToOne->string);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetAll() : void
|
||||||
|
{
|
||||||
|
BaseModelMapper::create($this->model);
|
||||||
|
self::assertCount(1, BaseModelMapper::getAll());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetFor() : void
|
||||||
|
{
|
||||||
|
$id = BaseModelMapper::create($this->model);
|
||||||
$for = ManyToManyDirectModelMapper::getFor($id, 'to');
|
$for = ManyToManyDirectModelMapper::getFor($id, 'to');
|
||||||
|
|
||||||
self::assertEquals(
|
self::assertEquals(
|
||||||
\reset($this->model->hasManyDirect)->string,
|
\reset($this->model->hasManyDirect)->string,
|
||||||
$for[1]->string
|
$for[1]->string
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
self::assertCount(1, BaseModelMapper::getAll());
|
public function testGetBy() : void
|
||||||
|
{
|
||||||
|
$model1 = new BaseModel();
|
||||||
|
$model1->string = '123';
|
||||||
|
|
||||||
|
$model2 = new BaseModel();
|
||||||
|
$model2->string = '456';
|
||||||
|
|
||||||
|
$id1 = BaseModelMapper::create($model1);
|
||||||
|
$id2 = BaseModelMapper::create($model2);
|
||||||
|
|
||||||
|
$by = BaseModelMapper::getBy('456', 'string');
|
||||||
|
self::assertEquals($model2->getId(), $by->getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetCached() : void
|
||||||
|
{
|
||||||
|
$id = BaseModelMapper::create($this->model);
|
||||||
|
$modelR = BaseModelMapper::get($id);
|
||||||
|
$modelR2 = BaseModelMapper::get($id);
|
||||||
|
|
||||||
|
self::assertEquals($modelR->getId(), $modelR2->getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetNewest() : void
|
||||||
|
{
|
||||||
|
$model1 = new BaseModel();
|
||||||
|
$model1->datetime = new \DateTime('now');
|
||||||
|
$id1 = BaseModelMapper::create($model1);
|
||||||
|
\sleep(1);
|
||||||
|
$model2 = new BaseModel();
|
||||||
|
$model2->datetime = new \DateTime('now');
|
||||||
|
$id2 = BaseModelMapper::create($model2);
|
||||||
|
|
||||||
|
$newest = BaseModelMapper::getNewest();
|
||||||
|
self::assertEquals($id2, \reset($newest)->getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetNullModel() : void
|
||||||
|
{
|
||||||
|
self::assertEquals(NullBaseModel::class, \get_class(BaseModelMapper::get(99)));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -437,4 +525,18 @@ class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
* Test the deletion of a model with relations (deleting relations).
|
* Test the deletion of a model with relations (deleting relations).
|
||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testDeleteHasManyRelation() : void
|
||||||
|
{
|
||||||
|
$id1 = BaseModelMapper::create($this->model);
|
||||||
|
|
||||||
|
$count1 = \count($this->model->hasManyRelations);
|
||||||
|
|
||||||
|
BaseModelMapper::deleteRelation('hasManyRelations', $id1, \reset($this->model->hasManyRelations)->id);
|
||||||
|
|
||||||
|
BaseModelMapper::clearCache();
|
||||||
|
$base = BaseModelMapper::get($id1);
|
||||||
|
|
||||||
|
self::assertCount($count1 - 1, $base->hasManyRelations);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -52,6 +52,7 @@ class MysqlGrammarTest extends \PHPUnit\Framework\TestCase
|
||||||
/**
|
/**
|
||||||
* @testdox The the grammar correctly creates and returns a database table
|
* @testdox The the grammar correctly creates and returns a database table
|
||||||
* @covers phpOMS\DataStorage\Database\Schema\Grammar\MysqlGrammar<extended>
|
* @covers phpOMS\DataStorage\Database\Schema\Grammar\MysqlGrammar<extended>
|
||||||
|
* @covers phpOMS\DataStorage\Database\Schema\Builder
|
||||||
* @group framework
|
* @group framework
|
||||||
*/
|
*/
|
||||||
public function testSchemaInputOutput() : void
|
public function testSchemaInputOutput() : void
|
||||||
|
|
|
||||||
|
|
@ -16,7 +16,7 @@ namespace phpOMS\tests\DataStorage\Database\TestModel;
|
||||||
|
|
||||||
class BaseModel
|
class BaseModel
|
||||||
{
|
{
|
||||||
public $id = 0;
|
protected $id = 0;
|
||||||
|
|
||||||
public $string = 'Base';
|
public $string = 'Base';
|
||||||
|
|
||||||
|
|
@ -83,4 +83,9 @@ class BaseModel
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getId() : int
|
||||||
|
{
|
||||||
|
return $this->id;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -16,4 +16,8 @@ namespace phpOMS\tests\DataStorage\Database\TestModel;
|
||||||
|
|
||||||
final class NullBaseModel extends BaseModel
|
final class NullBaseModel extends BaseModel
|
||||||
{
|
{
|
||||||
|
public function __construct(int $id = 0)
|
||||||
|
{
|
||||||
|
$this->id = $id;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -24,7 +24,7 @@ use phpOMS\System\MimeType;
|
||||||
*
|
*
|
||||||
* @internal
|
* @internal
|
||||||
*/
|
*/
|
||||||
class ResponseTest extends \PHPUnit\Framework\TestCase
|
class HttpResponseTest extends \PHPUnit\Framework\TestCase
|
||||||
{
|
{
|
||||||
protected HttpResponse $response;
|
protected HttpResponse $response;
|
||||||
|
|
||||||
|
|
@ -87,7 +87,7 @@ class ResponseTest extends \PHPUnit\Framework\TestCase
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @testdox Test disabling output buffering
|
* @testdox Test disabling output buffering
|
||||||
* @covers phpOMS\Message\Http\HttpResponse<extended>
|
* @covers phpOMS\Message\Http\HttpResponse
|
||||||
* @group framework
|
* @group framework
|
||||||
*/
|
*/
|
||||||
public function testEndAllOutputBuffering() : void
|
public function testEndAllOutputBuffering() : void
|
||||||
|
|
@ -100,9 +100,9 @@ class ResponseTest extends \PHPUnit\Framework\TestCase
|
||||||
\ob_start();
|
\ob_start();
|
||||||
\ob_start();
|
\ob_start();
|
||||||
|
|
||||||
self::assertEquals($start + 2, \ob_get_level());
|
self::assertEquals($start + 2, $end = \ob_get_level());
|
||||||
$this->response->endAllOutputBuffering();
|
$this->response->endAllOutputBuffering($end - $start);
|
||||||
self::assertEquals(0, \ob_get_level());
|
self::assertEquals($start, \ob_get_level());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -18,6 +18,7 @@ require_once __DIR__ . '/../../Autoloader.php';
|
||||||
|
|
||||||
use phpOMS\Message\Mail\Email;
|
use phpOMS\Message\Mail\Email;
|
||||||
use phpOMS\System\CharsetType;
|
use phpOMS\System\CharsetType;
|
||||||
|
use phpOMS\System\MimeType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @testdox phpOMS\tests\Message\MailHandlerTest: Abstract mail handler
|
* @testdox phpOMS\tests\Message\MailHandlerTest: Abstract mail handler
|
||||||
|
|
@ -46,6 +47,136 @@ class EmailTestTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertFalse($this->mail->hasInlineImage());
|
self::assertFalse($this->mail->hasInlineImage());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testFromInputOutput() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->mail->setFrom('test@orange-management.org', 'Test Name'));
|
||||||
|
self::assertEquals([0 => 'test@orange-management.org', 1 => 'Test Name'], $this->mail->getFrom());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testInvalidFromInputOutput() : void
|
||||||
|
{
|
||||||
|
self::assertFalse($this->mail->setFrom('Test Name <test-^invalid>'));
|
||||||
|
self::assertEquals([0 => '', 1 => ''], $this->mail->getFrom());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testContentTypeInputOutput() : void
|
||||||
|
{
|
||||||
|
$this->mail->setHtml(true);
|
||||||
|
self::assertEquals(MimeType::M_HTML, $this->mail->getContentType());
|
||||||
|
self::assertTrue($this->mail->isHtml());
|
||||||
|
|
||||||
|
$this->mail->setHtml(false);
|
||||||
|
self::assertEquals(MimeType::M_TEXT, $this->mail->getContentType());
|
||||||
|
self::assertFalse($this->mail->isHtml());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAddTo() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->mail->addTo('test@orange-management.org', 'Test Name'));
|
||||||
|
self::assertTrue($this->mail->addTo('test2@orange-management.org', 'Test Name 2'));
|
||||||
|
|
||||||
|
self::assertEquals(
|
||||||
|
[
|
||||||
|
'test@orange-management.org' => ['test@orange-management.org', 'Test Name'],
|
||||||
|
'test2@orange-management.org' => ['test2@orange-management.org', 'Test Name 2'],
|
||||||
|
],
|
||||||
|
$this->mail->to
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testInvalidAddTo() : void
|
||||||
|
{
|
||||||
|
self::assertFalse($this->mail->addTo('test-^invalid', 'Test Name'));
|
||||||
|
self::assertEquals([], $this->mail->to);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAddCC() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->mail->addCC('test@orange-management.org', 'Test Name'));
|
||||||
|
self::assertTrue($this->mail->addCC('test2@orange-management.org', 'Test Name 2'));
|
||||||
|
|
||||||
|
self::assertEquals(
|
||||||
|
[
|
||||||
|
'test@orange-management.org' => ['test@orange-management.org', 'Test Name'],
|
||||||
|
'test2@orange-management.org' => ['test2@orange-management.org', 'Test Name 2'],
|
||||||
|
],
|
||||||
|
$this->mail->cc
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testInvalidAddCC() : void
|
||||||
|
{
|
||||||
|
self::assertFalse($this->mail->addCC('test-^invalid', 'Test Name'));
|
||||||
|
self::assertEquals([], $this->mail->cc);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAddBCC() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->mail->addBCC('test@orange-management.org', 'Test Name'));
|
||||||
|
self::assertTrue($this->mail->addBCC('test2@orange-management.org', 'Test Name 2'));
|
||||||
|
|
||||||
|
self::assertEquals(
|
||||||
|
[
|
||||||
|
'test@orange-management.org' => ['test@orange-management.org', 'Test Name'],
|
||||||
|
'test2@orange-management.org' => ['test2@orange-management.org', 'Test Name 2'],
|
||||||
|
],
|
||||||
|
$this->mail->bcc
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testInvalidAddBCC() : void
|
||||||
|
{
|
||||||
|
self::assertFalse($this->mail->addBCC('test-^invalid', 'Test Name'));
|
||||||
|
self::assertEquals([], $this->mail->bcc);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAddReplyTo() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->mail->addReplyTo('test@orange-management.org', 'Test Name'));
|
||||||
|
self::assertTrue($this->mail->addReplyTo('test2@orange-management.org', 'Test Name 2'));
|
||||||
|
|
||||||
|
self::assertEquals(
|
||||||
|
[
|
||||||
|
'test@orange-management.org' => ['test@orange-management.org', 'Test Name'],
|
||||||
|
'test2@orange-management.org' => ['test2@orange-management.org', 'Test Name 2'],
|
||||||
|
],
|
||||||
|
$this->mail->replyTo
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testInvalidAddReplyTo() : void
|
||||||
|
{
|
||||||
|
self::assertFalse($this->mail->addReplyTo('test-^invalid', 'Test Name'));
|
||||||
|
self::assertEquals([], $this->mail->replyTo);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testMissingAddressPreSend() : void
|
||||||
|
{
|
||||||
|
self::assertFalse($this->mail->preSend(''));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAddrFormat() : void
|
||||||
|
{
|
||||||
|
self::assertEquals('test@orange-management.org', $this->mail->addrFormat(['test@orange-management.org']));
|
||||||
|
self::assertEquals('Test Name <test@orange-management.org>', $this->mail->addrFormat(['test@orange-management.org', 'Test Name']));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCustomHeaderInputOutput() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->mail->addCustomHeader('name', 'value'));
|
||||||
|
self::assertEquals([['name', 'value']], $this->mail->getCustomHeaders());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testInvalidCustomHeaderInputOutput() : void
|
||||||
|
{
|
||||||
|
self::assertFalse($this->mail->addCustomHeader('', ''));
|
||||||
|
self::AssertEquals([], $this->mail->getCustomHeaders());
|
||||||
|
}
|
||||||
|
|
||||||
public function testEmailParsing() : void
|
public function testEmailParsing() : void
|
||||||
{
|
{
|
||||||
self::assertEquals(
|
self::assertEquals(
|
||||||
|
|
@ -53,10 +184,20 @@ class EmailTestTest extends \PHPUnit\Framework\TestCase
|
||||||
Email::parseAddresses('Test Name <test@orange-management.org>')
|
Email::parseAddresses('Test Name <test@orange-management.org>')
|
||||||
);
|
);
|
||||||
|
|
||||||
|
self::assertEquals(
|
||||||
|
[['name' => '', 'address' => 'test@orange-management.org']],
|
||||||
|
Email::parseAddresses('test@orange-management.org')
|
||||||
|
);
|
||||||
|
|
||||||
self::assertEquals(
|
self::assertEquals(
|
||||||
[['name' => 'Test Name', 'address' => 'test@orange-management.org']],
|
[['name' => 'Test Name', 'address' => 'test@orange-management.org']],
|
||||||
Email::parseAddresses('Test Name <test@orange-management.org>', false)
|
Email::parseAddresses('Test Name <test@orange-management.org>', false)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
self::assertEquals(
|
||||||
|
[['name' => '', 'address' => 'test@orange-management.org']],
|
||||||
|
Email::parseAddresses('test@orange-management.org', false)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testHtml() : void
|
public function testHtml() : void
|
||||||
|
|
@ -76,8 +217,58 @@ class EmailTestTest extends \PHPUnit\Framework\TestCase
|
||||||
|
|
||||||
public function testAttachment() : void
|
public function testAttachment() : void
|
||||||
{
|
{
|
||||||
self::assertTrue($this->mail->addAttachment(__DIR__ . '/files/logo.png', 'logo'));
|
self::assertTrue($this->mail->addAttachment(__DIR__ . '/files/logo.png'));
|
||||||
self::assertTrue($this->mail->hasAttachment());
|
self::assertTrue($this->mail->hasAttachment());
|
||||||
self::assertCount(1, $this->mail->getAttachments());
|
self::assertCount(1, $this->mail->getAttachments());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testStringAttachment() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->mail->addStringAttachment('string', __DIR__ . '/files/logo.png'));
|
||||||
|
self::assertTrue($this->mail->hasAttachment());
|
||||||
|
self::assertCount(1, $this->mail->getAttachments());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEmbeddedImage() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->mail->addEmbeddedImage(__DIR__ . '/files/logo.png', 'cid'));
|
||||||
|
self::assertTrue($this->mail->hasInlineImage());
|
||||||
|
self::assertCount(1, $this->mail->getAttachments());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testStringEmbeddedImage() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->mail->addStringEmbeddedImage('string', 'cid', __DIR__ . '/files/logo.png'));
|
||||||
|
self::assertTrue($this->mail->hasInlineImage());
|
||||||
|
self::assertCount(1, $this->mail->getAttachments());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testInvalidAttachmentPath() : void
|
||||||
|
{
|
||||||
|
self::assertFalse($this->mail->addAttachment(__DIR__ . '/invalid.txt'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testInvalidEmbeddedImage() : void
|
||||||
|
{
|
||||||
|
self::assertFalse($this->mail->addEmbeddedImage(__DIR__ . '/invalid.png', ''));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testQuotedPrintableDkimHeader() : void
|
||||||
|
{
|
||||||
|
self::assertEquals(
|
||||||
|
"J'interdis=20aux=20marchands=20de=20vanter=20trop=20leurs=20marchandises.=20Car=20ils=20se=20font=20vite=20p=C3=A9dagogues=20et=20t'enseignent=20comme=20but=20ce=20qui=20n'est=20par=20essence=20qu'un=20moyen,=20et=20te=20trompant=20ainsi=20sur=20la=20route=20=C3=A0=20suivre=20les=20voil=C3=A0=20bient=C3=B4t=20qui=20te=20d=C3=A9gradent,=20car=20si=20leur=20musique=20est=20vulgaire=20ils=20te=20fabriquent=20pour=20te=20la=20vendre=20une=20=C3=A2me=20vulgaire.",
|
||||||
|
$this->mail->dkimQP("J'interdis aux marchands de vanter trop leurs marchandises. Car ils se font vite pédagogues et t'enseignent comme but ce qui n'est par essence qu'un moyen, et te trompant ainsi sur la route à suivre les voilà bientôt qui te dégradent, car si leur musique est vulgaire ils te fabriquent pour te la vendre une âme vulgaire.")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCanonicalizedDkimHeader() : void
|
||||||
|
{
|
||||||
|
self::assertEquals("header1:value1\r\nheader2:value2", $this->mail->dkimHeaderC("HEADER1:value1\t\nheader2:value2"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testCanonicalizedDkimBody() : void
|
||||||
|
{
|
||||||
|
self::assertEquals("Test\r\n string\r\n", $this->mail->dkimBodyC("Test\n string\t"));
|
||||||
|
self::assertEquals("\r\n", $this->mail->dkimBodyC(''));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -43,7 +43,7 @@ class MailHandlerTest extends \PHPUnit\Framework\TestCase
|
||||||
{
|
{
|
||||||
$this->handler->setMailer(SubmitType::MAIL);
|
$this->handler->setMailer(SubmitType::MAIL);
|
||||||
|
|
||||||
if (!\file_exists($this->handler->mailerTool)) {
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
self::markTestSkipped();
|
self::markTestSkipped();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -54,8 +54,12 @@ class MailHandlerTest extends \PHPUnit\Framework\TestCase
|
||||||
$mail->addBCC('test3@orange-management.email', 'Dennis Eichhorn');
|
$mail->addBCC('test3@orange-management.email', 'Dennis Eichhorn');
|
||||||
$mail->addReplyTo('test4@orange-management.email', 'Dennis Eichhorn');
|
$mail->addReplyTo('test4@orange-management.email', 'Dennis Eichhorn');
|
||||||
$mail->subject = 'testSendTextWithMail';
|
$mail->subject = 'testSendTextWithMail';
|
||||||
$mail->body = 'This is some content';
|
$mail->body = "This is some content\n\Image: <img alt=\"image\" src=\"cid:cid1\">";
|
||||||
|
$mail->altBody = 'Alt body';
|
||||||
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
||||||
|
$mail->addEmbeddedImage(__DIR__ . '/files/logo.png', 'cid1');
|
||||||
|
$mail->addStringAttachment('String content', 'string_content_file.txt');
|
||||||
|
$mail->addStringEmbeddedImage(\file_get_contents(__DIR__ . '/files/logo.png'), 'cid2');
|
||||||
|
|
||||||
self::assertTrue($this->handler->send($mail));
|
self::assertTrue($this->handler->send($mail));
|
||||||
}
|
}
|
||||||
|
|
@ -64,7 +68,7 @@ class MailHandlerTest extends \PHPUnit\Framework\TestCase
|
||||||
{
|
{
|
||||||
$this->handler->setMailer(SubmitType::SENDMAIL);
|
$this->handler->setMailer(SubmitType::SENDMAIL);
|
||||||
|
|
||||||
if (!\file_exists($this->handler->mailerTool)) {
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
self::markTestSkipped();
|
self::markTestSkipped();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -75,8 +79,12 @@ class MailHandlerTest extends \PHPUnit\Framework\TestCase
|
||||||
$mail->addBCC('test3@orange-management.email', 'Dennis Eichhorn');
|
$mail->addBCC('test3@orange-management.email', 'Dennis Eichhorn');
|
||||||
$mail->addReplyTo('test4@orange-management.email', 'Dennis Eichhorn');
|
$mail->addReplyTo('test4@orange-management.email', 'Dennis Eichhorn');
|
||||||
$mail->subject = 'testSendTextWithSendmail';
|
$mail->subject = 'testSendTextWithSendmail';
|
||||||
$mail->body = 'This is some content';
|
$mail->body = "This is some content\n\Image: <img alt=\"image\" src=\"cid:cid1\">";
|
||||||
|
$mail->altBody = 'Alt body';
|
||||||
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
||||||
|
$mail->addEmbeddedImage(__DIR__ . '/files/logo.png', 'cid1');
|
||||||
|
$mail->addStringAttachment('String content', 'string_content_file.txt');
|
||||||
|
$mail->addStringEmbeddedImage(\file_get_contents(__DIR__ . '/files/logo.png'), 'cid2');
|
||||||
|
|
||||||
self::assertTrue($this->handler->send($mail));
|
self::assertTrue($this->handler->send($mail));
|
||||||
}
|
}
|
||||||
|
|
@ -85,7 +93,7 @@ class MailHandlerTest extends \PHPUnit\Framework\TestCase
|
||||||
{
|
{
|
||||||
$this->handler->setMailer(SubmitType::MAIL);
|
$this->handler->setMailer(SubmitType::MAIL);
|
||||||
|
|
||||||
if (!\file_exists($this->handler->mailerTool)) {
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
self::markTestSkipped();
|
self::markTestSkipped();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -101,8 +109,12 @@ class MailHandlerTest extends \PHPUnit\Framework\TestCase
|
||||||
$mail->body = '';
|
$mail->body = '';
|
||||||
$mail->bodyAlt = '';
|
$mail->bodyAlt = '';
|
||||||
|
|
||||||
|
$mail->setHtml(true);
|
||||||
$mail->msgHTML($message, __DIR__ . '/files');
|
$mail->msgHTML($message, __DIR__ . '/files');
|
||||||
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
||||||
|
$mail->addEmbeddedImage(__DIR__ . '/files/logo.png', 'cid1');
|
||||||
|
$mail->addStringAttachment('String content', 'string_content_file.txt');
|
||||||
|
$mail->addStringEmbeddedImage(\file_get_contents(__DIR__ . '/files/logo.png'), 'cid2');
|
||||||
|
|
||||||
self::assertTrue($this->handler->send($mail));
|
self::assertTrue($this->handler->send($mail));
|
||||||
}
|
}
|
||||||
|
|
@ -111,7 +123,7 @@ class MailHandlerTest extends \PHPUnit\Framework\TestCase
|
||||||
{
|
{
|
||||||
$this->handler->setMailer(SubmitType::SENDMAIL);
|
$this->handler->setMailer(SubmitType::SENDMAIL);
|
||||||
|
|
||||||
if (!\file_exists($this->handler->mailerTool)) {
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
self::markTestSkipped();
|
self::markTestSkipped();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -127,8 +139,228 @@ class MailHandlerTest extends \PHPUnit\Framework\TestCase
|
||||||
$mail->body = '';
|
$mail->body = '';
|
||||||
$mail->bodyAlt = '';
|
$mail->bodyAlt = '';
|
||||||
|
|
||||||
|
$mail->setHtml(true);
|
||||||
$mail->msgHTML($message, __DIR__ . '/files');
|
$mail->msgHTML($message, __DIR__ . '/files');
|
||||||
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
||||||
|
$mail->addEmbeddedImage(__DIR__ . '/files/logo.png', 'cid1');
|
||||||
|
$mail->addStringAttachment('String content', 'string_content_file.txt');
|
||||||
|
$mail->addStringEmbeddedImage(\file_get_contents(__DIR__ . '/files/logo.png'), 'cid2');
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendInlineWithMail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::MAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendInlineWithMail';
|
||||||
|
$mail->setHtml(true);
|
||||||
|
$mail->msgHTML("<img alt=\"image\" src=\"cid:cid1\">");
|
||||||
|
$mail->addEmbeddedImage(__DIR__ . '/files/logo.png', 'cid1');
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendInlineWithSendmail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::SENDMAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendInlineWithSendmail';
|
||||||
|
$mail->setHtml(true);
|
||||||
|
$mail->msgHTML("<img alt=\"image\" src=\"cid:cid1\">");
|
||||||
|
$mail->addEmbeddedImage(__DIR__ . '/files/logo.png', 'cid1');
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendAttachmentWithMail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::MAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendAttachmentWithMail';
|
||||||
|
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendAttachmentWithSendmail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::SENDMAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendAttachmentWithSendmail';
|
||||||
|
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendAltWithMail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::MAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendAltWithMail';
|
||||||
|
$mail->altBody = 'Alt body';
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendAltWithSendmail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::SENDMAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendAltWithSendmail';
|
||||||
|
$mail->altBody = 'Alt body';
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendAltInlineWithMail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::MAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendAltInlineWithMail';
|
||||||
|
$mail->altBody = 'Alt body';
|
||||||
|
$mail->setHtml(true);
|
||||||
|
$mail->msgHTML("<img alt=\"image\" src=\"cid:cid1\">");
|
||||||
|
$mail->addEmbeddedImage(__DIR__ . '/files/logo.png', 'cid1');
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendAltInlineWithSendmail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::SENDMAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendAltInlineWithSendmail';
|
||||||
|
$mail->altBody = 'Alt body';
|
||||||
|
$mail->setHtml(true);
|
||||||
|
$mail->msgHTML("<img alt=\"image\" src=\"cid:cid1\">");
|
||||||
|
$mail->addEmbeddedImage(__DIR__ . '/files/logo.png', 'cid1');
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendAltAttachmentWithMail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::MAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendAltAttachmentWithMail';
|
||||||
|
$mail->altBody = 'Alt body';
|
||||||
|
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendAltAttachmentWithSendmail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::SENDMAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendAltAttachmentWithSendmail';
|
||||||
|
$mail->altBody = 'Alt body';
|
||||||
|
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendPlainWithMail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::MAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendPlainWithMail';
|
||||||
|
$mail->body = 'Body';
|
||||||
|
|
||||||
|
self::assertTrue($this->handler->send($mail));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSendPlainWithSendmail() : void
|
||||||
|
{
|
||||||
|
$this->handler->setMailer(SubmitType::SENDMAIL);
|
||||||
|
|
||||||
|
if ($this->handler->mailerTool !== '' && !\file_exists(\explode(' ', $this->handler->mailerTool)[0])) {
|
||||||
|
self::markTestSkipped();
|
||||||
|
}
|
||||||
|
|
||||||
|
$mail = new Email();
|
||||||
|
$mail->setFrom('test1@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->addTo('test@orange-management.email', 'Dennis Eichhorn');
|
||||||
|
$mail->subject = 'testSendPlainWithSendmail';
|
||||||
|
$mail->body = 'Body';
|
||||||
|
|
||||||
self::assertTrue($this->handler->send($mail));
|
self::assertTrue($this->handler->send($mail));
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -18,6 +18,8 @@
|
||||||
<p>Emoji: <span style="font-size: 48px">😂 🦄 💥 📤 📧</span></p>
|
<p>Emoji: <span style="font-size: 48px">😂 🦄 💥 📤 📧</span></p>
|
||||||
<p>Image data URL (base64)<img src="" alt="#"></p>
|
<p>Image data URL (base64)<img src="" alt="#"></p>
|
||||||
<p>Image data URL (URL-encoded)<img src="data:image/gif,GIF89a%01%00%01%00%00%00%00%21%F9%04%01%0A%00%01%00%2C%00%00%00%00%01%00%01%00%00%02%02L%01%00%3B" alt="#"></p>
|
<p>Image data URL (URL-encoded)<img src="data:image/gif,GIF89a%01%00%01%00%00%00%00%21%F9%04%01%0A%00%01%00%2C%00%00%00%00%01%00%01%00%00%02%02L%01%00%3B" alt="#"></p>
|
||||||
|
<p>Image inline: <img alt="image" src="cid:cid1"></p>
|
||||||
|
<p>Image string inline: <img alt="image" src="cid:cid2"></p>
|
||||||
</div>
|
</div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
58
tests/Module/InstallerAbstractTest.php
Normal file
58
tests/Module/InstallerAbstractTest.php
Normal file
|
|
@ -0,0 +1,58 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Orange Management
|
||||||
|
*
|
||||||
|
* PHP Version 8.0
|
||||||
|
*
|
||||||
|
* @package tests
|
||||||
|
* @copyright Dennis Eichhorn
|
||||||
|
* @license OMS License 1.0
|
||||||
|
* @version 1.0.0
|
||||||
|
* @link https://orange-management.org
|
||||||
|
*/
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace phpOMS\tests\Module;
|
||||||
|
|
||||||
|
require_once __DIR__ . '/../Autoloader.php';
|
||||||
|
|
||||||
|
use phpOMS\Module\InstallerAbstract;
|
||||||
|
use phpOMS\DataStorage\Database\DatabasePool;
|
||||||
|
use phpOMS\Module\ModuleInfo;
|
||||||
|
use Model\CoreSettings;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @testdox phpOMS\tests\Module\InstallerAbstractTest: Abstract module
|
||||||
|
*
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
class InstallerAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
|
{
|
||||||
|
protected InstallerAbstract $installer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function setUp() : void
|
||||||
|
{
|
||||||
|
$this->installer = new class() extends InstallerAbstract
|
||||||
|
{
|
||||||
|
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @covers phpOMS\Module\InstallerAbstract
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testInvalidModuleInstall() : void
|
||||||
|
{
|
||||||
|
$this->expectException(\UnexpectedValueException::class);
|
||||||
|
|
||||||
|
$this->installer::install(
|
||||||
|
new DatabasePool(),
|
||||||
|
new ModuleInfo(__DIR__),
|
||||||
|
new CoreSettings()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -100,7 +100,7 @@ class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
$model1 = BaseModelMapper::get(1);
|
$model1 = BaseModelMapper::get(1);
|
||||||
$model2 = ManyToManyRelModelMapper::get(1);
|
$model2 = ManyToManyRelModelMapper::get(1);
|
||||||
|
|
||||||
$this->createModelRelation(1, $model1->id, $model2->id, BaseModelMapper::class, 'hasManyRelations', '', '127.0.0.1');
|
$this->createModelRelation(1, $model1->getId(), $model2->id, BaseModelMapper::class, 'hasManyRelations', '', '127.0.0.1');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function deleteRelationDB() : void
|
public function deleteRelationDB() : void
|
||||||
|
|
@ -108,7 +108,7 @@ class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
$model1 = BaseModelMapper::get(1);
|
$model1 = BaseModelMapper::get(1);
|
||||||
$model2 = ManyToManyRelModelMapper::get(1);
|
$model2 = ManyToManyRelModelMapper::get(1);
|
||||||
|
|
||||||
$this->deleteModelRelation(1, $model1->id, $model2->id, BaseModelMapper::class, 'hasManyRelations', '', '127.0.0.1');
|
$this->deleteModelRelation(1, $model1->getId(), $model2->id, BaseModelMapper::class, 'hasManyRelations', '', '127.0.0.1');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function creates() : void
|
public function creates() : void
|
||||||
|
|
@ -134,6 +134,34 @@ class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
$model = BaseModelMapper::get(1);
|
$model = BaseModelMapper::get(1);
|
||||||
$this->deleteModel(1, $model, BaseModelMapper::class, '', '127.0.0.1');
|
$this->deleteModel(1, $model, BaseModelMapper::class, '', '127.0.0.1');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function createWithCallable() : string
|
||||||
|
{
|
||||||
|
\ob_start();
|
||||||
|
$this->createModel(1, null, function() { echo 1; }, '', '127.0.0.1');
|
||||||
|
return \ob_get_clean();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function createsWithCallable() : string
|
||||||
|
{
|
||||||
|
\ob_start();
|
||||||
|
$this->createModels(1, [null, null], function() { echo 1; }, '', '127.0.0.1');
|
||||||
|
return \ob_get_clean();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function updateWithCallable() : string
|
||||||
|
{
|
||||||
|
\ob_start();
|
||||||
|
$this->updateModel(1, null, null, function() { echo 1; }, '', '127.0.0.1');
|
||||||
|
return \ob_get_clean();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function deleteWithCallable() : string
|
||||||
|
{
|
||||||
|
\ob_start();
|
||||||
|
$this->deleteModel(1, null, function() { echo 1; }, '', '127.0.0.1');
|
||||||
|
return \ob_get_clean();
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -434,4 +462,19 @@ class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertCount(2, $model->hasManyRelations);
|
self::assertCount(2, $model->hasManyRelations);
|
||||||
$this->dbTeardown();
|
$this->dbTeardown();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testModelFunctionsWithClosure() : void
|
||||||
|
{
|
||||||
|
$output = $this->module->createWithCallable();
|
||||||
|
self::assertEquals('1', $output);
|
||||||
|
|
||||||
|
$output = $this->module->createsWithCallable();
|
||||||
|
self::assertEquals('11', $output);
|
||||||
|
|
||||||
|
$output = $this->module->updateWithCallable();
|
||||||
|
self::assertEquals('1', $output);
|
||||||
|
|
||||||
|
$output = $this->module->deleteWithCallable();
|
||||||
|
self::assertEquals('1', $output);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -25,6 +25,7 @@ use phpOMS\Module\ModuleManager;
|
||||||
use phpOMS\Module\ModuleStatus;
|
use phpOMS\Module\ModuleStatus;
|
||||||
use phpOMS\Router\WebRouter;
|
use phpOMS\Router\WebRouter;
|
||||||
use phpOMS\Uri\HttpUri;
|
use phpOMS\Uri\HttpUri;
|
||||||
|
use phpOMS\Utils\TestUtils;
|
||||||
|
|
||||||
require_once __DIR__ . '/../Autoloader.php';
|
require_once __DIR__ . '/../Autoloader.php';
|
||||||
|
|
||||||
|
|
@ -261,6 +262,22 @@ class ModuleManagerTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertTrue($this->moduleManager->isRunning('TestModule'));
|
self::assertTrue($this->moduleManager->isRunning('TestModule'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testGetLanguageForInvalidRequest() : void
|
||||||
|
{
|
||||||
|
$request = new HttpRequest(new HttpUri('http://127.0.0.1/en/error/invalid'));
|
||||||
|
$request->createRequestHashs(0);
|
||||||
|
|
||||||
|
TestUtils::setMember($request, 'hash', ['asdf']);
|
||||||
|
|
||||||
|
self::assertEquals([], $this->moduleManager->getLanguageFiles($request));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetActiveModulesWithInvalidBasePath() : void
|
||||||
|
{
|
||||||
|
$this->moduleManager = new ModuleManager($this->app, __DIR__ . '/invalid');
|
||||||
|
self::assertEquals([], $this->moduleManager->getActiveModules(false));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @testdox Installed modules can be returned
|
* @testdox Installed modules can be returned
|
||||||
* @covers phpOMS\Module\ModuleManager
|
* @covers phpOMS\Module\ModuleManager
|
||||||
|
|
@ -273,6 +290,21 @@ class ModuleManagerTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertNotEmpty($installed);
|
self::assertNotEmpty($installed);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testIsInstalled() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->moduleManager->isInstalled('TestModule'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testInstallingAlreadyInstalledModule() : void
|
||||||
|
{
|
||||||
|
self::assertTrue($this->moduleManager->install('TestModule'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAvailableModules() : void
|
||||||
|
{
|
||||||
|
self::assertEquals([], $this->moduleManager->getAvailableModules());
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @testdox The valid module can be returned
|
* @testdox The valid module can be returned
|
||||||
* @covers phpOMS\Module\ModuleManager
|
* @covers phpOMS\Module\ModuleManager
|
||||||
|
|
|
||||||
|
|
@ -90,6 +90,9 @@ class PackageManagerTest extends \PHPUnit\Framework\TestCase
|
||||||
Directory::delete(__DIR__ . '/dummyModule');
|
Directory::delete(__DIR__ . '/dummyModule');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
\chmod(__DIR__ . '/testPackage/testSubPackage/run.batch', 0777);
|
||||||
|
\chmod(__DIR__ . '/testPackage/testSubPackage/run.sh', 0777);
|
||||||
|
|
||||||
Directory::copy(__DIR__ . '/testModulePackage', __DIR__ . '/dummyModule');
|
Directory::copy(__DIR__ . '/testModulePackage', __DIR__ . '/dummyModule');
|
||||||
|
|
||||||
$package = new PackageManager(
|
$package = new PackageManager(
|
||||||
|
|
|
||||||
40
tests/Module/StatusAbstractTest.php
Normal file
40
tests/Module/StatusAbstractTest.php
Normal file
|
|
@ -0,0 +1,40 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Orange Management
|
||||||
|
*
|
||||||
|
* PHP Version 8.0
|
||||||
|
*
|
||||||
|
* @package tests
|
||||||
|
* @copyright Dennis Eichhorn
|
||||||
|
* @license OMS License 1.0
|
||||||
|
* @version 1.0.0
|
||||||
|
* @link https://orange-management.org
|
||||||
|
*/
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace phpOMS\tests\Module;
|
||||||
|
|
||||||
|
require_once __DIR__ . '/../Autoloader.php';
|
||||||
|
|
||||||
|
use phpOMS\Module\StatusAbstract;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @testdox phpOMS\tests\Module\StatusAbstractTest: Abstract module
|
||||||
|
*
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
class StatusAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
|
{
|
||||||
|
protected StatusAbstract $status;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function setUp() : void
|
||||||
|
{
|
||||||
|
$this->status = new class() extends StatusAbstract
|
||||||
|
{
|
||||||
|
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
58
tests/Module/UninstallerAbstractTest.php
Normal file
58
tests/Module/UninstallerAbstractTest.php
Normal file
|
|
@ -0,0 +1,58 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Orange Management
|
||||||
|
*
|
||||||
|
* PHP Version 8.0
|
||||||
|
*
|
||||||
|
* @package tests
|
||||||
|
* @copyright Dennis Eichhorn
|
||||||
|
* @license OMS License 1.0
|
||||||
|
* @version 1.0.0
|
||||||
|
* @link https://orange-management.org
|
||||||
|
*/
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace phpOMS\tests\Module;
|
||||||
|
|
||||||
|
require_once __DIR__ . '/../Autoloader.php';
|
||||||
|
|
||||||
|
use phpOMS\Module\UninstallerAbstract;
|
||||||
|
use phpOMS\DataStorage\Database\DatabasePool;
|
||||||
|
use phpOMS\Module\ModuleInfo;
|
||||||
|
use Model\CoreSettings;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @testdox phpOMS\tests\Module\UninstallerAbstractTest: Abstract module
|
||||||
|
*
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
class UninstallerAbstractTest extends \PHPUnit\Framework\TestCase
|
||||||
|
{
|
||||||
|
protected UninstallerAbstract $uninstaller;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function setUp() : void
|
||||||
|
{
|
||||||
|
|
||||||
|
$this->uninstaller = new class() extends UninstallerAbstract
|
||||||
|
{
|
||||||
|
public const PATH = __DIR__ . '/invalid';
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @covers phpOMS\Module\UninstallerAbstract
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testMissingDbFileUninstall() : void
|
||||||
|
{
|
||||||
|
$this->uninstaller::dropTables(
|
||||||
|
new DatabasePool(),
|
||||||
|
new ModuleInfo(__DIR__)
|
||||||
|
);
|
||||||
|
|
||||||
|
self::assertFalse(\file_exists($this->uninstaller::PATH . '/Install/db.json'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -64,7 +64,7 @@ class ClientTest extends \PHPUnit\Framework\TestCase
|
||||||
$this->app->orgId = 1;
|
$this->app->orgId = 1;
|
||||||
$this->app->cachePool = new CachePool($this->app->dbPool);
|
$this->app->cachePool = new CachePool($this->app->dbPool);
|
||||||
$this->app->accountManager = new AccountManager($GLOBALS['session']);
|
$this->app->accountManager = new AccountManager($GLOBALS['session']);
|
||||||
$this->app->appSettings = new CoreSettings($this->app->dbPool->get());
|
$this->app->appSettings = new CoreSettings();
|
||||||
$this->app->moduleManager = new ModuleManager($this->app, __DIR__ . '/../../../../Modules/');
|
$this->app->moduleManager = new ModuleManager($this->app, __DIR__ . '/../../../../Modules/');
|
||||||
$this->app->dispatcher = new Dispatcher($this->app);
|
$this->app->dispatcher = new Dispatcher($this->app);
|
||||||
$this->app->eventManager = new EventManager($this->app->dispatcher);
|
$this->app->eventManager = new EventManager($this->app->dispatcher);
|
||||||
|
|
|
||||||
|
|
@ -64,7 +64,7 @@ class ServerTest extends \PHPUnit\Framework\TestCase
|
||||||
$this->app->orgId = 1;
|
$this->app->orgId = 1;
|
||||||
$this->app->cachePool = new CachePool($this->app->dbPool);
|
$this->app->cachePool = new CachePool($this->app->dbPool);
|
||||||
$this->app->accountManager = new AccountManager($GLOBALS['session']);
|
$this->app->accountManager = new AccountManager($GLOBALS['session']);
|
||||||
$this->app->appSettings = new CoreSettings($this->app->dbPool->get());
|
$this->app->appSettings = new CoreSettings();
|
||||||
$this->app->moduleManager = new ModuleManager($this->app, __DIR__ . '/../../../../Modules/');
|
$this->app->moduleManager = new ModuleManager($this->app, __DIR__ . '/../../../../Modules/');
|
||||||
$this->app->dispatcher = new Dispatcher($this->app);
|
$this->app->dispatcher = new Dispatcher($this->app);
|
||||||
$this->app->eventManager = new EventManager($this->app->dispatcher);
|
$this->app->eventManager = new EventManager($this->app->dispatcher);
|
||||||
|
|
|
||||||
|
|
@ -63,6 +63,9 @@ class GraphTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertEquals([], $this->graph->getDijkstraShortestPath());
|
self::assertEquals([], $this->graph->getDijkstraShortestPath());
|
||||||
self::assertEquals([], $this->graph->longestPath());
|
self::assertEquals([], $this->graph->longestPath());
|
||||||
self::assertEquals([], $this->graph->longestPathBetweenNodes('invalid1', 'invalid2'));
|
self::assertEquals([], $this->graph->longestPathBetweenNodes('invalid1', 'invalid2'));
|
||||||
|
self::assertEquals([], $this->graph->shortestPathBetweenNodes('invalid1', 'invalid2'));
|
||||||
|
self::assertEquals([], $this->graph->getAllPathsBetweenNodes('invalid1', 'invalid2'));
|
||||||
|
self::assertEquals([], $this->graph->findAllReachableNodesDFS('invalid1'));
|
||||||
|
|
||||||
self::assertEquals(0, $this->graph->getCost());
|
self::assertEquals(0, $this->graph->getCost());
|
||||||
self::assertEquals($this->graph, $this->graph->getKruskalMinimalSpanningTree());
|
self::assertEquals($this->graph, $this->graph->getKruskalMinimalSpanningTree());
|
||||||
|
|
@ -393,4 +396,321 @@ class GraphTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertCount(6, $nodes);
|
self::assertCount(6, $nodes);
|
||||||
self::assertEquals(17.0, $minimalSpanningTree->getCost());
|
self::assertEquals(17.0, $minimalSpanningTree->getCost());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1 - 3 - 5
|
||||||
|
* / |\ /
|
||||||
|
* 0 | \ /
|
||||||
|
* \ | \ /
|
||||||
|
* 2 4 6
|
||||||
|
*
|
||||||
|
* @covers phpOMS\Stdlib\Graph\Graph
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testFindAllReachableNodesDFS() : void
|
||||||
|
{
|
||||||
|
$node0 = new Node('0');
|
||||||
|
$node1 = new Node('1');
|
||||||
|
$node2 = new Node('2');
|
||||||
|
$node3 = new Node('3');
|
||||||
|
$node4 = new Node('4');
|
||||||
|
$node5 = new Node('5');
|
||||||
|
$node6 = new Node('6');
|
||||||
|
|
||||||
|
$this->graph->setNode($node0);
|
||||||
|
$this->graph->setNode($node1);
|
||||||
|
$this->graph->setNode($node2);
|
||||||
|
$this->graph->setNode($node3);
|
||||||
|
$this->graph->setNode($node4);
|
||||||
|
$this->graph->setNode($node5);
|
||||||
|
$this->graph->setNode($node6);
|
||||||
|
|
||||||
|
$node0->setNodeRelative($node1);
|
||||||
|
$node0->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node3);
|
||||||
|
$node1->setNodeRelative($node4);
|
||||||
|
$node3->setNodeRelative($node5);
|
||||||
|
$node4->setNodeRelative($node5);
|
||||||
|
|
||||||
|
$nodes = $this->graph->findAllReachableNodesDFS($node0);
|
||||||
|
self::assertCount(6, $nodes);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1 - 3 - 5
|
||||||
|
* / |\ /
|
||||||
|
* 0 | \ /
|
||||||
|
* \ | \ /
|
||||||
|
* 2 4 6
|
||||||
|
*
|
||||||
|
* @covers phpOMS\Stdlib\Graph\Graph
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testGetAllPathsBetweenNodes() : void
|
||||||
|
{
|
||||||
|
$node0 = new Node('0');
|
||||||
|
$node1 = new Node('1');
|
||||||
|
$node2 = new Node('2');
|
||||||
|
$node3 = new Node('3');
|
||||||
|
$node4 = new Node('4');
|
||||||
|
$node5 = new Node('5');
|
||||||
|
$node6 = new Node('6');
|
||||||
|
|
||||||
|
$this->graph->setNode($node0);
|
||||||
|
$this->graph->setNode($node1);
|
||||||
|
$this->graph->setNode($node2);
|
||||||
|
$this->graph->setNode($node3);
|
||||||
|
$this->graph->setNode($node4);
|
||||||
|
$this->graph->setNode($node5);
|
||||||
|
$this->graph->setNode($node6);
|
||||||
|
|
||||||
|
$node0->setNodeRelative($node1);
|
||||||
|
$node0->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node3);
|
||||||
|
$node1->setNodeRelative($node4);
|
||||||
|
$node3->setNodeRelative($node5);
|
||||||
|
$node4->setNodeRelative($node5);
|
||||||
|
|
||||||
|
$paths = $this->graph->getAllPathsBetweenNodes($node0, $node5);
|
||||||
|
self::assertCount(4, $paths);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1 - 3 - 5
|
||||||
|
* / |\ /
|
||||||
|
* 0 | \ /
|
||||||
|
* \ | \ /
|
||||||
|
* 2 4 6
|
||||||
|
*
|
||||||
|
* @covers phpOMS\Stdlib\Graph\Graph
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testCountAllPathsBetweenNodes() : void
|
||||||
|
{
|
||||||
|
$node0 = new Node('0');
|
||||||
|
$node1 = new Node('1');
|
||||||
|
$node2 = new Node('2');
|
||||||
|
$node3 = new Node('3');
|
||||||
|
$node4 = new Node('4');
|
||||||
|
$node5 = new Node('5');
|
||||||
|
$node6 = new Node('6');
|
||||||
|
|
||||||
|
$this->graph->setNode($node0);
|
||||||
|
$this->graph->setNode($node1);
|
||||||
|
$this->graph->setNode($node2);
|
||||||
|
$this->graph->setNode($node3);
|
||||||
|
$this->graph->setNode($node4);
|
||||||
|
$this->graph->setNode($node5);
|
||||||
|
$this->graph->setNode($node6);
|
||||||
|
|
||||||
|
$node0->setNodeRelative($node1);
|
||||||
|
$node0->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node3);
|
||||||
|
$node1->setNodeRelative($node4);
|
||||||
|
$node3->setNodeRelative($node5);
|
||||||
|
$node4->setNodeRelative($node5);
|
||||||
|
|
||||||
|
self::assertEquals(4, $this->graph->countAllPathsBetweenNodes($node0, $node5));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1 - 3 - 5
|
||||||
|
* / |\ /
|
||||||
|
* 0 | \ /
|
||||||
|
* \ | \ /
|
||||||
|
* 2 4 6
|
||||||
|
*
|
||||||
|
* @covers phpOMS\Stdlib\Graph\Graph
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testLongestPathBetweenNodes() : void
|
||||||
|
{
|
||||||
|
$node0 = new Node('0');
|
||||||
|
$node1 = new Node('1');
|
||||||
|
$node2 = new Node('2');
|
||||||
|
$node3 = new Node('3');
|
||||||
|
$node4 = new Node('4');
|
||||||
|
$node5 = new Node('5');
|
||||||
|
$node6 = new Node('6');
|
||||||
|
|
||||||
|
$this->graph->setNode($node0);
|
||||||
|
$this->graph->setNode($node1);
|
||||||
|
$this->graph->setNode($node2);
|
||||||
|
$this->graph->setNode($node3);
|
||||||
|
$this->graph->setNode($node4);
|
||||||
|
$this->graph->setNode($node5);
|
||||||
|
$this->graph->setNode($node6);
|
||||||
|
|
||||||
|
$node0->setNodeRelative($node1);
|
||||||
|
$node0->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node3);
|
||||||
|
$node1->setNodeRelative($node4);
|
||||||
|
$node3->setNodeRelative($node5);
|
||||||
|
$node4->setNodeRelative($node5);
|
||||||
|
|
||||||
|
$path = $this->graph->longestPathBetweenNodes($node0, $node5);
|
||||||
|
self::assertCount(4, $path);
|
||||||
|
|
||||||
|
$path = $this->graph->longestPathBetweenNodes($node0, $node6);
|
||||||
|
self::assertEquals([], $path);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1 - 3 - 5
|
||||||
|
* / |\ /
|
||||||
|
* 0 | \ /
|
||||||
|
* \ | \ /
|
||||||
|
* 2 4 6
|
||||||
|
*
|
||||||
|
* @covers phpOMS\Stdlib\Graph\Graph
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testShortestPathBetweenNodes() : void
|
||||||
|
{
|
||||||
|
$node0 = new Node('0');
|
||||||
|
$node1 = new Node('1');
|
||||||
|
$node2 = new Node('2');
|
||||||
|
$node3 = new Node('3');
|
||||||
|
$node4 = new Node('4');
|
||||||
|
$node5 = new Node('5');
|
||||||
|
$node6 = new Node('6');
|
||||||
|
|
||||||
|
$this->graph->setNode($node0);
|
||||||
|
$this->graph->setNode($node1);
|
||||||
|
$this->graph->setNode($node2);
|
||||||
|
$this->graph->setNode($node3);
|
||||||
|
$this->graph->setNode($node4);
|
||||||
|
$this->graph->setNode($node5);
|
||||||
|
$this->graph->setNode($node6);
|
||||||
|
|
||||||
|
$node0->setNodeRelative($node1);
|
||||||
|
$node0->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node3);
|
||||||
|
$node1->setNodeRelative($node4);
|
||||||
|
$node3->setNodeRelative($node5);
|
||||||
|
$node4->setNodeRelative($node5);
|
||||||
|
|
||||||
|
$path = $this->graph->shortestPathBetweenNodes($node0, $node5);
|
||||||
|
self::assertCount(3, $path);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1 - 3 - 5
|
||||||
|
* / |\ /
|
||||||
|
* 0 | \ /
|
||||||
|
* \ | \ /
|
||||||
|
* 2 4 6
|
||||||
|
*
|
||||||
|
* @covers phpOMS\Stdlib\Graph\Graph
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testUnconnectedGraph() : void
|
||||||
|
{
|
||||||
|
$node0 = new Node('0');
|
||||||
|
$node1 = new Node('1');
|
||||||
|
$node2 = new Node('2');
|
||||||
|
$node3 = new Node('3');
|
||||||
|
$node4 = new Node('4');
|
||||||
|
$node5 = new Node('5');
|
||||||
|
$node6 = new Node('6');
|
||||||
|
|
||||||
|
$this->graph->setNode($node0);
|
||||||
|
$this->graph->setNode($node1);
|
||||||
|
$this->graph->setNode($node2);
|
||||||
|
$this->graph->setNode($node3);
|
||||||
|
$this->graph->setNode($node4);
|
||||||
|
$this->graph->setNode($node5);
|
||||||
|
$this->graph->setNode($node6);
|
||||||
|
|
||||||
|
$node0->setNodeRelative($node1);
|
||||||
|
$node0->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node3);
|
||||||
|
$node1->setNodeRelative($node4);
|
||||||
|
$node3->setNodeRelative($node5);
|
||||||
|
$node4->setNodeRelative($node5);
|
||||||
|
|
||||||
|
self::assertFalse($this->graph->isConnected());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1 - 3 - 5
|
||||||
|
* / |\ /
|
||||||
|
* 0 | \ /
|
||||||
|
* \ | \ /
|
||||||
|
* 2 4
|
||||||
|
*
|
||||||
|
* @covers phpOMS\Stdlib\Graph\Graph
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testConnectedGraph() : void
|
||||||
|
{
|
||||||
|
$node0 = new Node('0');
|
||||||
|
$node1 = new Node('1');
|
||||||
|
$node2 = new Node('2');
|
||||||
|
$node3 = new Node('3');
|
||||||
|
$node4 = new Node('4');
|
||||||
|
$node5 = new Node('5');
|
||||||
|
|
||||||
|
$this->graph->setNode($node0);
|
||||||
|
$this->graph->setNode($node1);
|
||||||
|
$this->graph->setNode($node2);
|
||||||
|
$this->graph->setNode($node3);
|
||||||
|
$this->graph->setNode($node4);
|
||||||
|
$this->graph->setNode($node5);
|
||||||
|
|
||||||
|
$node0->setNodeRelative($node1);
|
||||||
|
$node0->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node3);
|
||||||
|
$node1->setNodeRelative($node4);
|
||||||
|
$node3->setNodeRelative($node5);
|
||||||
|
$node4->setNodeRelative($node5);
|
||||||
|
|
||||||
|
self::assertTrue($this->graph->isConnected());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1 - 3 - 5
|
||||||
|
* / |\ /
|
||||||
|
* 0 | \ /
|
||||||
|
* \ | \ /
|
||||||
|
* 2 4
|
||||||
|
*
|
||||||
|
* @covers phpOMS\Stdlib\Graph\Graph
|
||||||
|
* @group framework
|
||||||
|
*/
|
||||||
|
public function testDiameter() : void
|
||||||
|
{
|
||||||
|
self::markTestIncomplete();
|
||||||
|
|
||||||
|
$node0 = new Node('0');
|
||||||
|
$node1 = new Node('1');
|
||||||
|
$node2 = new Node('2');
|
||||||
|
$node3 = new Node('3');
|
||||||
|
$node4 = new Node('4');
|
||||||
|
$node5 = new Node('5');
|
||||||
|
|
||||||
|
$this->graph->setNode($node0);
|
||||||
|
$this->graph->setNode($node1);
|
||||||
|
$this->graph->setNode($node2);
|
||||||
|
$this->graph->setNode($node3);
|
||||||
|
$this->graph->setNode($node4);
|
||||||
|
$this->graph->setNode($node5);
|
||||||
|
|
||||||
|
$node0->setNodeRelative($node1);
|
||||||
|
$node0->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node3);
|
||||||
|
$node1->setNodeRelative($node4);
|
||||||
|
$node3->setNodeRelative($node5);
|
||||||
|
$node4->setNodeRelative($node5);
|
||||||
|
|
||||||
|
self::assertEquals(0, $this->graph->getDiameter());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -160,4 +160,20 @@ class NodeTest extends \PHPUnit\Framework\TestCase
|
||||||
self::assertCount(2, $node1->getNeighbors());
|
self::assertCount(2, $node1->getNeighbors());
|
||||||
self::assertCount(1, $node4->getNeighbors());
|
self::assertCount(1, $node4->getNeighbors());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testFindEdgeFromNeighbor() : void
|
||||||
|
{
|
||||||
|
$node1 = new Node('A');
|
||||||
|
$node2 = new Node('B');
|
||||||
|
$node3 = new Node('C');
|
||||||
|
$node4 = new Node('D');
|
||||||
|
|
||||||
|
$node3->setNodeRelative($node4);
|
||||||
|
|
||||||
|
$node1->setNodeRelative($node2);
|
||||||
|
$node1->setNodeRelative($node3);
|
||||||
|
|
||||||
|
self::assertEquals('C', $node1->getEdgeByNeighbor($node3)->getNode2()->getId());
|
||||||
|
self::assertEquals(null, $node1->getEdgeByNeighbor($node4));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user