"
+ * their tag such as "[[_toc_]]".
+ *
+ * @param string $text Tag text to encode
+ *
+ * @return string
+ *
+ * @since 1.0.0
*/
- protected function encodeTagToHash($text)
+ protected function encodeToCTagToHash(string $text) : string
{
- $salt = $this->getSalt();
- $tagOrigin = $this->getTagToC();
+ $salt = \bin2hex(\random_bytes(4));
+ $tagOrigin = $this->options['toc']['set_toc_tag'] ?? '[toc]';
if (\strpos($text, $tagOrigin) === false) {
return $text;
}
- $tagHashed = \hash('sha256', $salt.$tagOrigin);
+ $tagHashed = \hash('sha256', $salt . $tagOrigin);
return \str_replace($tagOrigin, $tagHashed, $text);
}
@@ -1583,14 +2999,19 @@ class Markdown
* Decodes the hashed ToC tag to an original tag and replaces.
*
* This is used to avoid parsing user defined ToC tag which includes "_" in
- * their tag such as "[[_toc_]]". Unless it will be parsed as:
- * "
');
foreach ($oShape->getShapeCollection() as $oShapeChild) {
$this->displayShape($oShapeChild);
}
diff --git a/Utils/Parser/Spreadsheet/SpreadsheetParser.php b/Utils/Parser/Spreadsheet/SpreadsheetParser.php
index 07847522b..b85fc0f4c 100755
--- a/Utils/Parser/Spreadsheet/SpreadsheetParser.php
+++ b/Utils/Parser/Spreadsheet/SpreadsheetParser.php
@@ -25,8 +25,18 @@ use PhpOffice\PhpSpreadsheet\Worksheet\PageSetup;
* @link https://jingga.app
* @since 1.0.0
*/
-class SpreadsheetParser
+final class SpreadsheetParser
{
+ /**
+ * Constructor.
+ *
+ * @since 1.0.0
+ * @codeCoverageIgnore
+ */
+ private function __construct()
+ {
+ }
+
/**
* Spreadsheet to string
*
@@ -38,9 +48,9 @@ class SpreadsheetParser
*/
public static function parseSpreadsheet(string $path, string $output = 'json') : string
{
- if ($output === 'json') {
- $spreadsheet = IOFactory::load($path);
+ $spreadsheet = IOFactory::load($path);
+ if ($output === 'json') {
$sheetCount = $spreadsheet->getSheetCount();
$csv = [];
@@ -52,8 +62,6 @@ class SpreadsheetParser
return $json === false ? '' : $json;
} elseif ($output === 'pdf') {
- $spreadsheet = IOFactory::load($path);
-
$spreadsheet->getActiveSheet()->setShowGridLines(false);
$spreadsheet->getActiveSheet()->getPageSetup()->setOrientation(PageSetup::ORIENTATION_LANDSCAPE);
@@ -64,13 +72,31 @@ class SpreadsheetParser
return $writer->toPdfString();
} elseif ($output === 'html') {
- $spreadsheet = IOFactory::load($path);
-
IOFactory::registerWriter('custom', \phpOMS\Utils\Parser\Spreadsheet\SpreadsheetWriter::class);
/** @var \phpOMS\Utils\Parser\Spreadsheet\SpreadsheetWriter $writer */
$writer = IOFactory::createWriter($spreadsheet, 'custom');
return $writer->generateHtmlAll();
+ } elseif ($output === 'txt') {
+ IOFactory::registerWriter('custom', \phpOMS\Utils\Parser\Spreadsheet\SpreadsheetWriter::class);
+
+ /** @var \phpOMS\Utils\Parser\Spreadsheet\SpreadsheetWriter $writer */
+ $writer = IOFactory::createWriter($spreadsheet, 'custom');
+ $html = $writer->generateHtmlAll();
+
+ $doc = new \DOMDocument();
+ $html = \preg_replace(
+ ['~~', '~~'],
+ ['', ''],
+ $html
+ );
+
+ $doc->loadHTMLFile($path);
+
+ $body = $doc->getElementsByTagName('body');
+ $node = $body->item(0);
+
+ return empty($node->textContent) ? '' : $node->textContent;
}
return '';
diff --git a/Utils/Parser/Xml/XmlParser.php b/Utils/Parser/Xml/XmlParser.php
new file mode 100644
index 000000000..3c772a652
--- /dev/null
+++ b/Utils/Parser/Xml/XmlParser.php
@@ -0,0 +1,96 @@
+preserveWhiteSpace = true;
+ $doc->formatOutput = true;
+
+ $xml = \file_get_contents($path);
+ if ($xml === false || $xml === null) {
+ return '';
+ }
+
+ $xml = \preg_replace(
+ ['~~', '~~'],
+ ['', ''],
+ $xml
+ );
+
+ if ($xml === null) {
+ return '';
+ }
+
+ $result = $doc->loadXML($xml);
+ if ($result === false) {
+ return '';
+ }
+
+ if (empty($xpath)) {
+ $result = $doc->saveHTML();
+
+ return $result === false ? '' : $result;
+ }
+
+ $content = '';
+ $xNode = new \DOMXpath($doc);
+ $elements = $xNode->query($xpath);
+
+ if ($elements === false) {
+ return $content;
+ }
+
+ foreach ($elements as $element) {
+ $nodes = $element->childNodes;
+
+ foreach ($nodes as $node) {
+ $content .= $node->textContent . "\n";
+ }
+ }
+
+ return $content;
+ }
+}
diff --git a/Utils/Permutation.php b/Utils/Permutation.php
index 6f4bc3532..d2f62106e 100755
--- a/Utils/Permutation.php
+++ b/Utils/Permutation.php
@@ -37,14 +37,14 @@ final class Permutation
/**
* Create all permutations.
*
- * @param array $toPermute data to permutate
+ * @param array $toPermute data to permute
* @param array $result existing permutations
*
* @return array
*
* @since 1.0.0
*/
- public static function permut(array $toPermute, array $result = [], bool $concat = true) : array
+ public static function permuteAll(array $toPermute, array $result = [], bool $concat = true) : array
{
$permutations = [];
@@ -58,7 +58,7 @@ final class Permutation
unset($newArr[$key]);
- $permutations = \array_merge($permutations, self::permut($newArr, $newres, $concat));
+ $permutations = \array_merge($permutations, self::permuteAll($newArr, $newres, $concat));
}
}
@@ -98,9 +98,9 @@ final class Permutation
}
/**
- * Permutate based on transposition key.
+ * Permute based on transposition key.
*
- * @param array|string $toPermute To permutate
+ * @param array|string $toPermute To permute
* @param int[] $key Permutation keys
*
* @return string|array
@@ -109,7 +109,7 @@ final class Permutation
*
* @since 1.0.0
*/
- public static function permutate(string | array $toPermute, array $key) : string | array
+ public static function permuteByKey(string | array $toPermute, array $key) : string | array
{
$length = \is_array($toPermute) ? \count($toPermute) : \strlen($toPermute);
diff --git a/Utils/RnG/ArrayRandomize.php b/Utils/RnG/ArrayRandomize.php
index adfb5fbda..6619e3b11 100755
--- a/Utils/RnG/ArrayRandomize.php
+++ b/Utils/RnG/ArrayRandomize.php
@@ -22,8 +22,18 @@ namespace phpOMS\Utils\RnG;
* @link https://jingga.app
* @since 1.0.0
*/
-class ArrayRandomize
+final class ArrayRandomize
{
+ /**
+ * Constructor.
+ *
+ * @since 1.0.0
+ * @codeCoverageIgnore
+ */
+ private function __construct()
+ {
+ }
+
/**
* Yates array shuffler.
*
diff --git a/Utils/RnG/DateTime.php b/Utils/RnG/DateTime.php
index c288b10ff..704a8e39f 100755
--- a/Utils/RnG/DateTime.php
+++ b/Utils/RnG/DateTime.php
@@ -22,8 +22,18 @@ namespace phpOMS\Utils\RnG;
* @link https://jingga.app
* @since 1.0.0
*/
-class DateTime
+final class DateTime
{
+ /**
+ * Constructor.
+ *
+ * @since 1.0.0
+ * @codeCoverageIgnore
+ */
+ private function __construct()
+ {
+ }
+
/**
* Get a random \DateTime.
*
diff --git a/Utils/RnG/Email.php b/Utils/RnG/Email.php
index 4ae5ab4cf..50a71dcca 100755
--- a/Utils/RnG/Email.php
+++ b/Utils/RnG/Email.php
@@ -22,8 +22,18 @@ namespace phpOMS\Utils\RnG;
* @link https://jingga.app
* @since 1.0.0
*/
-class Email
+final class Email
{
+ /**
+ * Constructor.
+ *
+ * @since 1.0.0
+ * @codeCoverageIgnore
+ */
+ private function __construct()
+ {
+ }
+
/**
* Get a random email.
*
diff --git a/Utils/RnG/File.php b/Utils/RnG/File.php
index 22b951659..87288bf29 100755
--- a/Utils/RnG/File.php
+++ b/Utils/RnG/File.php
@@ -22,7 +22,7 @@ namespace phpOMS\Utils\RnG;
* @link https://jingga.app
* @since 1.0.0
*/
-class File
+final class File
{
/**
* Extensions.
@@ -44,6 +44,16 @@ class File
['flv'], ['fla'], ['deb'], ['py'], ['pl'],
];
+ /**
+ * Constructor.
+ *
+ * @since 1.0.0
+ * @codeCoverageIgnore
+ */
+ private function __construct()
+ {
+ }
+
/**
* Get a random file extension.
*
@@ -53,11 +63,9 @@ class File
*
* @since 1.0.0
*/
- public static function generateExtension(array $source = null) : string
+ public static function generateExtension(?array $source = null) : string
{
- if ($source === null) {
- $source = self::$extensions;
- }
+ $source ??= self::$extensions;
$key = \array_rand($source, 1);
diff --git a/Utils/RnG/LinearCongruentialGenerator.php b/Utils/RnG/LinearCongruentialGenerator.php
index bfc60986e..c10e42258 100755
--- a/Utils/RnG/LinearCongruentialGenerator.php
+++ b/Utils/RnG/LinearCongruentialGenerator.php
@@ -22,7 +22,7 @@ namespace phpOMS\Utils\RnG;
* @link https://jingga.app
* @since 1.0.0
*/
-class LinearCongruentialGenerator
+final class LinearCongruentialGenerator
{
/**
* BSD seed value.
@@ -40,6 +40,16 @@ class LinearCongruentialGenerator
*/
private static $msvcrtSeed = 0;
+ /**
+ * Constructor.
+ *
+ * @since 1.0.0
+ * @codeCoverageIgnore
+ */
+ private function __construct()
+ {
+ }
+
/**
* BSD random number
*
diff --git a/Utils/RnG/Name.php b/Utils/RnG/Name.php
index f02a9faec..dff549c46 100755
--- a/Utils/RnG/Name.php
+++ b/Utils/RnG/Name.php
@@ -22,7 +22,7 @@ namespace phpOMS\Utils\RnG;
* @link https://jingga.app
* @since 1.0.0
*/
-class Name
+final class Name
{
private static array $names = [
'western' => [
@@ -216,7 +216,7 @@ class Name
'Zula', 'Catrina', 'Hazeline', 'Lillian', 'Reanne', 'Zuri', 'Catriona', 'Heather', 'Lillie', 'Rebecca',
'Zyana', 'Cayla', 'Heaven',
],
- 'male' => [
+ 'male' => [
'Aaron', 'Clay', 'Gino', 'Laurie', 'Richard', 'Abdul', 'Clayton', 'Giorgio', 'Lawrence', 'Richie',
'Abdullah', 'Clement', 'Giovanni', 'Lawson', 'Rick', 'Abe', 'Cliff', 'Glen', 'Layne', 'Rickey', 'Abel',
'Clifford', 'Glenn', 'Layton', 'Rickie', 'Abraham', 'Clifton', 'Glyndwr', 'Leaf', 'Ricky', 'Abram',
@@ -481,6 +481,16 @@ class Name
],
];
+ /**
+ * Constructor.
+ *
+ * @since 1.0.0
+ * @codeCoverageIgnore
+ */
+ private function __construct()
+ {
+ }
+
/**
* Get a random string.
*
diff --git a/Utils/RnG/Number.php b/Utils/RnG/Number.php
new file mode 100644
index 000000000..3bc1a7c47
--- /dev/null
+++ b/Utils/RnG/Number.php
@@ -0,0 +1,71 @@
+ 49, 'us' => 1];
- }
+ $countries ??= ['de' => 49, 'us' => 1];
$numberString = \str_replace(
'$1',
diff --git a/Utils/RnG/StringUtils.php b/Utils/RnG/StringUtils.php
index 55e67dd6b..1cc6c73d0 100755
--- a/Utils/RnG/StringUtils.php
+++ b/Utils/RnG/StringUtils.php
@@ -22,8 +22,18 @@ namespace phpOMS\Utils\RnG;
* @link https://jingga.app
* @since 1.0.0
*/
-class StringUtils
+final class StringUtils
{
+ /**
+ * Constructor.
+ *
+ * @since 1.0.0
+ * @codeCoverageIgnore
+ */
+ private function __construct()
+ {
+ }
+
/**
* Get a random string.
*
diff --git a/Utils/RnG/Text.php b/Utils/RnG/Text.php
index 2b8b8a87b..d07cc0236 100755
--- a/Utils/RnG/Text.php
+++ b/Utils/RnG/Text.php
@@ -22,7 +22,7 @@ namespace phpOMS\Utils\RnG;
* @link https://jingga.app
* @since 1.0.0
*/
-class Text
+final class Text
{
/**
* Vocabulary.
@@ -97,15 +97,13 @@ class Text
*
* @since 1.0.0
*/
- public function generateText(int $length, array $words = null) : string
+ public function generateText(int $length, ?array $words = null) : string
{
if ($length === 0) {
return '';
}
- if ($words === null) {
- $words = self::LOREM_IPSUM;
- }
+ $words ??= self::LOREM_IPSUM;
$punctuation = $this->generatePunctuation($length);
$punctuationCount = \array_count_values(
@@ -249,7 +247,7 @@ class Text
$paragraphLength = $length - $i;
}
- $i += $paragraphLength;
+ $i += $paragraphLength;
$paragraph[] = $i;
}
diff --git a/Utils/RnG/UUID.php b/Utils/RnG/UUID.php
index 3dcf94611..a7661145f 100755
--- a/Utils/RnG/UUID.php
+++ b/Utils/RnG/UUID.php
@@ -24,6 +24,16 @@ namespace phpOMS\Utils\RnG;
*/
final class UUID
{
+ /**
+ * Constructor.
+ *
+ * @since 1.0.0
+ * @codeCoverageIgnore
+ */
+ private function __construct()
+ {
+ }
+
/**
* Get default random UUID
*
diff --git a/Utils/StringUtils.php b/Utils/StringUtils.php
index 31d23d291..e82295714 100755
--- a/Utils/StringUtils.php
+++ b/Utils/StringUtils.php
@@ -131,7 +131,7 @@ final class StringUtils
}
/**
- * Count occurences of character at the beginning of a string.
+ * Count occurrences of character at the beginning of a string.
*
* @param string $string string to analyze
* @param string $character character to count at the beginning of the string
@@ -139,7 +139,7 @@ final class StringUtils
* @example StringUtils::countCharacterFromStart(' Test string', ' '); // 4
* @example StringUtils::countCharacterFromStart(' Test string', 's'); // 0
*
- * @return int the amount of repeating occurences at the beginning of the string
+ * @return int the amount of repeating occurrences at the beginning of the string
*
* @since 1.0.0
*/
@@ -178,7 +178,7 @@ final class StringUtils
/** @var int $v */
foreach ($countChars as $v) {
- $p = $v / $size;
+ $p = $v / $size;
$entropy -= $p * \log($p) / \log(2);
}
@@ -265,37 +265,30 @@ final class StringUtils
for ($i = 0; $i < $n; ++$i) {
$mc = $diff['mask'][$i];
- if ($mc !== 0) {
- switch ($mc) {
- case -1:
- $result .= '' . $diff['values'][$i] . '' . $delim;
- break;
- case 1:
- $result .= '' . $diff['values'][$i] . '' . $delim;
- break;
- }
- } else {
- $result .= $diff['values'][$i] . $delim;
+ $previousMC = $diff['mask'][$i - 1] ?? 0;
+ $nextMC = $diff['mask'][$i + 1] ?? 0;
+
+ switch ($mc) {
+ case -1:
+ $result .= ($previousMC === -1 ? '' : '')
+ . $diff['values'][$i]
+ . ($nextMC === -1 ? '' : '')
+ . $delim;
+
+ break;
+ case 1:
+ $result .= ($previousMC === 1 ? '' : '')
+ . $diff['values'][$i]
+ . ($nextMC === 1 ? '' : '')
+ . $delim;
+
+ break;
+ default:
+ $result .= $diff['values'][$i] . $delim;
}
}
- $result = \rtrim($result, $delim);
-
- switch ($mc) {
- case -1:
- $result .= '';
- break;
- case 1:
- $result .= '';
- break;
- }
-
- // @todo: This should not be necessary but the algorithm above allows for weird combinations.
- return \str_replace(
- ['', '', '', '', '', '', '', ' '],
- ['', '', '', '', '', '', '', ''],
- $result
- );
+ return \rtrim($result, $delim);
}
/**
@@ -389,36 +382,6 @@ final class StringUtils
return (int) $res;
}
- /**
- * Fix CVE-2016-10033 and CVE-2016-10045 by disallowing potentially unsafe shell characters.
- *
- * @param string $string String to check
- *
- * @return bool
- *
- * @since 1.0.0
- */
- public static function isShellSafe(string $string) : bool
- {
- if (\escapeshellcmd($string) !== $string
- || !\in_array(\escapeshellarg($string), ["'{$string}'", "\"{$string}\""])
- ) {
- return false;
- }
-
- $length = \strlen($string);
-
- for ($i = 0; $i < $length; ++$i) {
- $c = $string[$i];
-
- if (!\ctype_alnum($c) && \strpos('@_-.', $c) === false) {
- return false;
- }
- }
-
- return true;
- }
-
/**
* Turn ints into spreadsheet column names
*
diff --git a/Utils/TaskSchedule/Cron.php b/Utils/TaskSchedule/Cron.php
index 13c2ad9b1..e3b98a063 100755
--- a/Utils/TaskSchedule/Cron.php
+++ b/Utils/TaskSchedule/Cron.php
@@ -206,8 +206,10 @@ class Cron extends SchedulerAbstract
$elements = \array_merge($elements, $interval);
$elements[] = \trim(\substr($line, $len = (\strlen(\implode(' ', $interval)) + 1), $comment - $len - 1));
- $jobs[] = $job = CronJob::createWith($elements);
- $job->setStatus($line[0] === '#' ? TaskStatus::INACTIVE : TaskStatus::ACTIVE);
+ $job = CronJob::createWith($elements);
+ $job->status = $line[0] === '#' ? TaskStatus::INACTIVE : TaskStatus::ACTIVE;
+
+ $jobs[] = $job;
}
$line = \fgets($fp);
diff --git a/Utils/TaskSchedule/Interval.php b/Utils/TaskSchedule/Interval.php
index c7f5f0e70..775f061f4 100755
--- a/Utils/TaskSchedule/Interval.php
+++ b/Utils/TaskSchedule/Interval.php
@@ -110,7 +110,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function __construct(\DateTime $start = null, string $interval = null)
+ public function __construct(?\DateTime $start = null, ?string $interval = null)
{
$this->start = $start ?? new \DateTime('now');
@@ -225,7 +225,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function setMinute(int $index, int $start = null, int $end = null, int $step = null) : void
+ public function setMinute(int $index, ?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->minute[$index] = [
'start' => $start,
@@ -245,7 +245,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function addMinute(int $start = null, int $end = null, int $step = null) : void
+ public function addMinute(?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->minute[] = [
'start' => $start,
@@ -278,7 +278,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function setHour(int $index, int $start = null, int $end = null, int $step = null) : void
+ public function setHour(int $index, ?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->hour[$index] = [
'start' => $start,
@@ -298,7 +298,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function addHour(int $start = null, int $end = null, int $step = null) : void
+ public function addHour(?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->hour[] = [
'start' => $start,
@@ -331,7 +331,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function setDayOfMonth(int $index, int $start = null, int $end = null, int $step = null) : void
+ public function setDayOfMonth(int $index, ?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->dayOfMonth[$index] = [
'start' => $start,
@@ -351,7 +351,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function addDayOfMonth(int $start = null, int $end = null, int $step = null) : void
+ public function addDayOfMonth(?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->dayOfMonth[] = [
'start' => $start,
@@ -384,7 +384,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function setDayOfWeek(int $index, int $start = null, int $end = null, int $step = null) : void
+ public function setDayOfWeek(int $index, ?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->dayOfWeek[$index] = [
'start' => $start,
@@ -404,7 +404,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function addDayOfWeek(int $start = null, int $end = null, int $step = null) : void
+ public function addDayOfWeek(?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->dayOfWeek[] = [
'start' => $start,
@@ -437,7 +437,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function setMonth(int $index, int $start = null, int $end = null, int $step = null) : void
+ public function setMonth(int $index, ?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->month[$index] = [
'start' => $start,
@@ -457,7 +457,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function addMonth(int $start = null, int $end = null, int $step = null) : void
+ public function addMonth(?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->month[] = [
'start' => $start,
@@ -490,7 +490,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function setYear(int $index, int $start = null, int $end = null, int $step = null) : void
+ public function setYear(int $index, ?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->year[$index] = [
'start' => $start,
@@ -510,7 +510,7 @@ class Interval implements SerializableInterface
*
* @since 1.0.0
*/
- public function addYear(int $start = null, int $end = null, int $step = null) : void
+ public function addYear(?int $start = null, ?int $end = null, ?int $step = null) : void
{
$this->year[] = [
'start' => $start,
diff --git a/Utils/TaskSchedule/Schedule.php b/Utils/TaskSchedule/Schedule.php
index b00f6b7e5..9991020d8 100755
--- a/Utils/TaskSchedule/Schedule.php
+++ b/Utils/TaskSchedule/Schedule.php
@@ -23,6 +23,9 @@ use phpOMS\Validation\Base\DateTime;
* @license OMS License 2.0
* @link https://jingga.app
* @since 1.0.0
+ *
+ * @todo Use `Interval` for scheduler instead of string etc.
+ * https://github.com/Karaka-Management/phpOMS/issues/257
*/
class Schedule extends TaskAbstract
{
@@ -39,13 +42,9 @@ class Schedule extends TaskAbstract
*/
public static function createWith(array $jobData) : TaskAbstract
{
- /**
- * @todo Karaka/phpOMS#231
- * Use the interval for generating a schedule
- */
$job = new self($jobData[1], $jobData[8], $jobData[7]);
- $job->setStatus((int) $jobData[3]);
+ $job->status = (int) $jobData[3];
if (DateTime::isValid($jobData[2])) {
$job->setNextRunTime(new \DateTime($jobData[2]));
diff --git a/Utils/TaskSchedule/TaskAbstract.php b/Utils/TaskSchedule/TaskAbstract.php
index e1dc82ff2..586720f0b 100755
--- a/Utils/TaskSchedule/TaskAbstract.php
+++ b/Utils/TaskSchedule/TaskAbstract.php
@@ -54,7 +54,7 @@ abstract class TaskAbstract
* @var int
* @since 1.0.0
*/
- protected int $status = TaskStatus::ACTIVE;
+ public int $status = TaskStatus::ACTIVE;
/**
* Next runtime
@@ -170,32 +170,6 @@ abstract class TaskAbstract
$this->interval = $interval;
}
- /**
- * Get status.
- *
- * @return int
- *
- * @since 1.0.0
- */
- public function getStatus() : int
- {
- return $this->status;
- }
-
- /**
- * Set status.
- *
- * @param int $status Status
- *
- * @return void
- *
- * @since 1.0.0
- */
- public function setStatus(int $status) : void
- {
- $this->status = $status;
- }
-
/**
* Get next run time.
*
diff --git a/Validation/Base/DateTime.php b/Validation/Base/DateTime.php
index b0f656058..38ddbcfc9 100755
--- a/Validation/Base/DateTime.php
+++ b/Validation/Base/DateTime.php
@@ -29,7 +29,7 @@ abstract class DateTime extends ValidatorAbstract
/**
* {@inheritdoc}
*/
- public static function isValid(mixed $value, array $constraints = null) : bool
+ public static function isValid(mixed $value, ?array $constraints = null) : bool
{
if (!\is_string($value)) {
return false;
diff --git a/Validation/Base/Json.php b/Validation/Base/Json.php
index c0f4d375a..78e285cec 100755
--- a/Validation/Base/Json.php
+++ b/Validation/Base/Json.php
@@ -30,7 +30,7 @@ abstract class Json extends ValidatorAbstract
/**
* {@inheritdoc}
*/
- public static function isValid(mixed $value, array $constraints = null) : bool
+ public static function isValid(mixed $value, ?array $constraints = null) : bool
{
if (!\is_string($value)) {
return false;
diff --git a/Validation/Finance/BIC.php b/Validation/Finance/BIC.php
index 986ad0645..d63dc9004 100755
--- a/Validation/Finance/BIC.php
+++ b/Validation/Finance/BIC.php
@@ -29,7 +29,7 @@ final class BIC extends ValidatorAbstract
/**
* {@inheritdoc}
*/
- public static function isValid(mixed $value, array $constraints = null) : bool
+ public static function isValid(mixed $value, ?array $constraints = null) : bool
{
if (!\is_string($value)) {
return false;
diff --git a/Validation/Finance/CreditCard.php b/Validation/Finance/CreditCard.php
index 19c5ee050..05a292010 100755
--- a/Validation/Finance/CreditCard.php
+++ b/Validation/Finance/CreditCard.php
@@ -29,7 +29,7 @@ final class CreditCard extends ValidatorAbstract
/**
* {@inheritdoc}
*/
- public static function isValid($value, array $constraints = null) : bool
+ public static function isValid($value, ?array $constraints = null) : bool
{
if (!\is_string($value)) {
return false;
diff --git a/Validation/Finance/EUVat.php b/Validation/Finance/EUVat.php
index 1d86aa38b..92e1776e3 100644
--- a/Validation/Finance/EUVat.php
+++ b/Validation/Finance/EUVat.php
@@ -63,7 +63,7 @@ final class EUVat extends ValidatorAbstract
/**
* {@inheritdoc}
*/
- public static function isValid(mixed $value, array $constraints = null) : bool
+ public static function isValid(mixed $value, ?array $constraints = null) : bool
{
if (!\is_string($value)) {
return false;
diff --git a/Validation/Finance/Iban.php b/Validation/Finance/Iban.php
index c905bbebf..e30f2b803 100755
--- a/Validation/Finance/Iban.php
+++ b/Validation/Finance/Iban.php
@@ -29,7 +29,7 @@ final class Iban extends ValidatorAbstract
/**
* {@inheritdoc}
*/
- public static function isValid(mixed $value, array $constraints = null) : bool
+ public static function isValid(mixed $value, ?array $constraints = null) : bool
{
if (!\is_string($value)) {
return false;
@@ -42,7 +42,7 @@ final class Iban extends ValidatorAbstract
return false; // @codeCoverageIgnore
}
- $enumName = 'C_' . \strtoupper($temp);
+ $enumName = '_' . \strtoupper($temp);
if (!IbanEnum::isValidName($enumName)) {
self::$error = IbanErrorType::INVALID_COUNTRY;
@@ -148,14 +148,16 @@ final class Iban extends ValidatorAbstract
*/
private static function validateChecksum(string $iban) : bool
{
- $chars = ['a' => 10, 'b' => 11, 'c' => 12, 'd' => 13, 'e' => 14, 'f' => 15, 'g' => 16, 'h' => 17, 'i' => 18,
- 'j' => 19, 'k' => 20, 'l' => 21, 'm' => 22, 'n' => 23, 'o' => 24, 'p' => 25, 'q' => 26, 'r' => 27,
- 's' => 28, 't' => 29, 'u' => 30, 'v' => 31, 'w' => 32, 'x' => 33, 'y' => 34, 'z' => 35,];
+ $chars = [
+ 'a' => 10, 'b' => 11, 'c' => 12, 'd' => 13, 'e' => 14, 'f' => 15, 'g' => 16, 'h' => 17, 'i' => 18,
+ 'j' => 19, 'k' => 20, 'l' => 21, 'm' => 22, 'n' => 23, 'o' => 24, 'p' => 25, 'q' => 26, 'r' => 27,
+ 's' => 28, 't' => 29, 'u' => 30, 'v' => 31, 'w' => 32, 'x' => 33, 'y' => 34, 'z' => 35,
+ ];
$moved = \substr($iban, 4) . \substr($iban, 0, 4);
$movedArray = (array) \str_split($moved);
$new = '';
- foreach ($movedArray as $key => $value) {
+ foreach ($movedArray as $key => $_) {
if (!\is_numeric($movedArray[$key])) {
$movedArray[$key] = $chars[$movedArray[$key]];
}
diff --git a/Validation/Finance/IbanEnum.php b/Validation/Finance/IbanEnum.php
index 50e0bdf16..31c7ec98e 100755
--- a/Validation/Finance/IbanEnum.php
+++ b/Validation/Finance/IbanEnum.php
@@ -26,167 +26,167 @@ use phpOMS\Stdlib\Base\Enum;
*/
class IbanEnum extends Enum
{
- public const C_AL = 'ALkk bbbs sssx cccc cccc cccc cccc';
+ public const _AL = 'ALkk bbbs sssx cccc cccc cccc cccc';
- public const C_AD = 'ADkk bbbb ssss cccc cccc cccc';
+ public const _AD = 'ADkk bbbb ssss cccc cccc cccc';
- public const C_AT = 'ATkk bbbb bccc cccc cccc';
+ public const _AT = 'ATkk bbbb bccc cccc cccc';
- public const C_AZ = 'AZkk bbbb cccc cccc cccc cccc cccc ';
+ public const _AZ = 'AZkk bbbb cccc cccc cccc cccc cccc ';
- public const C_BH = 'BHkk bbbb cccc cccc cccc cc';
+ public const _BH = 'BHkk bbbb cccc cccc cccc cc';
- public const C_BE = 'BEkk bbbc cccc ccxx';
+ public const _BE = 'BEkk bbbc cccc ccxx';
- public const C_BA = 'BAkk bbbs sscc cccc ccxx';
+ public const _BA = 'BAkk bbbs sscc cccc ccxx';
- public const C_BR = 'BRkk bbbb bbbb ssss sccc cccc ccct n';
+ public const _BR = 'BRkk bbbb bbbb ssss sccc cccc ccct n';
- public const C_BG = 'BGkk bbbb ssss ttcc cccc cc';
+ public const _BG = 'BGkk bbbb ssss ttcc cccc cc';
- public const C_CR = 'CRkk bbbc cccc cccc cccc c';
+ public const _CR = 'CRkk bbbc cccc cccc cccc c';
- public const C_HR = 'HRkk bbbb bbbc cccc cccc c';
+ public const _HR = 'HRkk bbbb bbbc cccc cccc c';
- public const C_CY = 'CYkk bbbs ssss cccc cccc cccc cccc';
+ public const _CY = 'CYkk bbbs ssss cccc cccc cccc cccc';
- public const C_CZ = 'CZkk bbbb ssss sscc cccc cccc';
+ public const _CZ = 'CZkk bbbb ssss sscc cccc cccc';
- public const C_DK = 'DKkk bbbb cccc cccc cc';
+ public const _DK = 'DKkk bbbb cccc cccc cc';
- public const C_DO = 'DOkk bbbb cccc cccc cccc cccc cccc';
+ public const _DO = 'DOkk bbbb cccc cccc cccc cccc cccc';
- public const C_TL = 'TLkk bbbc cccc cccc cccc cxx';
+ public const _TL = 'TLkk bbbc cccc cccc cccc cxx';
- public const C_EE = 'EEkk bbss cccc cccc cccx';
+ public const _EE = 'EEkk bbss cccc cccc cccx';
- public const C_FO = 'FOkk bbbb cccc cccc cx';
+ public const _FO = 'FOkk bbbb cccc cccc cx';
- public const C_FI = 'FIkk bbbb bbcc cccc cx';
+ public const _FI = 'FIkk bbbb bbcc cccc cx';
- public const C_FR = 'FRkk bbbb bsss sscc cccc cccc cxx';
+ public const _FR = 'FRkk bbbb bsss sscc cccc cccc cxx';
- public const C_GE = 'GEkk bbcc cccc cccc cccc cc';
+ public const _GE = 'GEkk bbcc cccc cccc cccc cc';
- public const C_DE = 'DEkk bbbb bbbb cccc cccc cc';
+ public const _DE = 'DEkk bbbb bbbb cccc cccc cc';
- public const C_GI = 'GIkk bbbb cccc cccc cccc ccc';
+ public const _GI = 'GIkk bbbb cccc cccc cccc ccc';
- public const C_GR = 'GRkk bbbs sssc cccc cccc cccc ccc';
+ public const _GR = 'GRkk bbbs sssc cccc cccc cccc ccc';
- public const C_GL = 'GLkk bbbb cccc cccc cc';
+ public const _GL = 'GLkk bbbb cccc cccc cc';
- public const C_GT = 'GTkk bbbb mmtt cccc cccc cccc cccc';
+ public const _GT = 'GTkk bbbb mmtt cccc cccc cccc cccc';
- public const C_HU = 'HUkk bbbs sssx cccc cccc cccc cccx';
+ public const _HU = 'HUkk bbbs sssx cccc cccc cccc cccx';
- public const C_IS = 'ISkk bbbb sscc cccc iiii iiii ii';
+ public const _IS = 'ISkk bbbb sscc cccc iiii iiii ii';
- public const C_IE = 'IEkk aaaa bbbb bbcc cccc cc';
+ public const _IE = 'IEkk aaaa bbbb bbcc cccc cc';
- public const C_IL = 'ILkk bbbn nncc cccc cccc ccc';
+ public const _IL = 'ILkk bbbn nncc cccc cccc ccc';
- public const C_IT = 'ITkk xbbb bbss sssc cccc cccc ccc';
+ public const _IT = 'ITkk xbbb bbss sssc cccc cccc ccc';
- public const C_JO = 'JOkk bbbb ssss cccc cccc cccc cccc cc';
+ public const _JO = 'JOkk bbbb ssss cccc cccc cccc cccc cc';
- public const C_KZ = 'KZkk bbbc cccc cccc cccc';
+ public const _KZ = 'KZkk bbbc cccc cccc cccc';
- public const C_XK = 'XKkk bbbb cccc cccc cccc';
+ public const _XK = 'XKkk bbbb cccc cccc cccc';
- public const C_KW = 'KWkk bbbb cccc cccc cccc cccc cccc cc';
+ public const _KW = 'KWkk bbbb cccc cccc cccc cccc cccc cc';
- public const C_LV = 'LVkk bbbb cccc cccc cccc c';
+ public const _LV = 'LVkk bbbb cccc cccc cccc c';
- public const C_LB = 'LBkk bbbb cccc cccc cccc cccc cccc';
+ public const _LB = 'LBkk bbbb cccc cccc cccc cccc cccc';
- public const C_LI = 'LIkk bbbb bccc cccc cccc c';
+ public const _LI = 'LIkk bbbb bccc cccc cccc c';
- public const C_LT = 'LTkk bbbb bccc cccc cccc';
+ public const _LT = 'LTkk bbbb bccc cccc cccc';
- public const C_LU = 'LUkk bbbc cccc cccc cccc';
+ public const _LU = 'LUkk bbbc cccc cccc cccc';
- public const C_MK = 'MKkk bbbc cccc cccc cxx';
+ public const _MK = 'MKkk bbbc cccc cccc cxx';
- public const C_MT = 'MTkk bbbb ssss sccc cccc cccc cccc ccc';
+ public const _MT = 'MTkk bbbb ssss sccc cccc cccc cccc ccc';
- public const C_MR = 'MRkk bbbb bsss sscc cccc cccc cxx';
+ public const _MR = 'MRkk bbbb bsss sscc cccc cccc cxx';
- public const C_MU = 'MUkk bbbb bbss cccc cccc cccc 000m mm';
+ public const _MU = 'MUkk bbbb bbss cccc cccc cccc 000m mm';
- public const C_MC = 'MCkk bbbb bsss sscc cccc cccc cxx';
+ public const _MC = 'MCkk bbbb bsss sscc cccc cccc cxx';
- public const C_MD = 'MDkk bbcc cccc cccc cccc cccc';
+ public const _MD = 'MDkk bbcc cccc cccc cccc cccc';
- public const C_ME = 'MEkk bbbc cccc cccc cccc xx';
+ public const _ME = 'MEkk bbbc cccc cccc cccc xx';
- public const C_NL = 'NLkk bbbb cccc cccc cc';
+ public const _NL = 'NLkk bbbb cccc cccc cc';
- public const C_NO = 'NOkk bbbb cccc ccx';
+ public const _NO = 'NOkk bbbb cccc ccx';
- public const C_PK = 'PKkk bbbb cccc cccc cccc cccc';
+ public const _PK = 'PKkk bbbb cccc cccc cccc cccc';
- public const C_PS = 'PSkk bbbb xxxx xxxx xccc cccc cccc c';
+ public const _PS = 'PSkk bbbb xxxx xxxx xccc cccc cccc c';
- public const C_PL = 'PLkk bbbs sssx cccc cccc cccc cccc';
+ public const _PL = 'PLkk bbbs sssx cccc cccc cccc cccc';
- public const C_PT = 'PTkk bbbb ssss cccc cccc cccx x';
+ public const _PT = 'PTkk bbbb ssss cccc cccc cccx x';
- public const C_QA = 'QAkk bbbb cccc cccc cccc cccc cccc c';
+ public const _QA = 'QAkk bbbb cccc cccc cccc cccc cccc c';
- public const C_RO = 'ROkk bbbb cccc cccc cccc cccc';
+ public const _RO = 'ROkk bbbb cccc cccc cccc cccc';
- public const C_SM = 'SMkk xbbb bbss sssc cccc cccc ccc';
+ public const _SM = 'SMkk xbbb bbss sssc cccc cccc ccc';
- public const C_SA = 'SAkk bbcc cccc cccc cccc cccc';
+ public const _SA = 'SAkk bbcc cccc cccc cccc cccc';
- public const C_RS = 'RSkk bbbc cccc cccc cccc xx';
+ public const _RS = 'RSkk bbbc cccc cccc cccc xx';
- public const C_SK = 'SKkk bbbb ssss sscc cccc cccc';
+ public const _SK = 'SKkk bbbb ssss sscc cccc cccc';
- public const C_SI = 'SIkk bbss sccc cccc cxx';
+ public const _SI = 'SIkk bbss sccc cccc cxx';
- public const C_ES = 'ESkk bbbb ssss xxcc cccc cccc';
+ public const _ES = 'ESkk bbbb ssss xxcc cccc cccc';
- public const C_SE = 'SEkk bbbc cccc cccc cccc cccc';
+ public const _SE = 'SEkk bbbc cccc cccc cccc cccc';
- public const C_CH = 'CHkk bbbb bccc cccc cccc c';
+ public const _CH = 'CHkk bbbb bccc cccc cccc c';
- public const C_TN = 'TNkk bbss sccc cccc cccc cccc';
+ public const _TN = 'TNkk bbss sccc cccc cccc cccc';
- public const C_TR = 'TRkk bbbb bxcc cccc cccc cccc cc';
+ public const _TR = 'TRkk bbbb bxcc cccc cccc cccc cc';
- public const C_UA = 'UAkk bbbb bbcc cccc cccc cccc cccc c';
+ public const _UA = 'UAkk bbbb bbcc cccc cccc cccc cccc c';
- public const C_AE = 'AEkk bbbc cccc cccc cccc ccc';
+ public const _AE = 'AEkk bbbc cccc cccc cccc ccc';
- public const C_GB = 'GBkk bbbb ssss sscc cccc cc';
+ public const _GB = 'GBkk bbbb ssss sscc cccc cc';
- public const C_VG = 'VGkk bbbb cccc cccc cccc cccc';
+ public const _VG = 'VGkk bbbb cccc cccc cccc cccc';
- public const C_SN = 'SNkk annn nnnn nnnn nnnn nnnn nnnn';
+ public const _SN = 'SNkk annn nnnn nnnn nnnn nnnn nnnn';
- public const C_MZ = 'MZkk nnnn nnnn nnnn nnnn nnnn n';
+ public const _MZ = 'MZkk nnnn nnnn nnnn nnnn nnnn n';
- public const C_ML = 'MLkk annn nnnn nnnn nnnn nnnn nnnn';
+ public const _ML = 'MLkk annn nnnn nnnn nnnn nnnn nnnn';
- public const C_MG = 'MGkk nnnn nnnn nnnn nnnn nnnn nnn';
+ public const _MG = 'MGkk nnnn nnnn nnnn nnnn nnnn nnn';
- public const C_CI = 'CIkk annn nnnn nnnn nnnn nnnn nnnn';
+ public const _CI = 'CIkk annn nnnn nnnn nnnn nnnn nnnn';
- public const C_IR = 'IRkk nnnn nnnn nnnn nnnn nnnn nn';
+ public const _IR = 'IRkk nnnn nnnn nnnn nnnn nnnn nn';
- public const C_CV = 'CVkk nnnn nnnn nnnn nnnn nnnn n';
+ public const _CV = 'CVkk nnnn nnnn nnnn nnnn nnnn n';
- public const C_CM = 'CMkk nnnn nnnn nnnn nnnn nnnn nnn';
+ public const _CM = 'CMkk nnnn nnnn nnnn nnnn nnnn nnn';
- public const C_BI = 'BIkk nnnn nnnn nnnn';
+ public const _BI = 'BIkk nnnn nnnn nnnn';
- public const C_BF = 'BFkk nnnn nnnn nnnn nnnn nnnn nnn';
+ public const _BF = 'BFkk nnnn nnnn nnnn nnnn nnnn nnn';
- public const C_BJ = 'BJkk annn nnnn nnnn nnnn nnnn nnnn';
+ public const _BJ = 'BJkk annn nnnn nnnn nnnn nnnn nnnn';
- public const C_AO = 'AOkk nnnn nnnn nnnn nnnn nnnn n';
+ public const _AO = 'AOkk nnnn nnnn nnnn nnnn nnnn n';
- public const C_DZ = 'DZkk nnnn nnnn nnnn nnnn nnnn';
+ public const _DZ = 'DZkk nnnn nnnn nnnn nnnn nnnn';
}
diff --git a/Validation/Network/Email.php b/Validation/Network/Email.php
index edb68fb2f..81a6dc209 100755
--- a/Validation/Network/Email.php
+++ b/Validation/Network/Email.php
@@ -39,7 +39,7 @@ abstract class Email extends ValidatorAbstract
/**
* {@inheritdoc}
*/
- public static function isValid(mixed $value, array $constraints = null) : bool
+ public static function isValid(mixed $value, ?array $constraints = null) : bool
{
if (\filter_var($value, \FILTER_VALIDATE_EMAIL) === false) {
self::$msg = 'Invalid Email by filter_var standards';
diff --git a/Validation/Network/Hostname.php b/Validation/Network/Hostname.php
index 215c7bdc7..7b6aa25a5 100755
--- a/Validation/Network/Hostname.php
+++ b/Validation/Network/Hostname.php
@@ -39,9 +39,9 @@ abstract class Hostname extends ValidatorAbstract
/**
* {@inheritdoc}
*
- * A IPv6 string MUST be in [...] to be sucessfully validated
+ * A IPv6 string MUST be in [...] to be successfully validated
*/
- public static function isValid(mixed $value, array $constraints = null) : bool
+ public static function isValid(mixed $value, ?array $constraints = null) : bool
{
//return \filter_var(\gethostbyname($value), \FILTER_VALIDATE_IP) !== false;
diff --git a/Validation/Network/Ip.php b/Validation/Network/Ip.php
index b8a358f53..dafffce06 100755
--- a/Validation/Network/Ip.php
+++ b/Validation/Network/Ip.php
@@ -39,7 +39,7 @@ abstract class Ip extends ValidatorAbstract
/**
* {@inheritdoc}
*/
- public static function isValid(mixed $value, array $constraints = null) : bool
+ public static function isValid(mixed $value, ?array $constraints = null) : bool
{
return \filter_var($value, \FILTER_VALIDATE_IP) !== false;
}
diff --git a/Validation/Validator.php b/Validation/Validator.php
index bbc88455a..80d879cf7 100755
--- a/Validation/Validator.php
+++ b/Validation/Validator.php
@@ -38,7 +38,7 @@ final class Validator extends ValidatorAbstract
*
* @since 1.0.0
*/
- public static function isValid(mixed $var, array $constraints = null) : bool
+ public static function isValid(mixed $var, ?array $constraints = null) : bool
{
if ($constraints === null) {
return true;
diff --git a/Validation/ValidatorInterface.php b/Validation/ValidatorInterface.php
index 955cfa258..48b419fab 100755
--- a/Validation/ValidatorInterface.php
+++ b/Validation/ValidatorInterface.php
@@ -34,7 +34,7 @@ interface ValidatorInterface
*
* @since 1.0.0
*/
- public static function isValid(mixed $value, array $constraints = null) : bool;
+ public static function isValid(mixed $value, ?array $constraints = null) : bool;
/**
* Get most recent error string.
diff --git a/Views/View.php b/Views/View.php
index f9b743c0a..15863d165 100755
--- a/Views/View.php
+++ b/Views/View.php
@@ -98,7 +98,7 @@ class View extends ViewAbstract
*
* @since 1.0.0
*/
- public function __construct(L11nManager $l11n = null, RequestAbstract $request = null, ResponseAbstract $response = null)
+ public function __construct(?L11nManager $l11n = null, ?RequestAbstract $request = null, ?ResponseAbstract $response = null)
{
$this->l11nManager = $l11n ?? new L11nManager();
$this->request = $request;
@@ -201,7 +201,7 @@ class View extends ViewAbstract
*
* @since 1.0.0
*/
- public function getText(string $translation, string $module = null, string $theme = null) : string
+ public function getText(string $translation, ?string $module = null, ?string $theme = null) : string
{
if ($module === null && $this->module === null) {
$this->setModuleDynamically();
@@ -302,7 +302,7 @@ class View extends ViewAbstract
*
* @since 1.0.0
*/
- public function getHtml(string $translation, string $module = null, string $theme = null) : string
+ public function getHtml(string $translation, ?string $module = null, ?string $theme = null) : string
{
return \htmlspecialchars($this->getText($translation, $module, $theme));
}
@@ -317,7 +317,7 @@ class View extends ViewAbstract
*
* @since 1.0.0
*/
- public function getNumeric(int | float | FloatInt $numeric, string $format = null) : string
+ public function getNumeric(int | float | FloatInt $numeric, ?string $format = null) : string
{
return $this->l11nManager->getNumeric($this->l11n, $numeric, $format);
}
@@ -325,14 +325,14 @@ class View extends ViewAbstract
/**
* Print a percentage value
*
- * @param float $percentage Percentage value to print
- * @param null|string $format Format type to use
+ * @param float|FloatInt $percentage Percentage value to print
+ * @param null|string $format Format type to use
*
* @return string
*
* @since 1.0.0
*/
- public function getPercentage(float $percentage, string $format = null) : string
+ public function getPercentage(float | FloatInt $percentage, ?string $format = null) : string
{
return $this->l11nManager->getPercentage($this->l11n, $percentage, $format);
}
@@ -351,8 +351,8 @@ class View extends ViewAbstract
*/
public function getCurrency(
int | float | Money | FloatInt $currency,
- string $symbol = null,
- string $format = null,
+ ?string $symbol = null,
+ ?string $format = null,
int $divide = 1
) : string
{
@@ -369,7 +369,7 @@ class View extends ViewAbstract
*
* @since 1.0.0
*/
- public function getDateTime(\DateTimeInterface $datetime = null, string $format = null) : string
+ public function getDateTime(?\DateTimeInterface $datetime = null, ?string $format = null) : string
{
return $this->l11nManager->getDateTime($this->l11n, $datetime, $format);
}
diff --git a/Views/ViewAbstract.php b/Views/ViewAbstract.php
index d39ca6b64..f218c0274 100755
--- a/Views/ViewAbstract.php
+++ b/Views/ViewAbstract.php
@@ -32,7 +32,7 @@ abstract class ViewAbstract implements RenderableInterface
* @var string
* @since 1.0.0
*/
- protected const BASE_PATH = __DIR__ . '/../..';
+ public const BASE_PATH = __DIR__ . '/../..';
/**
* Output is buffered
@@ -230,7 +230,7 @@ abstract class ViewAbstract implements RenderableInterface
}
/**
- * Arrayify view and it's subviews.
+ * Arrayify view and it's sub-views.
*
* @return array
*
diff --git a/preload.php b/preload.php
index 6f719dcad..9d94e5a8e 100755
--- a/preload.php
+++ b/preload.php
@@ -4,7 +4,7 @@
*
* PHP Version 8.1
*
- * @package Karaka
+ * @package Jingga
* @copyright Dennis Eichhorn
* @license OMS License 2.0
* @version 1.0.0
diff --git a/tests/Account/AccountManagerTest.php b/tests/Account/AccountManagerTest.php
index bc1e19090..63c6ea074 100755
--- a/tests/Account/AccountManagerTest.php
+++ b/tests/Account/AccountManagerTest.php
@@ -73,7 +73,7 @@ final class AccountManagerTest extends \PHPUnit\Framework\TestCase
public function testRetrieveAccount() : void
{
$this->manager->add($this->account);
- self::assertEquals($this->account, $this->manager->get($this->account->getId()));
+ self::assertEquals($this->account, $this->manager->get($this->account->id));
}
/**
@@ -87,7 +87,7 @@ final class AccountManagerTest extends \PHPUnit\Framework\TestCase
$added = $this->manager->add($this->account);
self::assertFalse($added);
- self::assertTrue($this->manager->remove($this->account->getId()));
+ self::assertTrue($this->manager->remove($this->account->id));
self::assertFalse($this->manager->remove(-1));
self::assertEquals(0, $this->manager->count());
}
@@ -100,7 +100,7 @@ final class AccountManagerTest extends \PHPUnit\Framework\TestCase
public function testRemoveAccount() : void
{
$this->manager->add($this->account);
- self::assertTrue($this->manager->remove($this->account->getId()));
+ self::assertTrue($this->manager->remove($this->account->id));
self::assertEquals(0, $this->manager->count());
self::assertFalse($this->manager->remove(-1));
}
@@ -115,7 +115,7 @@ final class AccountManagerTest extends \PHPUnit\Framework\TestCase
$this->manager->add($this->account);
self::assertFalse($this->manager->remove(-1));
self::assertEquals(1, $this->manager->count());
- self::assertTrue($this->manager->remove($this->account->getId()));
+ self::assertTrue($this->manager->remove($this->account->id));
self::assertEquals(0, $this->manager->count());
}
}
diff --git a/tests/Account/AccountTest.php b/tests/Account/AccountTest.php
index 130d2c571..99891fb9e 100755
--- a/tests/Account/AccountTest.php
+++ b/tests/Account/AccountTest.php
@@ -53,8 +53,8 @@ final class AccountTest extends \PHPUnit\Framework\TestCase
$account = new Account();
/* Testing default values */
- self::assertIsInt($account->getId());
- self::assertEquals(0, $account->getId());
+ self::assertIsInt($account->id);
+ self::assertEquals(0, $account->id);
self::assertInstanceOf('\phpOMS\Localization\Localization', $account->l11n);
@@ -74,11 +74,11 @@ final class AccountTest extends \PHPUnit\Framework\TestCase
self::assertIsString($account->getEmail());
self::assertEquals('', $account->getEmail());
- self::assertIsInt($account->getStatus());
- self::assertEquals(AccountStatus::INACTIVE, $account->getStatus());
+ self::assertIsInt($account->status);
+ self::assertEquals(AccountStatus::INACTIVE, $account->status);
- self::assertIsInt($account->getType());
- self::assertEquals(AccountType::USER, $account->getType());
+ self::assertIsInt($account->type);
+ self::assertEquals(AccountType::USER, $account->type);
self::assertEquals([], $account->getPermissions());
self::assertFalse($account->hasGroup(2));
@@ -145,34 +145,6 @@ final class AccountTest extends \PHPUnit\Framework\TestCase
self::assertEquals('d.duck@duckburg.com', $account->getEmail());
}
- /**
- * @testdox The default status of the account can be changed to a different valid status
- * @covers phpOMS\Account\Account
- * @group framework
- */
- public function testChangeStatus() : void
- {
- $account = new Account();
- $account->generatePassword('abcd');
-
- $account->setStatus(AccountStatus::ACTIVE);
- self::assertEquals(AccountStatus::ACTIVE, $account->getStatus());
- }
-
- /**
- * @testdox The default type of the account can be changed to a different valid type
- * @covers phpOMS\Account\Account
- * @group framework
- */
- public function testChangeType() : void
- {
- $account = new Account();
- $account->generatePassword('abcd');
-
- $account->setType(AccountType::GROUP);
- self::assertEquals(AccountType::GROUP, $account->getType());
- }
-
/**
* @testdox Account permissions can be added
* @covers phpOMS\Account\Account
@@ -293,40 +265,4 @@ final class AccountTest extends \PHPUnit\Framework\TestCase
$account = new Account();
$account->setEmail('d.duck!@#%@duckburg');
}
-
- /**
- * @testdox An account can only have valid account status
- * @group framework
- */
- public function testStatusException() : void
- {
- $this->expectException(\phpOMS\Stdlib\Base\Exception\InvalidEnumValue::class);
-
- $account = new Account();
-
- $rand = 0;
- do {
- $rand = \mt_rand(\PHP_INT_MIN, \PHP_INT_MAX);
- } while (AccountStatus::isValidValue($rand));
-
- $account->setStatus($rand);
- }
-
- /**
- * @testdox An account can only have valid account types
- * @group framework
- */
- public function testTypeException() : void
- {
- $this->expectException(\phpOMS\Stdlib\Base\Exception\InvalidEnumValue::class);
-
- $account = new Account();
-
- $rand = 0;
- do {
- $rand = \mt_rand(\PHP_INT_MIN, \PHP_INT_MAX);
- } while (AccountType::isValidValue($rand));
-
- $account->setType($rand);
- }
}
diff --git a/tests/Account/GroupTest.php b/tests/Account/GroupTest.php
index f55bbd427..a6d4c36c7 100755
--- a/tests/Account/GroupTest.php
+++ b/tests/Account/GroupTest.php
@@ -38,14 +38,14 @@ final class GroupTest extends \PHPUnit\Framework\TestCase
$group = new Group();
/* Testing default values */
- self::assertIsInt($group->getId());
- self::assertEquals(0, $group->getId());
+ self::assertIsInt($group->id);
+ self::assertEquals(0, $group->id);
self::assertIsString($group->name);
self::assertEquals('', $group->name);
- self::assertIsInt($group->getStatus());
- self::assertEquals(GroupStatus::INACTIVE, $group->getStatus());
+ self::assertIsInt($group->status);
+ self::assertEquals(GroupStatus::INACTIVE, $group->status);
self::assertIsString($group->description);
self::assertEquals('', $group->description);
@@ -138,36 +138,4 @@ final class GroupTest extends \PHPUnit\Framework\TestCase
$group->removePermission($perm);
self::assertCount(0, $group->getPermissions());
}
-
- /**
- * @testdox The default status of the group can be changed to a different valid status
- * @covers phpOMS\Account\Group
- * @group framework
- */
- public function testChangeStatus() : void
- {
- $group = new Group();
-
- $group->setStatus(GroupStatus::ACTIVE);
- self::assertEquals(GroupStatus::ACTIVE, $group->getStatus());
- }
-
- /**
- * @testdox A group can only have valid group status
- * @covers phpOMS\Account\Group
- * @group framework
- */
- public function testStatusException() : void
- {
- $this->expectException(\phpOMS\Stdlib\Base\Exception\InvalidEnumValue::class);
-
- $group = new Group();
-
- $rand = 0;
- do {
- $rand = \mt_rand(\PHP_INT_MIN, \PHP_INT_MAX);
- } while (GroupStatus::isValidValue($rand));
-
- $group->setStatus($rand);
- }
}
diff --git a/tests/Account/NullAccountTest.php b/tests/Account/NullAccountTest.php
index f3c5e5470..e08f6c07e 100755
--- a/tests/Account/NullAccountTest.php
+++ b/tests/Account/NullAccountTest.php
@@ -42,7 +42,7 @@ final class NullAccountTest extends \PHPUnit\Framework\TestCase
public function testId() : void
{
$null = new NullAccount(2);
- self::assertEquals(2, $null->getId());
+ self::assertEquals(2, $null->id);
}
public function testJsonSerialization() : void
diff --git a/tests/Account/NullGroupTest.php b/tests/Account/NullGroupTest.php
index 39694ba93..03e4738e3 100755
--- a/tests/Account/NullGroupTest.php
+++ b/tests/Account/NullGroupTest.php
@@ -42,7 +42,7 @@ final class NullGroupTest extends \PHPUnit\Framework\TestCase
public function testId() : void
{
$null = new NullGroup(2);
- self::assertEquals(2, $null->getId());
+ self::assertEquals(2, $null->id);
}
public function testJsonSerialization() : void
diff --git a/tests/Algorithm/Frequency/AprioriTest.php b/tests/Algorithm/Frequency/AprioriTest.php
new file mode 100644
index 000000000..fe998058b
--- /dev/null
+++ b/tests/Algorithm/Frequency/AprioriTest.php
@@ -0,0 +1,115 @@
+ 2,
+ 'epsilon' => 2,
+ 'epsilon:theta' => 0,
+ 'beta' => 4,
+ 'beta:theta' => 2,
+ 'beta:epsilon' => 2,
+ 'beta:epsilon:theta' => 0,
+ 'alpha' => 4,
+ 'alpha:theta' => 2,
+ 'alpha:epsilon' => 2,
+ 'alpha:epsilon:theta' => 0,
+ 'alpha:beta' => 4,
+ 'alpha:beta:theta' => 2,
+ 'alpha:beta:epsilon' => 2,
+ 'alpha:beta:epsilon:theta' => 0,
+ ],
+ Apriori::apriori([
+ ['alpha', 'beta', 'epsilon'],
+ ['alpha', 'beta', 'theta'],
+ ['alpha', 'beta', 'epsilon'],
+ ['alpha', 'beta', 'theta'],
+ ])
+ );
+
+ self::assertEquals(
+ [
+ '4' => 5,
+ '3' => 3,
+ '3:4' => 3,
+ '2' => 5,
+ '2:4' => 4,
+ '2:3' => 2,
+ '2:3:4' => 2,
+ '1' => 3,
+ '1:4' => 2,
+ '1:3' => 1,
+ '1:3:4' => 1,
+ '1:2' => 3,
+ '1:2:4' => 2,
+ '1:2:3' => 1,
+ '1:2:3:4' => 1,
+ ],
+ Apriori::apriori([
+ ['1', '2', '3', '4'],
+ ['1', '2', '4'],
+ ['1', '2'],
+ ['2', '3', '4'],
+ ['3', '4'],
+ ['2', '4'],
+ ])
+ );
+ }
+
+ public function testAprioriSubset() : void
+ {
+ self::assertEquals(
+ ['beta:theta' => 2],
+ Apriori::apriori(
+ [
+ ['alpha', 'beta', 'epsilon'],
+ ['alpha', 'beta', 'theta'],
+ ['alpha', 'beta', 'epsilon'],
+ ['alpha', 'beta', 'theta'],
+ ],
+ ['beta', 'theta']
+ )
+ );
+
+ self::assertEquals(
+ ['2:3' => 2],
+ Apriori::apriori(
+ [
+ ['1', '2', '3', '4'],
+ ['1', '2', '4'],
+ ['1', '2'],
+ ['2', '3', '4'],
+ ['3', '4'],
+ ['2', '4'],
+ ],
+ ['2', '3']
+ )
+ );
+ }
+}
diff --git a/tests/Algorithm/Graph/DependencyResolverTest.php b/tests/Algorithm/Graph/DependencyResolverTest.php
new file mode 100644
index 000000000..eeab355b6
--- /dev/null
+++ b/tests/Algorithm/Graph/DependencyResolverTest.php
@@ -0,0 +1,50 @@
+ [1, 2], 1 => [0, 2], 2 => []])
+ );
+ }
+
+ /**
+ * @covers phpOMS\Algorithm\Graph\DependencyResolver
+ * @group framework
+ */
+ public function testResolve() : void
+ {
+ self::assertEquals(
+ [2, 3, 1, 0],
+ DependencyResolver::resolve([0 => [1, 2], 1 => [2, 3], 2 => [], 3 => []])
+ );
+ }
+}
diff --git a/tests/Algorithm/Graph/MarkovChainTest.php b/tests/Algorithm/Graph/MarkovChainTest.php
new file mode 100644
index 000000000..0521dc2d5
--- /dev/null
+++ b/tests/Algorithm/Graph/MarkovChainTest.php
@@ -0,0 +1,105 @@
+setTraining(
+ [
+ 'A' => ['A' => 0.1, 'C' => 0.6, 'E' => 0.3],
+ 'C' => ['A' => 0.25, 'C' => 0.05, 'E' => 0.7],
+ 'E' => ['A' => 0.7, 'C' => 0.3, 'E' => 0.0],
+ ]
+ );
+
+ self::assertEquals(3, \count($markov->generate(3, ['A'])));
+ }
+
+ /**
+ * @covers phpOMS\Algorithm\Graph\MarkovChain
+ * @group framework
+ */
+ public function testTrainingGenerate() : void
+ {
+ $markov = new MarkovChain();
+ $markov->train(['A', 'C', 'E', 'A', 'C', 'E', 'E', 'C', 'A', 'A', 'E', 'A']);
+
+ self::assertEquals(5, \count($markov->generate(5, ['A'])));
+ }
+
+ /**
+ * @covers phpOMS\Algorithm\Graph\MarkovChain
+ * @group framework
+ */
+ public function testStepProbability() : void
+ {
+ $markov = new MarkovChain(2);
+ $markov->setTraining(
+ [
+ 'A A' => ['A' => 0.18, 'D' => 0.6, 'G' => 0.22],
+ 'A D' => ['A' => 0.5, 'D' => 0.5, 'G' => 0.0],
+ 'A G' => ['A' => 0.15, 'D' => 0.75, 'G' => 0.1],
+ 'D D' => ['A' => 0.0, 'D' => 0.0, 'G' => 1.0],
+ 'D A' => ['A' => 0.25, 'D' => 0.0, 'G' => 0.75],
+ 'D G' => ['A' => 0.9, 'D' => 0.1, 'G' => 0.0],
+ 'G G' => ['A' => 0.4, 'D' => 0.4, 'G' => 0.2],
+ 'G A' => ['A' => 0.5, 'D' => 0.25, 'G' => 0.25],
+ 'G D' => ['A' => 1.0, 'D' => 0.0, 'G' => 0.0],
+ ]
+ );
+
+ self::assertEquals(0.1, $markov->stepProbability(['D', 'G'], 'D'));
+ }
+
+ /**
+ * @covers phpOMS\Algorithm\Graph\MarkovChain
+ * @group framework
+ */
+ public function testPathProbability() : void
+ {
+ $markov = new MarkovChain(2);
+ $markov->setTraining(
+ [
+ 'A A' => ['A' => 0.18, 'D' => 0.6, 'G' => 0.22],
+ 'A D' => ['A' => 0.5, 'D' => 0.5, 'G' => 0.0],
+ 'A G' => ['A' => 0.15, 'D' => 0.75, 'G' => 0.1],
+ 'D D' => ['A' => 0.0, 'D' => 0.0, 'G' => 1.0],
+ 'D A' => ['A' => 0.25, 'D' => 0.0, 'G' => 0.75],
+ 'D G' => ['A' => 0.9, 'D' => 0.1, 'G' => 0.0],
+ 'G G' => ['A' => 0.4, 'D' => 0.4, 'G' => 0.2],
+ 'G A' => ['A' => 0.5, 'D' => 0.25, 'G' => 0.25],
+ 'G D' => ['A' => 1.0, 'D' => 0.0, 'G' => 0.0],
+ ]
+ );
+
+ self::assertEquals(0.9 * 0.5 * 0.6, $markov->pathProbability(['D', 'G', 'A', 'A', 'D']));
+ }
+}
diff --git a/tests/Algorithm/JobScheduling/WeightedTest.php b/tests/Algorithm/JobScheduling/WeightedTest.php
index fa7bd0412..69ce8908f 100755
--- a/tests/Algorithm/JobScheduling/WeightedTest.php
+++ b/tests/Algorithm/JobScheduling/WeightedTest.php
@@ -46,7 +46,7 @@ final class WeightedTest extends \PHPUnit\Framework\TestCase
$names = [];
foreach ($filtered as $job) {
- $value += $job->getValue();
+ $value += $job->getValue();
$names[] = $job->name;
}
diff --git a/tests/Api/Geocoding/NominatimTest.php b/tests/Api/Geocoding/NominatimTest.php
new file mode 100644
index 000000000..2d12e42fc
--- /dev/null
+++ b/tests/Api/Geocoding/NominatimTest.php
@@ -0,0 +1,46 @@
+ 50.3050738,
+ 'lon' => 8.688465172531158,
+ ],
+ Nominatim::geocoding('de', 'Rosbach', 'Kirchstraße 33'),
+ 0.01
+ );
+
+ self::assertEqualsWithDelta(
+ [
+ 'lat' => 50.3050738,
+ 'lon' => 8.688465172531158,
+ ],
+ Nominatim::geocoding('de', 'Rosbach', 'Kirchstraße 33', '61191'),
+ 0.01
+ );
+ }
+}
diff --git a/tests/Application/ApplicationInfoTest.php b/tests/Application/ApplicationInfoTest.php
index 427fe5a3e..6af83db67 100755
--- a/tests/Application/ApplicationInfoTest.php
+++ b/tests/Application/ApplicationInfoTest.php
@@ -111,7 +111,7 @@ final class ApplicationInfoTest extends \PHPUnit\Framework\TestCase
$info = new ApplicationInfo(__DIR__ . '/info-test.json');
$info->load();
- $testObj = new class() {
+ $testObj = new class() {
public $test = 1;
public function test() : void
diff --git a/tests/Application/ApplicationManagerTest.php b/tests/Application/ApplicationManagerTest.php
index 6c594c4e1..aac7e3318 100755
--- a/tests/Application/ApplicationManagerTest.php
+++ b/tests/Application/ApplicationManagerTest.php
@@ -49,7 +49,7 @@ final class ApplicationManagerTest extends \PHPUnit\Framework\TestCase
*/
protected function setUp() : void
{
- $app = new class() extends ApplicationAbstract {
+ $app = new class() extends ApplicationAbstract {
protected string $appName = 'Api';
};
@@ -62,12 +62,12 @@ final class ApplicationManagerTest extends \PHPUnit\Framework\TestCase
public function get(
mixed $ids = null,
- string | array $names = null,
- int $unit = null,
- int $app = null,
- string $module = null,
- int $group = null,
- int $account = null
+ string | array|null $names = null,
+ ?int $unit = null,
+ ?int $app = null,
+ ?string $module = null,
+ ?int $group = null,
+ ?int $account = null
) : mixed {
return '';
}
@@ -172,7 +172,7 @@ final class ApplicationManagerTest extends \PHPUnit\Framework\TestCase
}
/**
- * @testdox A invalid application path results in no uninstallation
+ * @testdox A invalid application path results in no uninstall
* @covers phpOMS\Application\ApplicationManager
* @group framework
*/
@@ -183,7 +183,7 @@ final class ApplicationManagerTest extends \PHPUnit\Framework\TestCase
}
/**
- * @testdox A missing uninstallation file results in no uninstallation
+ * @testdox A missing uninstall file results in no uninstall
* @covers phpOMS\Application\ApplicationManager
* @group framework
*/
diff --git a/tests/Application/InstallerAbstractTest.php b/tests/Application/InstallerAbstractTest.php
index d06211f77..0cdba868d 100755
--- a/tests/Application/InstallerAbstractTest.php
+++ b/tests/Application/InstallerAbstractTest.php
@@ -32,7 +32,7 @@ final class InstallerAbstractTest extends \PHPUnit\Framework\TestCase
*/
protected function setUp() : void
{
- $this->installer = new class() extends InstallerAbstract {
+ $this->installer = new class() extends InstallerAbstract {
public const PATH = __DIR__ . '/Invalid';
};
}
diff --git a/tests/Application/Testapp/Admin/Install/Application/Routes.php b/tests/Application/Testapp/Admin/Install/Application/Routes.php
index 8bfccbeab..8ca42bfe7 100755
--- a/tests/Application/Testapp/Admin/Install/Application/Routes.php
+++ b/tests/Application/Testapp/Admin/Install/Application/Routes.php
@@ -15,13 +15,13 @@ declare(strict_types=1);
use phpOMS\Router\RouteVerb;
return [
- '^.*/testapp.*$' => [
+ '^.*/testapp(\?.*$|$)' => [
[
'dest' => '\phpOMS\tess\Application\Apps\Testapp\Controller\Controller:testEndpoint',
'verb' => RouteVerb::GET,
'permission' => [
- 'type' => 1,
- 'state' => 2,
+ 'type' => 1,
+ 'state' => 2,
],
],
],
diff --git a/tests/Application/Testapp/info.json b/tests/Application/Testapp/info.json
index d079e1e00..96bc7c4f2 100755
--- a/tests/Application/Testapp/info.json
+++ b/tests/Application/Testapp/info.json
@@ -14,7 +14,6 @@
"name": "Jingga",
"website": "jingga.app"
},
- "description": "The administration module.",
"directory": "Admin",
"providing": {
"Navigation": "*",
diff --git a/tests/Application/info-test.json b/tests/Application/info-test.json
index bb4cc9cba..8b8fe302f 100755
--- a/tests/Application/info-test.json
+++ b/tests/Application/info-test.json
@@ -14,7 +14,6 @@
"name": "Jingga",
"website": "jingga.app"
},
- "description": "The administration module.",
"directory": "Admin",
"providing": {
"Navigation": "*"
diff --git a/tests/Autoloader.php b/tests/Autoloader.php
index 6e249662d..95dd1b74c 100755
--- a/tests/Autoloader.php
+++ b/tests/Autoloader.php
@@ -75,8 +75,8 @@ class Autoloader
*/
public static function defaultAutoloader(string $class) : void
{
- $class = \ltrim($class, '\\');
- $class = \strtr($class, '_\\', '//');
+ $class = \ltrim($class, '\\');
+ $class = \strtr($class, '_\\', '//');
if (\stripos($class, 'Web/Backend') !== false || \stripos($class, 'Web/Api') !== false) {
$class = \is_dir(__DIR__ . '/Web') ? $class : \str_replace('Web/', 'MainRepository/Web/', $class);
diff --git a/tests/Bootstrap.php b/tests/Bootstrap.php
index 1b48ed57b..44c8a78a9 100755
--- a/tests/Bootstrap.php
+++ b/tests/Bootstrap.php
@@ -1,4 +1,15 @@
[
+ 'db' => [
'core' => [
'masters' => [
- 'admin' => [
+ 'admin' => [
'db' => 'mysql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '3306', /* db host port */
@@ -80,7 +91,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'insert' => [
+ 'insert' => [
'db' => 'mysql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '3306', /* db host port */
@@ -90,7 +101,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'select' => [
+ 'select' => [
'db' => 'mysql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '3306', /* db host port */
@@ -100,7 +111,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'update' => [
+ 'update' => [
'db' => 'mysql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '3306', /* db host port */
@@ -110,7 +121,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'delete' => [
+ 'delete' => [
'db' => 'mysql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '3306', /* db host port */
@@ -120,7 +131,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'schema' => [
+ 'schema' => [
'db' => 'mysql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '3306', /* db host port */
@@ -132,7 +143,7 @@ $CONFIG = [
],
],
'postgresql' => [
- 'admin' => [
+ 'admin' => [
'db' => 'pgsql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '5432', /* db host port */
@@ -142,7 +153,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'insert' => [
+ 'insert' => [
'db' => 'pgsql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '5432', /* db host port */
@@ -152,7 +163,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'select' => [
+ 'select' => [
'db' => 'pgsql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '5432', /* db host port */
@@ -162,7 +173,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'update' => [
+ 'update' => [
'db' => 'pgsql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '5432', /* db host port */
@@ -172,7 +183,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'delete' => [
+ 'delete' => [
'db' => 'pgsql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '5432', /* db host port */
@@ -182,7 +193,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'schema' => [
+ 'schema' => [
'db' => 'pgsql', /* db type */
'host' => '127.0.0.1', /* db host address */
'port' => '5432', /* db host port */
@@ -194,37 +205,37 @@ $CONFIG = [
],
],
'sqlite' => [
- 'admin' => [
+ 'admin' => [
'db' => 'sqlite', /* db type */
'database' => __DIR__ . '/../Localization/Defaults/localization.sqlite', /* db name */
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'insert' => [
+ 'insert' => [
'db' => 'sqlite', /* db type */
'database' => __DIR__ . '/../Localization/Defaults/localization.sqlite', /* db name */
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'select' => [
+ 'select' => [
'db' => 'sqlite', /* db type */
'database' => __DIR__ . '/../Localization/Defaults/localization.sqlite', /* db name */
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'update' => [
+ 'update' => [
'db' => 'sqlite', /* db type */
'database' => __DIR__ . '/../Localization/Defaults/localization.sqlite', /* db name */
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'delete' => [
+ 'delete' => [
'db' => 'sqlite', /* db type */
'database' => __DIR__ . '/../Localization/Defaults/localization.sqlite', /* db name */
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'schema' => [
+ 'schema' => [
'db' => 'sqlite', /* db type */
'database' => __DIR__ . '/../Localization/Defaults/localization.sqlite', /* db name */
'weight' => 1000, /* db table prefix */
@@ -232,7 +243,7 @@ $CONFIG = [
],
],
'mssql' => [
- 'admin' => [
+ 'admin' => [
'db' => 'mssql', /* db type */
'host' => 'localhost', /* db host address */
'port' => '1433', /* db host port */
@@ -242,7 +253,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'insert' => [
+ 'insert' => [
'db' => 'mssql', /* db type */
'host' => 'localhost', /* db host address */
'port' => '1433', /* db host port */
@@ -252,7 +263,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'select' => [
+ 'select' => [
'db' => 'mssql', /* db type */
'host' => 'localhost', /* db host address */
'port' => '1433', /* db host port */
@@ -262,7 +273,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'update' => [
+ 'update' => [
'db' => 'mssql', /* db type */
'host' => 'localhost', /* db host address */
'port' => '1433', /* db host port */
@@ -272,7 +283,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'delete' => [
+ 'delete' => [
'db' => 'mssql', /* db type */
'host' => 'localhost', /* db host address */
'port' => '1433', /* db host port */
@@ -282,7 +293,7 @@ $CONFIG = [
'weight' => 1000, /* db table prefix */
'datetimeformat' => 'Y-m-d H:i:s',
],
- 'schema' => [
+ 'schema' => [
'db' => 'mssql', /* db type */
'host' => 'localhost', /* db host address */
'port' => '1433', /* db host port */
@@ -322,16 +333,16 @@ $CONFIG = [
'password' => '123456',
],
],
- 'log' => [
+ 'log' => [
'file' => [
'path' => __DIR__ . '/Logs',
],
],
- 'page' => [
+ 'page' => [
'root' => '/',
'https' => false,
],
- 'app' => [
+ 'app' => [
'path' => __DIR__,
'default' => [
'app' => 'Backend',
@@ -350,7 +361,7 @@ $CONFIG = [
],
],
],
- 'socket' => [
+ 'socket' => [
'master' => [
'host' => '127.0.0.1',
'limit' => 300,
@@ -360,7 +371,7 @@ $CONFIG = [
'language' => [
'en',
],
- 'apis' => [
+ 'apis' => [
],
];
diff --git a/tests/Business/Finance/FinanceFormulasTest.php b/tests/Business/Finance/FinanceFormulasTest.php
index 54d2b1b59..dcf12e886 100755
--- a/tests/Business/Finance/FinanceFormulasTest.php
+++ b/tests/Business/Finance/FinanceFormulasTest.php
@@ -121,13 +121,13 @@ final class FinanceFormulasTest extends \PHPUnit\Framework\TestCase
* @covers phpOMS\Business\Finance\FinanceFormulas
* @group framework
*/
- public function testAnnutiyPaymentFactorPV() : void
+ public function testAnnuityPaymentFactorPV() : void
{
$expected = 0.21216;
$r = 0.02;
$n = 5;
- $p = FinanceFormulas::getAnnutiyPaymentFactorPV($r, $n);
+ $p = FinanceFormulas::getAnnuityPaymentFactorPV($r, $n);
self::assertEqualsWithDelta(\round($expected, 5), \round($p, 5), 0.01);
self::assertEqualsWithDelta($n, FinanceFormulas::getNumberOfAPFPV($p, $r), 0.01);
@@ -314,8 +314,8 @@ final class FinanceFormulasTest extends \PHPUnit\Framework\TestCase
$C = \round(FinanceFormulas::getCompoundInterest($P, $r, $t), 2);
self::assertEqualsWithDelta(\round($expected, 2), $C, 0.01);
- self::assertEqualsWithDelta($P, FinanceFormulas::getPrincipalOfCompundInterest($C, $r, $t), 0.1);
- self::assertEqualsWithDelta($t, (int) \round(FinanceFormulas::getPeriodsOfCompundInterest($P, $C, $r), 0), 0.01);
+ self::assertEqualsWithDelta($P, FinanceFormulas::getPrincipalOfCompoundInterest($C, $r, $t), 0.1);
+ self::assertEqualsWithDelta($t, (int) \round(FinanceFormulas::getPeriodsOfCompoundInterest($P, $C, $r), 0), 0.01);
}
/**
diff --git a/tests/Business/Recommendation/BayesianPersonalizedRankingTest.php b/tests/Business/Recommendation/BayesianPersonalizedRankingTest.php
new file mode 100644
index 000000000..f8ed76a2e
--- /dev/null
+++ b/tests/Business/Recommendation/BayesianPersonalizedRankingTest.php
@@ -0,0 +1,24 @@
+ [1.0, 2.0],
+ 'B' => [2.0, 4.0],
+ 'C' => [2.5, 4.0],
+ 'D' => [4.5, 5.0],
+ ]);
+
+ self::assertEquals(
+ ['B', 'C'],
+ $memory->bestMatch([2.2, 4.1], 2)
+ );
+ }
+}
diff --git a/tests/Business/Recommendation/ModelCFTest.php b/tests/Business/Recommendation/ModelCFTest.php
new file mode 100644
index 000000000..4e10ac810
--- /dev/null
+++ b/tests/Business/Recommendation/ModelCFTest.php
@@ -0,0 +1,48 @@
+cache->get('test'));
self::assertEquals(
[
- 'status' => CacheStatus::OK,
- 'count' => 0,
- 'size' => 0,
+ 'status' => CacheStatus::OK,
+ 'count' => 0,
+ 'size' => 0,
],
$this->cache->stats()
);
@@ -237,7 +237,7 @@ final class FileCacheTest extends \PHPUnit\Framework\TestCase
self::assertEquals([], $this->cache->getLike('key\d'));
}
- public function testExpiredDelteLike() : void
+ public function testExpiredDeleteLike() : void
{
$this->cache->set('key1', 'testVal1', 2);
$this->cache->set('key2', 'testVal2', 2);
@@ -339,9 +339,9 @@ final class FileCacheTest extends \PHPUnit\Framework\TestCase
self::assertEquals(
[
- 'status' => CacheStatus::OK,
- 'count' => 2,
- 'size' => 17,
+ 'status' => CacheStatus::OK,
+ 'count' => 2,
+ 'size' => 17,
],
$this->cache->stats()
);
@@ -365,9 +365,9 @@ final class FileCacheTest extends \PHPUnit\Framework\TestCase
self::assertEquals(
[
- 'status' => CacheStatus::OK,
- 'count' => 0,
- 'size' => 0,
+ 'status' => CacheStatus::OK,
+ 'count' => 0,
+ 'size' => 0,
],
$this->cache->stats()
);
diff --git a/tests/DataStorage/Cache/Connection/MemCachedTest.php b/tests/DataStorage/Cache/Connection/MemCachedTest.php
index fe8614030..db3ff6c14 100755
--- a/tests/DataStorage/Cache/Connection/MemCachedTest.php
+++ b/tests/DataStorage/Cache/Connection/MemCachedTest.php
@@ -63,9 +63,9 @@ final class MemCachedTest extends \PHPUnit\Framework\TestCase
self::assertEquals(11211, $this->cache->getPort());
self::assertEquals(
[
- 'status' => CacheStatus::OK,
- 'count' => 0,
- 'size' => 0,
+ 'status' => CacheStatus::OK,
+ 'count' => 0,
+ 'size' => 0,
],
$this->cache->stats()
);
@@ -321,7 +321,7 @@ final class MemCachedTest extends \PHPUnit\Framework\TestCase
self::assertTrue($this->cache->flushAll());
self::assertNull($this->cache->get('key5'));
- // Carefull memcached is dumb and keeps expired elements which were not acessed after flushing in stat
+ // Careful memcached is dumb and keeps expired elements which were not acessed after flushing in stat
self::assertGreaterThanOrEqual(0, $this->cache->stats()['count']);
self::assertGreaterThanOrEqual(0, $this->cache->stats()['size']);
}
diff --git a/tests/DataStorage/Database/DataMapperAbstractTest.php b/tests/DataStorage/Database/DataMapperAbstractTest.php
index 1e34165fd..ceb2b0873 100755
--- a/tests/DataStorage/Database/DataMapperAbstractTest.php
+++ b/tests/DataStorage/Database/DataMapperAbstractTest.php
@@ -14,6 +14,8 @@ declare(strict_types=1);
namespace phpOMS\tests\DataStorage\Database;
+include_once __DIR__ . '/../../Autoloader.php';
+
use phpOMS\DataStorage\Database\Query\OrderType;
use phpOMS\tests\DataStorage\Database\TestModel\BaseModel;
use phpOMS\tests\DataStorage\Database\TestModel\BaseModelMapper;
@@ -42,21 +44,27 @@ final class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
{
$this->model = new BaseModel();
+ \phpOMS\Log\FileLogger::getInstance()->verbose = true;
+
$GLOBALS['dbpool']->get()->con->prepare(
'CREATE TABLE `test_base` (
`test_base_id` int(11) NOT NULL AUTO_INCREMENT,
`test_base_string` varchar(254) NOT NULL,
+ `test_base_compress` BLOB NOT NULL,
+ `test_base_pstring` varchar(254) NOT NULL,
`test_base_int` int(11) NOT NULL,
`test_base_bool` tinyint(1) DEFAULT NULL,
`test_base_null` int(11) DEFAULT NULL,
`test_base_float` decimal(5, 4) DEFAULT NULL,
`test_base_belongs_to_one` int(11) DEFAULT NULL,
+ `test_base_belongs_top_one` int(11) DEFAULT NULL,
`test_base_owns_one_self` int(11) DEFAULT NULL,
+ `test_base_owns_onep_self` int(11) DEFAULT NULL,
`test_base_json` varchar(254) DEFAULT NULL,
`test_base_json_serializable` varchar(254) DEFAULT NULL,
`test_base_serializable` varchar(254) DEFAULT NULL,
`test_base_datetime` datetime DEFAULT NULL,
- `test_base_datetime_null` datetime DEFAULT NULL, /* There was a bug where it returned the current date because new \DateTime(null) === current date which is wrong, we want null as value! */
+ `test_base_datetime_null` datetime DEFAULT NULL,
PRIMARY KEY (`test_base_id`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
)->execute();
@@ -112,6 +120,49 @@ final class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
PRIMARY KEY (`test_has_many_rel_relations_id`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
)->execute();
+
+ // private
+ $GLOBALS['dbpool']->get()->con->prepare(
+ 'CREATE TABLE `test_has_many_directp` (
+ `test_has_many_directp_id` int(11) NOT NULL AUTO_INCREMENT,
+ `test_has_many_directp_string` varchar(254) NOT NULL,
+ `test_has_many_directp_to` int(11) NOT NULL,
+ PRIMARY KEY (`test_has_many_directp_id`)
+ )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
+ )->execute();
+
+ $GLOBALS['dbpool']->get()->con->prepare(
+ 'CREATE TABLE `test_has_many_relp` (
+ `test_has_many_relp_id` int(11) NOT NULL AUTO_INCREMENT,
+ `test_has_many_relp_string` varchar(254) NOT NULL,
+ PRIMARY KEY (`test_has_many_relp_id`)
+ )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
+ )->execute();
+
+ $GLOBALS['dbpool']->get()->con->prepare(
+ 'CREATE TABLE `test_has_many_rel_relationsp` (
+ `test_has_many_rel_relationsp_id` int(11) NOT NULL AUTO_INCREMENT,
+ `test_has_many_rel_relationsp_src` int(11) NOT NULL,
+ `test_has_many_rel_relationsp_dest` int(11) NOT NULL,
+ PRIMARY KEY (`test_has_many_rel_relationsp_id`)
+ )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
+ )->execute();
+
+ $GLOBALS['dbpool']->get()->con->prepare(
+ 'CREATE TABLE `test_belongs_to_onep` (
+ `test_belongs_to_onep_id` int(11) NOT NULL AUTO_INCREMENT,
+ `test_belongs_to_onep_string` varchar(254) NOT NULL,
+ PRIMARY KEY (`test_belongs_to_onep_id`)
+ )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
+ )->execute();
+
+ $GLOBALS['dbpool']->get()->con->prepare(
+ 'CREATE TABLE `test_owns_onep` (
+ `test_owns_onep_id` int(11) NOT NULL AUTO_INCREMENT,
+ `test_owns_onep_string` varchar(254) NOT NULL,
+ PRIMARY KEY (`test_owns_onep_id`)
+ )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
+ )->execute();
}
protected function tearDown() : void
@@ -123,6 +174,14 @@ final class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_direct')->execute();
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_rel')->execute();
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_rel_relations')->execute();
+
+ $GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_directp')->execute();
+ $GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_relp')->execute();
+ $GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_rel_relationsp')->execute();
+ $GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_belongs_to_onep')->execute();
+ $GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_owns_onep')->execute();
+
+ \phpOMS\Log\FileLogger::getInstance()->verbose = false;
}
/**
@@ -138,7 +197,7 @@ final class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
public function testCreate() : void
{
self::assertGreaterThan(0, BaseModelMapper::create()->execute($this->model));
- self::assertGreaterThan(0, $this->model->getId());
+ self::assertGreaterThan(0, $this->model->id);
}
public function testCreateNullModel() : void
@@ -153,9 +212,9 @@ final class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
public function testCreateAlreadyCreatedModel() : void
{
self::assertGreaterThan(0, $id = BaseModelMapper::create()->execute($this->model));
- self::assertGreaterThan(0, $this->model->getId());
+ self::assertGreaterThan(0, $this->model->id);
self::assertEquals($id, BaseModelMapper::create()->execute($this->model));
- self::assertEquals($id, $this->model->getId());
+ self::assertEquals($id, $this->model->id);
}
public function testCreateHasManyRelation() : void
@@ -197,8 +256,10 @@ final class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
->where('id', $id)
->execute();
- self::assertEquals($this->model->getId(), $modelR->getId());
+ self::assertEquals($this->model->id, $modelR->id);
self::assertEquals($this->model->string, $modelR->string);
+ self::assertEquals($this->model->compress, $modelR->compress);
+ self::assertEquals($this->model->getPString(), $modelR->getPString());
self::assertEquals($this->model->int, $modelR->int);
self::assertEquals($this->model->bool, $modelR->bool);
self::assertEquals($this->model->float, $modelR->float);
@@ -218,12 +279,38 @@ final class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
self::assertEquals($this->model->belongsToOne->string, $modelR->belongsToOne->string);
}
+ public function testGetRaw() : void
+ {
+ $id = BaseModelMapper::create()->execute($this->model);
+
+ /** @var BaseModel $modelR */
+ $modelR = BaseModelMapper::getRaw()
+ ->with('belongsToOne')
+ ->with('ownsOneSelf')
+ ->with('hasManyDirect')
+ ->with('hasMnayRelations')
+ ->with('conditional')
+ ->where('id', $id)
+ ->execute();
+
+ self::assertTrue(\is_array($modelR));
+ }
+
public function testGetAll() : void
{
BaseModelMapper::create()->execute($this->model);
self::assertCount(1, BaseModelMapper::getAll()->execute());
}
+ public function testGetYield() : void
+ {
+ BaseModelMapper::create()->execute($this->model);
+
+ foreach (BaseModelMapper::yield()->execute() as $model) {
+ self::assertGreaterThan(0, $model->id);
+ }
+ }
+
public function testGetFor() : void
{
$id = BaseModelMapper::create()->execute($this->model);
@@ -247,7 +334,7 @@ final class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
$id2 = BaseModelMapper::create()->execute($model2);
$by = BaseModelMapper::get()->where('string', '456')->execute();
- self::assertEquals($model2->getId(), $by->getId());
+ self::assertEquals($model2->id, $by->id);
}
public function testGetNewest() : void
@@ -255,13 +342,14 @@ final class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
$model1 = new BaseModel();
$model1->datetime = new \DateTime('now');
$id1 = BaseModelMapper::create()->execute($model1);
+
\sleep(1);
$model2 = new BaseModel();
$model2->datetime = new \DateTime('now');
$id2 = BaseModelMapper::create()->execute($model2);
$newest = BaseModelMapper::getAll()->sort('id', OrderType::DESC)->limit(1)->execute();
- self::assertEquals($id2, \reset($newest)->getId());
+ self::assertEquals($id2, \reset($newest)->id);
}
public function testGetNullModel() : void
@@ -269,6 +357,38 @@ final class DataMapperAbstractTest extends \PHPUnit\Framework\TestCase
self::assertEquals(NullBaseModel::class, \get_class(BaseModelMapper::get()->where('id', 99)->execute()));
}
+ public function testCount() : void
+ {
+ BaseModelMapper::create()->execute($this->model);
+ self::assertEquals(1, BaseModelMapper::count()->execute());
+ }
+
+ public function testSum() : void
+ {
+ BaseModelMapper::create()->execute($this->model);
+ self::assertEquals(11, BaseModelMapper::sum()->columns(['test_base_int'])->execute());
+ }
+
+ public function testExists() : void
+ {
+ $id = BaseModelMapper::create()->execute($this->model);
+ self::assertTrue(BaseModelMApper::exists()->where('id', $id)->execute());
+ self::assertFalse(BaseModelMApper::exists()->where('id', $id + 1)->execute());
+ }
+
+ public function testHas() : void
+ {
+ $id = BaseModelMapper::create()->execute($this->model);
+ self::assertTrue(BaseModelMApper::has()->with('hasManyRelations')->where('id', $id)->execute());
+ self::assertTrue(BaseModelMApper::has()->with('hasManyDirect')->where('id', $id)->execute());
+ }
+
+ public function testRandom() : void
+ {
+ $id = BaseModelMapper::create()->execute($this->model);
+ self::assertEquals($id, BaseModelMApper::getRandom()->limit(1)->execute()->id);
+ }
+
/**
* @covers phpOMS\DataStorage\Database\Mapper\DataMapperAbstract
* @covers phpOMS\DataStorage\Database\Mapper\DataMapperFactory
diff --git a/tests/DataStorage/Database/Query/BuilderTest.php b/tests/DataStorage/Database/Query/BuilderTest.php
index fb61096a5..0defa7035 100755
--- a/tests/DataStorage/Database/Query/BuilderTest.php
+++ b/tests/DataStorage/Database/Query/BuilderTest.php
@@ -85,7 +85,7 @@ final class BuilderTest extends \PHPUnit\Framework\TestCase
$datetime = new \DateTime('now');
$sql = 'SELECT [a].[test], [b].[test] FROM [a], [b] WHERE [a].[test] = \'' . $datetime->format('Y-m-d H:i:s')
. '\';';
- $sql = \strtr($sql, '[]', $iS . $iE);
+ $sql = \strtr($sql, '[]', $iS . $iE);
self::assertEquals($sql, $query->select('a.test', 'b.test')->from('a', 'b')->where('a.test', '=', $datetime)->toSql());
$query = new Builder($con);
@@ -121,7 +121,7 @@ final class BuilderTest extends \PHPUnit\Framework\TestCase
$iE = $con->getGrammar()->systemIdentifierEnd;
$query = new Builder($con);
- $sql = 'SELECT [a].[test] FROM [a] as b WHERE [a].[test] = 1 ORDER BY \rand() LIMIT 1;';
+ $sql = 'SELECT [a].[test] FROM [a] as b WHERE [a].[test] = 1 ORDER BY RAND() LIMIT 1;';
$sql = \strtr($sql, '[]', $iS . $iE);
self::assertEquals($sql, $query->random('a.test')->fromAs('a', 'b')->where('a.test', '=', 1)->toSql());
}
@@ -535,19 +535,19 @@ final class BuilderTest extends \PHPUnit\Framework\TestCase
$iE = $con->getGrammar()->systemIdentifierEnd;
$query = new Builder($con);
- $sql = 'UPDATE [a] SET [a].[test] = 1, [a].[test2] = 2 WHERE [a].[test] = 1;';
+ $sql = 'UPDATE [a] SET [test] = 1, [test2] = 2 WHERE [a].[test] = 1;';
$sql = \strtr($sql, '[]', $iS . $iE);
- self::assertEquals($sql, $query->update('a')->set(['a.test' => 1])->set(['a.test2' => 2])->where('a.test', '=', 1)->toSql());
+ self::assertEquals($sql, $query->update('a')->set(['test' => 1])->set(['test2' => 2])->where('a.test', '=', 1)->toSql());
$query = new Builder($con);
- $sql = 'UPDATE [a] SET [a].[test] = 1, [a].[test2] = 2 WHERE [a].[test] = 1;';
+ $sql = 'UPDATE [a] SET [test] = 1, [test2] = 2 WHERE [a].[test] = 1;';
$sql = \strtr($sql, '[]', $iS . $iE);
- self::assertEquals($sql, $query->update('a')->sets('a.test', 1)->sets('a.test2', 2)->where('a.test', '=', 1)->toSql());
+ self::assertEquals($sql, $query->update('a')->sets('test', 1)->sets('test2', 2)->where('a.test', '=', 1)->toSql());
$query = new Builder($con);
- $sql = 'UPDATE [a] SET [a].[test] = 1, [a].[test2] = :test2 WHERE [a].[test] = :test3;';
+ $sql = 'UPDATE [a] SET [test] = 1, [test2] = :test2 WHERE [a].[test] = :test3;';
$sql = \strtr($sql, '[]', $iS . $iE);
- self::assertEquals($sql, $query->update('a')->set(['a.test' => 1])->set(['a.test2' => new Parameter('test2')])->where('a.test', '=', new Parameter('test3'))->toSql());
+ self::assertEquals($sql, $query->update('a')->set(['test' => 1])->set(['test2' => new Parameter('test2')])->where('a.test', '=', new Parameter('test3'))->toSql());
}
/**
@@ -744,28 +744,6 @@ final class BuilderTest extends \PHPUnit\Framework\TestCase
$query->delete();
}
- /**
- * @testdox Invalid select types throw a InvalidArgumentException
- * @group framework
- * @dataProvider dbConnectionProvider
- */
- public function testInvalidSelectParameter($con) : void
- {
- if (!$con->isInitialized()) {
- self::markTestSkipped();
-
- return;
- }
-
- $iS = $con->getGrammar()->systemIdentifierStart;
- $iE = $con->getGrammar()->systemIdentifierEnd;
-
- $this->expectException(\InvalidArgumentException::class);
-
- $query = new Builder($con, true);
- $query->select(false);
- }
-
/**
* @testdox Invalid from types throw a InvalidArgumentException
* @group framework
diff --git a/tests/DataStorage/Database/Query/ColumnTest.php b/tests/DataStorage/Database/Query/ColumnTest.php
deleted file mode 100755
index 51a14aa20..000000000
--- a/tests/DataStorage/Database/Query/ColumnTest.php
+++ /dev/null
@@ -1,32 +0,0 @@
-get()));
- }
-}
diff --git a/tests/DataStorage/Database/Query/CountTest.php b/tests/DataStorage/Database/Query/CountTest.php
deleted file mode 100755
index d13cfd7a8..000000000
--- a/tests/DataStorage/Database/Query/CountTest.php
+++ /dev/null
@@ -1,32 +0,0 @@
-get()));
- }
-}
diff --git a/tests/DataStorage/Database/Query/ExpressionTest.php b/tests/DataStorage/Database/Query/ExpressionTest.php
deleted file mode 100755
index 0743230fc..000000000
--- a/tests/DataStorage/Database/Query/ExpressionTest.php
+++ /dev/null
@@ -1,32 +0,0 @@
-get()));
- }
-}
diff --git a/tests/DataStorage/Database/Query/FromTest.php b/tests/DataStorage/Database/Query/FromTest.php
deleted file mode 100755
index f1a7111d9..000000000
--- a/tests/DataStorage/Database/Query/FromTest.php
+++ /dev/null
@@ -1,32 +0,0 @@
-get()));
- }
-}
diff --git a/tests/DataStorage/Database/Query/IntoTest.php b/tests/DataStorage/Database/Query/IntoTest.php
deleted file mode 100755
index fd3daafaa..000000000
--- a/tests/DataStorage/Database/Query/IntoTest.php
+++ /dev/null
@@ -1,32 +0,0 @@
-get()));
- }
-}
diff --git a/tests/DataStorage/Database/Query/SelectTest.php b/tests/DataStorage/Database/Query/SelectTest.php
deleted file mode 100755
index 83a46661e..000000000
--- a/tests/DataStorage/Database/Query/SelectTest.php
+++ /dev/null
@@ -1,32 +0,0 @@
-get()));
- }
-}
diff --git a/tests/DataStorage/Database/Schema/BuilderTest.php b/tests/DataStorage/Database/Schema/BuilderTest.php
index b988c99c0..f5a70693e 100755
--- a/tests/DataStorage/Database/Schema/BuilderTest.php
+++ b/tests/DataStorage/Database/Schema/BuilderTest.php
@@ -170,7 +170,6 @@ final class BuilderTest extends \PHPUnit\Framework\TestCase
$iS = $con->getGrammar()->systemIdentifierStart;
$iE = $con->getGrammar()->systemIdentifierEnd;
- // @todo: fix, this is not correct for sqlite
$query = new Builder($con);
$sql = '';
@@ -181,7 +180,7 @@ final class BuilderTest extends \PHPUnit\Framework\TestCase
} elseif ($con instanceof SqlServerConnection) {
$sql = 'CREATE TABLE IF NOT EXISTS [user_roles] ([user_id] INT AUTO_INCREMENT, [role_id] VARCHAR(10) DEFAULT \'1\' NULL, PRIMARY KEY ([user_id]), FOREIGN KEY ([user_id]) REFERENCES [users] ([ext1_id]), FOREIGN KEY ([role_id]) REFERENCES [roles] ([ext2_id]));';
} elseif ($con instanceof SQLiteConnection) {
- $sql = 'CREATE TABLE IF NOT EXISTS [user_roles] ([user_id] INT AUTO_INCREMENT, [role_id] VARCHAR(10) DEFAULT \'1\' NULL, PRIMARY KEY ([user_id]), FOREIGN KEY ([user_id]) REFERENCES [users] ([ext1_id]), FOREIGN KEY ([role_id]) REFERENCES [roles] ([ext2_id]));';
+ $sql = 'CREATE TABLE [user_roles] ([user_id] INTEGER PRIMARY KEY AUTOINCREMENT, [role_id] TEXT DEFAULT \'1\' NULL, PRIMARY KEY ([user_id]), FOREIGN KEY ([user_id]) REFERENCES [users] ([ext1_id]), FOREIGN KEY ([role_id]) REFERENCES [roles] ([ext2_id]));';
}
$sql = \strtr($sql, '[]', $iS . $iE);
diff --git a/tests/DataStorage/Database/Schema/Grammar/MysqlGrammarTest.php b/tests/DataStorage/Database/Schema/Grammar/MysqlGrammarTest.php
index dc43f93ef..bc1315f34 100755
--- a/tests/DataStorage/Database/Schema/Grammar/MysqlGrammarTest.php
+++ b/tests/DataStorage/Database/Schema/Grammar/MysqlGrammarTest.php
@@ -78,7 +78,7 @@ final class MysqlGrammarTest extends \PHPUnit\Framework\TestCase
);
}
- $delete = new Builder($this->con);
+ $delete = new Builder($this->con);
$delete->dropTable('test')
->dropTable('test_foreign')
->execute();
@@ -101,7 +101,7 @@ final class MysqlGrammarTest extends \PHPUnit\Framework\TestCase
self::assertContains('test', $tables);
self::assertContains('test_foreign', $tables);
- $delete = new Builder($this->con);
+ $delete = new Builder($this->con);
$delete->dropTable('test')
->dropTable('test_foreign')
->execute();
diff --git a/tests/DataStorage/Database/TestModel/BaseModel.php b/tests/DataStorage/Database/TestModel/BaseModel.php
index 24b892d34..7c6a6c117 100755
--- a/tests/DataStorage/Database/TestModel/BaseModel.php
+++ b/tests/DataStorage/Database/TestModel/BaseModel.php
@@ -22,6 +22,10 @@ class BaseModel
public string $string = 'Base';
+ public string $compress = 'Uncompressed';
+
+ private string $pstring = 'Private';
+
public string $conditional = '';
public int $int = 11;
@@ -40,10 +44,18 @@ class BaseModel
public array $hasManyRelations = [];
+ private array $hasManyDirectPrivate = [];
+
+ private array $hasManyRelationsPrivate = [];
+
public $ownsOneSelf = 0;
public $belongsToOne = 0;
+ private $ownsOneSelfPrivate = 0;
+
+ private $belongsToOnePrivate = 0;
+
public ?object $serializable = null;
public array $json = [1, 2, 3];
@@ -64,11 +76,21 @@ class BaseModel
new ManyToManyRelModel(),
];
+ $this->hasManyDirectPrivate = [
+ new ManyToManyDirectModel(),
+ new ManyToManyDirectModel(),
+ ];
+
+ $this->hasManyRelationsPrivate = [
+ new ManyToManyRelModel(),
+ new ManyToManyRelModel(),
+ ];
+
$this->ownsOneSelf = new OwnsOneModel();
$this->belongsToOne = new BelongsToModel();
$this->serializable = new class() implements SerializableInterface {
- public $value = '';
+ public $value = '';
public function serialize() : string
{
@@ -89,6 +111,11 @@ class BaseModel
};
}
+ public function getPString() : string
+ {
+ return $this->pstring;
+ }
+
public function getId() : int
{
return $this->id;
diff --git a/tests/DataStorage/Database/TestModel/BaseModelMapper.php b/tests/DataStorage/Database/TestModel/BaseModelMapper.php
index 37d2146fe..6809192b3 100755
--- a/tests/DataStorage/Database/TestModel/BaseModelMapper.php
+++ b/tests/DataStorage/Database/TestModel/BaseModelMapper.php
@@ -27,6 +27,8 @@ class BaseModelMapper extends DataMapperFactory
public const COLUMNS = [
'test_base_id' => ['name' => 'test_base_id', 'type' => 'int', 'internal' => 'id'],
'test_base_string' => ['name' => 'test_base_string', 'type' => 'string', 'internal' => 'string', 'autocomplete' => true],
+ 'test_base_compress' => ['name' => 'test_base_compress', 'type' => 'compress', 'internal' => 'compress',],
+ 'test_base_pstring' => ['name' => 'test_base_pstring', 'type' => 'pstring', 'internal' => 'pstring', 'private' => true],
'test_base_int' => ['name' => 'test_base_int', 'type' => 'int', 'internal' => 'int'],
'test_base_bool' => ['name' => 'test_base_bool', 'type' => 'bool', 'internal' => 'bool'],
'test_base_null' => ['name' => 'test_base_null', 'type' => 'int', 'internal' => 'null'],
@@ -38,6 +40,8 @@ class BaseModelMapper extends DataMapperFactory
'test_base_datetime_null' => ['name' => 'test_base_datetime_null', 'type' => 'DateTime', 'internal' => 'datetime_null'],
'test_base_owns_one_self' => ['name' => 'test_base_owns_one_self', 'type' => 'int', 'internal' => 'ownsOneSelf'],
'test_base_belongs_to_one' => ['name' => 'test_base_belongs_to_one', 'type' => 'int', 'internal' => 'belongsToOne'],
+ 'test_base_owns_onep_self' => ['name' => 'test_base_owns_onep_self', 'type' => 'int', 'internal' => 'ownsOneSelfPrivate', 'private' => true],
+ 'test_base_belongs_top_one' => ['name' => 'test_base_belongs_top_one', 'type' => 'int', 'internal' => 'belongsToOnePrivate', 'private' => true],
];
/**
@@ -50,6 +54,12 @@ class BaseModelMapper extends DataMapperFactory
'belongsToOne' => [
'mapper' => BelongsToModelMapper::class,
'external' => 'test_base_belongs_to_one',
+ 'private' => true,
+ ],
+ 'belongsToOnePrivate' => [
+ 'mapper' => BelongsToModelPrivateMapper::class,
+ 'external' => 'test_base_belongs_top_one',
+ 'private' => true,
],
];
@@ -58,6 +68,10 @@ class BaseModelMapper extends DataMapperFactory
'mapper' => OwnsOneModelMapper::class,
'external' => 'test_base_owns_one_self',
],
+ 'ownsOneSelfPrivate' => [
+ 'mapper' => OwnsOneModelPrivateMapper::class,
+ 'external' => 'test_base_owns_onep_self',
+ ],
];
/**
@@ -86,6 +100,20 @@ class BaseModelMapper extends DataMapperFactory
'column' => 'title',
'external' => null,
],
+ 'hasManyDirectPrivate' => [
+ 'mapper' => ManyToManyDirectModelPrivateMapper::class,
+ 'table' => 'test_has_many_directp',
+ 'self' => 'test_has_many_directp_to',
+ 'external' => null,
+ 'private' => true,
+ ],
+ 'hasManyRelationsPrivate' => [
+ 'mapper' => ManyToManyRelModelPrivateMapper::class,
+ 'table' => 'test_has_many_rel_relationsp',
+ 'external' => 'test_has_many_rel_relationsp_src',
+ 'self' => 'test_has_many_rel_relationsp_dest',
+ 'private' => true,
+ ],
];
/**
diff --git a/tests/DataStorage/Database/TestModel/BelongsToModelPrivateMapper.php b/tests/DataStorage/Database/TestModel/BelongsToModelPrivateMapper.php
new file mode 100644
index 000000000..4ed89646e
--- /dev/null
+++ b/tests/DataStorage/Database/TestModel/BelongsToModelPrivateMapper.php
@@ -0,0 +1,49 @@
+
+ * @since 1.0.0
+ */
+ public const COLUMNS = [
+ 'test_belongs_to_onep_id' => ['name' => 'test_belongs_to_onep_id', 'type' => 'int', 'internal' => 'id'],
+ 'test_belongs_to_onep_string' => ['name' => 'test_belongs_to_onep_string', 'type' => 'string', 'internal' => 'string'],
+ ];
+
+ /**
+ * Primary table.
+ *
+ * @var string
+ * @since 1.0.0
+ */
+ public const TABLE = 'test_belongs_to_onep';
+
+ /**
+ * Primary field name.
+ *
+ * @var string
+ * @since 1.0.0
+ */
+ public const PRIMARYFIELD = 'test_belongs_to_onep_id';
+
+ public const MODEL = BelongsToModel::class;
+}
diff --git a/tests/DataStorage/Database/TestModel/ManyToManyDirectModelPrivateMapper.php b/tests/DataStorage/Database/TestModel/ManyToManyDirectModelPrivateMapper.php
new file mode 100644
index 000000000..e1de0fd8a
--- /dev/null
+++ b/tests/DataStorage/Database/TestModel/ManyToManyDirectModelPrivateMapper.php
@@ -0,0 +1,50 @@
+
+ * @since 1.0.0
+ */
+ public const COLUMNS = [
+ 'test_has_many_directp_id' => ['name' => 'test_has_many_directp_id', 'type' => 'int', 'internal' => 'id'],
+ 'test_has_many_directp_string' => ['name' => 'test_has_many_directp_string', 'type' => 'string', 'internal' => 'string'],
+ 'test_has_many_directp_to' => ['name' => 'test_has_many_directp_to', 'type' => 'int', 'internal' => 'to'],
+ ];
+
+ /**
+ * Primary table.
+ *
+ * @var string
+ * @since 1.0.0
+ */
+ public const TABLE = 'test_has_many_directp';
+
+ /**
+ * Primary field name.
+ *
+ * @var string
+ * @since 1.0.0
+ */
+ public const PRIMARYFIELD = 'test_has_many_directp_id';
+
+ public const MODEL = ManyToManyDirectModel::class;
+}
diff --git a/tests/DataStorage/Database/TestModel/ManyToManyRelModelPrivateMapper.php b/tests/DataStorage/Database/TestModel/ManyToManyRelModelPrivateMapper.php
new file mode 100644
index 000000000..e7df8b66d
--- /dev/null
+++ b/tests/DataStorage/Database/TestModel/ManyToManyRelModelPrivateMapper.php
@@ -0,0 +1,49 @@
+
+ * @since 1.0.0
+ */
+ public const COLUMNS = [
+ 'test_has_many_relp_id' => ['name' => 'test_has_many_relp_id', 'type' => 'int', 'internal' => 'id'],
+ 'test_has_many_relp_string' => ['name' => 'test_has_many_relp_string', 'type' => 'string', 'internal' => 'string'],
+ ];
+
+ /**
+ * Primary table.
+ *
+ * @var string
+ * @since 1.0.0
+ */
+ public const TABLE = 'test_has_many_relp';
+
+ /**
+ * Primary field name.
+ *
+ * @var string
+ * @since 1.0.0
+ */
+ public const PRIMARYFIELD = 'test_has_many_relp_id';
+
+ public const MODEL = ManyToManyRelModel::class;
+}
diff --git a/tests/DataStorage/Database/TestModel/OwnsOneModelPrivateMapper.php b/tests/DataStorage/Database/TestModel/OwnsOneModelPrivateMapper.php
new file mode 100644
index 000000000..08511b3aa
--- /dev/null
+++ b/tests/DataStorage/Database/TestModel/OwnsOneModelPrivateMapper.php
@@ -0,0 +1,49 @@
+
+ * @since 1.0.0
+ */
+ public const COLUMNS = [
+ 'test_owns_onep_id' => ['name' => 'test_owns_onep_id', 'type' => 'int', 'internal' => 'id'],
+ 'test_owns_onep_string' => ['name' => 'test_owns_onep_string', 'type' => 'string', 'internal' => 'string'],
+ ];
+
+ /**
+ * Primary table.
+ *
+ * @var string
+ * @since 1.0.0
+ */
+ public const TABLE = 'test_owns_onep';
+
+ /**
+ * Primary field name.
+ *
+ * @var string
+ * @since 1.0.0
+ */
+ public const PRIMARYFIELD = 'test_owns_onep_id';
+
+ public const MODEL = OwnsOneModel::class;
+}
diff --git a/tests/Dispatcher/DispatcherTest.php b/tests/Dispatcher/DispatcherTest.php
index 9d9937d12..2af67ec07 100755
--- a/tests/Dispatcher/DispatcherTest.php
+++ b/tests/Dispatcher/DispatcherTest.php
@@ -39,7 +39,7 @@ final class DispatcherTest extends \PHPUnit\Framework\TestCase
*/
protected function setUp() : void
{
- $this->app = new class() extends ApplicationAbstract {
+ $this->app = new class() extends ApplicationAbstract {
protected string $appName = 'Api';
};
diff --git a/tests/Localization/Defaults/CityMapperTest.php b/tests/Localization/Defaults/CityMapperTest.php
index 647170efb..cf9cb420d 100755
--- a/tests/Localization/Defaults/CityMapperTest.php
+++ b/tests/Localization/Defaults/CityMapperTest.php
@@ -33,8 +33,8 @@ final class CityMapperTest extends \PHPUnit\Framework\TestCase
public static function setUpBeforeClass() : void
{
self::$con = new SqliteConnection([
- 'db' => 'sqlite',
- 'database' => \realpath(__DIR__ . '/../../../Localization/Defaults/localization.sqlite'),
+ 'db' => 'sqlite',
+ 'database' => \realpath(__DIR__ . '/../../../Localization/Defaults/localization.sqlite'),
]);
self::$con->connect();
diff --git a/tests/Localization/Defaults/CountryMapperTest.php b/tests/Localization/Defaults/CountryMapperTest.php
index 403bfdc65..9ea15f43f 100755
--- a/tests/Localization/Defaults/CountryMapperTest.php
+++ b/tests/Localization/Defaults/CountryMapperTest.php
@@ -33,8 +33,8 @@ final class CountryMapperTest extends \PHPUnit\Framework\TestCase
public static function setUpBeforeClass() : void
{
self::$con = new SqliteConnection([
- 'db' => 'sqlite',
- 'database' => \realpath(__DIR__ . '/../../../Localization/Defaults/localization.sqlite'),
+ 'db' => 'sqlite',
+ 'database' => \realpath(__DIR__ . '/../../../Localization/Defaults/localization.sqlite'),
]);
self::$con->connect();
diff --git a/tests/Localization/Defaults/CountryTest.php b/tests/Localization/Defaults/CountryTest.php
index 2d678bfb9..ee5c76381 100755
--- a/tests/Localization/Defaults/CountryTest.php
+++ b/tests/Localization/Defaults/CountryTest.php
@@ -33,7 +33,7 @@ final class CountryTest extends \PHPUnit\Framework\TestCase
public function testDefaults() : void
{
$obj = new Country();
- self::assertEquals(0, $obj->getId());
+ self::assertEquals(0, $obj->id);
self::assertEquals('', $obj->getName());
self::assertEquals('', $obj->getCode2());
self::assertEquals('', $obj->getCode3());
diff --git a/tests/Localization/Defaults/CurrencyMapperTest.php b/tests/Localization/Defaults/CurrencyMapperTest.php
index ce42e7c81..6c576276c 100755
--- a/tests/Localization/Defaults/CurrencyMapperTest.php
+++ b/tests/Localization/Defaults/CurrencyMapperTest.php
@@ -33,8 +33,8 @@ final class CurrencyMapperTest extends \PHPUnit\Framework\TestCase
public static function setUpBeforeClass() : void
{
self::$con = new SqliteConnection([
- 'db' => 'sqlite',
- 'database' => \realpath(__DIR__ . '/../../../Localization/Defaults/localization.sqlite'),
+ 'db' => 'sqlite',
+ 'database' => \realpath(__DIR__ . '/../../../Localization/Defaults/localization.sqlite'),
]);
self::$con->connect();
diff --git a/tests/Localization/Defaults/IbanMapperTest.php b/tests/Localization/Defaults/IbanMapperTest.php
index 477dcb63d..f4dcecd3b 100755
--- a/tests/Localization/Defaults/IbanMapperTest.php
+++ b/tests/Localization/Defaults/IbanMapperTest.php
@@ -33,8 +33,8 @@ final class IbanMapperTest extends \PHPUnit\Framework\TestCase
public static function setUpBeforeClass() : void
{
self::$con = new SqliteConnection([
- 'db' => 'sqlite',
- 'database' => \realpath(__DIR__ . '/../../../Localization/Defaults/localization.sqlite'),
+ 'db' => 'sqlite',
+ 'database' => \realpath(__DIR__ . '/../../../Localization/Defaults/localization.sqlite'),
]);
self::$con->connect();
@@ -51,7 +51,7 @@ final class IbanMapperTest extends \PHPUnit\Framework\TestCase
{
/** @var Iban $obj */
$obj = IbanMapper::get()->where('id', 22)->execute();
- self::assertEquals('DE', $obj->getCountry());
+ self::assertEquals('DE', $obj->country);
self::assertEquals(22, $obj->getChars());
self::assertEquals('18n', $obj->getBban());
self::assertEquals('DEkk bbbb bbbb cccc cccc cc', $obj->getFields());
diff --git a/tests/Localization/Defaults/IbanTest.php b/tests/Localization/Defaults/IbanTest.php
index 041247d79..bbf92365f 100755
--- a/tests/Localization/Defaults/IbanTest.php
+++ b/tests/Localization/Defaults/IbanTest.php
@@ -33,7 +33,7 @@ final class IbanTest extends \PHPUnit\Framework\TestCase
public function testDefaults() : void
{
$obj = new Iban();
- self::assertEquals('', $obj->getCountry());
+ self::assertEquals('', $obj->country);
self::assertEquals(2, $obj->getChars());
self::assertEquals('', $obj->getBban());
self::assertEquals('', $obj->getFields());
diff --git a/tests/Localization/Defaults/LanguageMapperTest.php b/tests/Localization/Defaults/LanguageMapperTest.php
index 0b9758858..fd96411f2 100755
--- a/tests/Localization/Defaults/LanguageMapperTest.php
+++ b/tests/Localization/Defaults/LanguageMapperTest.php
@@ -33,8 +33,8 @@ final class LanguageMapperTest extends \PHPUnit\Framework\TestCase
public static function setUpBeforeClass() : void
{
self::$con = new SqliteConnection([
- 'db' => 'sqlite',
- 'database' => \realpath(__DIR__ . '/../../../Localization/Defaults/localization.sqlite'),
+ 'db' => 'sqlite',
+ 'database' => \realpath(__DIR__ . '/../../../Localization/Defaults/localization.sqlite'),
]);
self::$con->connect();
diff --git a/tests/Localization/Defaults/LanguageTest.php b/tests/Localization/Defaults/LanguageTest.php
index 000d36ac4..bfafe2464 100755
--- a/tests/Localization/Defaults/LanguageTest.php
+++ b/tests/Localization/Defaults/LanguageTest.php
@@ -33,7 +33,7 @@ final class LanguageTest extends \PHPUnit\Framework\TestCase
public function testDefaults() : void
{
$obj = new Language();
- self::assertEquals(0, $obj->getId());
+ self::assertEquals(0, $obj->id);
self::assertEquals('', $obj->getName());
self::assertEquals('', $obj->getNative());
self::assertEquals('', $obj->getCode2());
diff --git a/tests/Localization/LocalizationTest.php b/tests/Localization/LocalizationTest.php
index 980f0e9a5..1e670bec7 100755
--- a/tests/Localization/LocalizationTest.php
+++ b/tests/Localization/LocalizationTest.php
@@ -48,11 +48,11 @@ final class LocalizationTest extends \PHPUnit\Framework\TestCase
*/
public function testDefault() : void
{
- self::assertEquals(0, $this->localization->getId());
+ self::assertEquals(0, $this->localization->id);
self::assertTrue(ISO3166TwoEnum::isValidValue($this->localization->country));
self::assertTrue(TimeZoneEnumArray::isValidValue($this->localization->getTimezone()));
self::assertTrue(ISO639x1Enum::isValidValue($this->localization->language));
- self::assertTrue(ISO4217CharEnum::isValidValue($this->localization->getCurrency()));
+ self::assertTrue(ISO4217CharEnum::isValidValue($this->localization->currency));
self::assertEquals('0', $this->localization->getCurrencyFormat());
self::assertEquals('.', $this->localization->getDecimal());
self::assertEquals(',', $this->localization->getThousands());
@@ -66,18 +66,6 @@ final class LocalizationTest extends \PHPUnit\Framework\TestCase
self::assertEquals([], $this->localization->getVolume());
}
- /**
- * @testdox Setting a invalid language code throws InvalidEnumValue
- * @covers phpOMS\Localization\Localization
- * @group framework
- */
- public function testInvalidLanguage() : void
- {
- $this->expectException(\phpOMS\Stdlib\Base\Exception\InvalidEnumValue::class);
-
- $this->localization->setLanguage('abc');
- }
-
/**
* @testdox Setting a invalid country code throws InvalidEnumValue
* @covers phpOMS\Localization\Localization
@@ -102,18 +90,6 @@ final class LocalizationTest extends \PHPUnit\Framework\TestCase
$this->localization->setTimezone('abc');
}
- /**
- * @testdox Setting a invalid currency code throws InvalidEnumValue
- * @covers phpOMS\Localization\Localization
- * @group framework
- */
- public function testInvalidCurrency() : void
- {
- $this->expectException(\phpOMS\Stdlib\Base\Exception\InvalidEnumValue::class);
-
- $this->localization->setCurrency('abc');
- }
-
/**
* @testdox Setting a invalid angle throws InvalidEnumValue
* @covers phpOMS\Localization\Localization
@@ -160,28 +136,6 @@ final class LocalizationTest extends \PHPUnit\Framework\TestCase
self::assertEquals(TimeZoneEnumArray::get(315), $this->localization->getTimezone());
}
- /**
- * @testdox The language can be set and returned
- * @covers phpOMS\Localization\Localization
- * @group framework
- */
- public function testLanguageInputOutput() : void
- {
- $this->localization->setLanguage(ISO639x1Enum::_DE);
- self::assertEquals(ISO639x1Enum::_DE, $this->localization->language);
- }
-
- /**
- * @testdox The currency can be set and returned
- * @covers phpOMS\Localization\Localization
- * @group framework
- */
- public function testCurrencyInputOutput() : void
- {
- $this->localization->setCurrency(ISO4217CharEnum::_EUR);
- self::assertEquals(ISO4217CharEnum::_EUR, $this->localization->getCurrency());
- }
-
/**
* @testdox The datetime can be set and returned
* @covers phpOMS\Localization\Localization
@@ -322,7 +276,7 @@ final class LocalizationTest extends \PHPUnit\Framework\TestCase
public function testLocalizationFromLanguageCode() : void
{
$l11n = Localization::fromLanguage(ISO639x1Enum::_DE);
- self::assertEquals(ISO4217CharEnum::_EUR, $l11n->getCurrency());
+ self::assertEquals(ISO4217CharEnum::_EUR, $l11n->currency);
}
/**
@@ -333,7 +287,7 @@ final class LocalizationTest extends \PHPUnit\Framework\TestCase
public function testLocalizationLoading() : void
{
$this->localization->loadFromLanguage(ISO639x1Enum::_DE);
- self::assertEquals(ISO4217CharEnum::_EUR, $this->localization->getCurrency());
+ self::assertEquals(ISO4217CharEnum::_EUR, $this->localization->currency);
}
/**
@@ -360,7 +314,7 @@ final class LocalizationTest extends \PHPUnit\Framework\TestCase
public function testInvalidCountryLocalizationLoading() : void
{
$this->localization->loadFromLanguage(ISO639x1Enum::_DE, 'ABC');
- self::assertEquals(ISO4217CharEnum::_EUR, $this->localization->getCurrency());
+ self::assertEquals(ISO4217CharEnum::_EUR, $this->localization->currency);
}
/**
@@ -371,6 +325,6 @@ final class LocalizationTest extends \PHPUnit\Framework\TestCase
public function testMissingLocalizationLoading() : void
{
$this->localization->loadFromLanguage(ISO639x1Enum::_AA);
- self::assertEquals(ISO4217CharEnum::_USD, $this->localization->getCurrency());
+ self::assertEquals(ISO4217CharEnum::_USD, $this->localization->currency);
}
}
diff --git a/tests/Math/Functions/AlgebraTest.php b/tests/Math/Functions/AlgebraTest.php
new file mode 100644
index 000000000..7455ea3fe
--- /dev/null
+++ b/tests/Math/Functions/AlgebraTest.php
@@ -0,0 +1,91 @@
+ 9, 'y' => 0]], GrahamScan::createConvexHull([['x' => 9, 'y' => 0]]));
+
+ $points = [];
+ for ($i = 0; $i < 10; ++$i) {
+ for ($j = 0; $j < 10; ++$j) {
+ $points[] = ['x' => $i, 'y' => $j];
+ }
+ }
+
+ self::assertEquals([
+ ['x' => 0, 'y' => 0],
+ ['x' => 9, 'y' => 0],
+ ['x' => 9, 'y' => 9],
+ ['x' => 0, 'y' => 9],
+ ],
+ GrahamScan::createConvexHull($points)
+ );
+ }
+}
diff --git a/tests/Math/Matrix/MatrixTest.php b/tests/Math/Matrix/MatrixTest.php
index f418c5790..276867ec5 100755
--- a/tests/Math/Matrix/MatrixTest.php
+++ b/tests/Math/Matrix/MatrixTest.php
@@ -69,7 +69,7 @@ final class MatrixTest extends \PHPUnit\Framework\TestCase
*/
public function testMultMatrix() : void
{
- self::assertEquals([[0, -5], [-6, -7]], $this->C->getMatrix());
+ self::assertEquals([[0, -5], [-6, -7]], $this->C->toArray());
}
/**
@@ -79,7 +79,7 @@ final class MatrixTest extends \PHPUnit\Framework\TestCase
*/
public function testMultMatrixScalar() : void
{
- self::assertEquals([[0, -10], [-12, -14]], $this->C->mult(2)->getMatrix());
+ self::assertEquals([[0, -10], [-12, -14]], $this->C->mult(2)->toArray());
}
/**
@@ -291,7 +291,7 @@ final class MatrixTest extends \PHPUnit\Framework\TestCase
*/
public function testUpperTriangular() : void
{
- self::assertEquals([[-6, -7], [0, -5]], $this->C->upperTriangular()->getMatrix());
+ self::assertEquals([[-6, -7], [0, -5]], $this->C->upperTriangular()->toArray());
}
/**
@@ -301,8 +301,8 @@ final class MatrixTest extends \PHPUnit\Framework\TestCase
public function testLowerTriangular() : void
{
self::markTestIncomplete();
- //self::assertEquals([], $this->C->lowerTriangular()->getMatrix());
- //self::assertEquals([], $this->C->diagonalize()->getMatrix());
+ //self::assertEquals([], $this->C->lowerTriangular()->toArray());
+ //self::assertEquals([], $this->C->diagonalize()->toArray());
}
/**
@@ -492,4 +492,134 @@ final class MatrixTest extends \PHPUnit\Framework\TestCase
$A->mult($B);
}
+
+ public function testSumAll() : void
+ {
+ $m = Matrix::fromArray([
+ [1, 2, 3],
+ [4, 5, 6],
+ [7, 8, 9],
+ ]);
+
+ self::assertEquals(
+ 45,
+ $m->sum(-1)
+ );
+ }
+
+ public function testSumColumns() : void
+ {
+ $m = Matrix::fromArray([
+ [1, 2, 3],
+ [4, 5, 6],
+ [7, 8, 9],
+ ]);
+
+ self::assertEquals(
+ [12, 15, 18],
+ $m->sum(0)->toVectorArray()
+ );
+ }
+
+ public function testSumRows() : void
+ {
+ $m = Matrix::fromArray([
+ [1, 2, 3],
+ [4, 5, 6],
+ [7, 8, 9],
+ ]);
+
+ self::assertEquals(
+ [6, 15, 24],
+ $m->sum(1)->toVectorArray()
+ );
+ }
+
+ public function testDiaglonal() : void
+ {
+ $m = Matrix::fromArray([
+ [1, 2, 3],
+ [4, 5, 6],
+ [7, 8, 9],
+ ]);
+
+ self::assertFalse($m->isDiagonal());
+
+ $m = Matrix::fromArray([
+ [1, 0, 0],
+ [0, 5, 0],
+ [0, 0, -8],
+ ]);
+
+ self::assertTrue($m->isDiagonal());
+ }
+
+ public function testPow() : void
+ {
+ $m = Matrix::fromArray([
+ [1, 2, 3],
+ [4, 5, 6],
+ [7, 8, 9],
+ ]);
+
+ self::assertEquals(
+ [
+ [30, 36, 42],
+ [66, 81, 96],
+ [102, 126, 150],
+ ],
+ $m->pow(2)->toArray()
+ );
+
+ $m = Matrix::fromArray([
+ [1.5, 2.5, 3.5],
+ [4.5, 5.5, 6.5],
+ [7.5, 8.5, 9.5],
+ ]);
+
+ self::assertEqualsWithDelta(
+ [
+ [39.75, 47.25, 54.75],
+ [80.25, 96.75, 113.25],
+ [120.75, 146.25, 171.75],
+ ],
+ $m->pow(2)->toArray(),
+ 0.1
+ );
+
+ $m = Matrix::fromArray([
+ [1, 1, 1],
+ [1, 2, 3],
+ [1, 3, 6],
+ ]);
+
+ self::assertEqualsWithDelta(
+ [
+ [0.8901, 0.5882, 0.3684],
+ [0.5882, 1.2035, 1.3799],
+ [0.3684, 1.3799, 3.1167],
+ ],
+ $m->pow(2 / 3)->toArray(),
+ 0.01
+ );
+ }
+
+ public function testExp() : void
+ {
+ $m = Matrix::fromArray([
+ [1, 2, 3],
+ [4, 5, 6],
+ [7, 8, 9],
+ ]);
+
+ self::assertEqualsWithDelta(
+ [
+ [1118906.6994131860386, 1374815.062935806540981, 1630724.426458427043361],
+ [2533881.041898971697907, 3113415.03138055427637, 3692947.020862136854833],
+ [3948856.384384757357213, 4852012.999825302011759, 5755170.615265846666304],
+ ],
+ $m->exp(12)->toArray(),
+ 0.1
+ );
+ }
}
diff --git a/tests/Math/Matrix/VectorTest.php b/tests/Math/Matrix/VectorTest.php
index afc52c23c..70200aa89 100755
--- a/tests/Math/Matrix/VectorTest.php
+++ b/tests/Math/Matrix/VectorTest.php
@@ -65,4 +65,20 @@ final class VectorTest extends \PHPUnit\Framework\TestCase
self::assertEquals(5, $vec->getM());
}
+
+ public function testCosine() : void
+ {
+ $v1 = Vector::fromArray([3, 4, 0]);
+ $v2 = Vector::fromArray([4, 4, 2]);
+
+ self::assertEqualsWithDelta(14 / 15, $v1->cosine($v2), 0.1);
+ }
+
+ public function testCross3() : void
+ {
+ self::assertEquals(
+ [-15, -2, 39],
+ Vector::fromArray([3, -3, 1])->cross3(Vector::fromArray([4, 9, 2]))->toVectorArray()
+ );
+ }
}
diff --git a/tests/Math/Optimization/SimplexTest.php b/tests/Math/Optimization/SimplexTest.php
new file mode 100644
index 000000000..ca9c1be16
--- /dev/null
+++ b/tests/Math/Optimization/SimplexTest.php
@@ -0,0 +1,108 @@
+solve(
+ [
+ [-1, 1],
+ [1, 1],
+ [1, -4],
+ ],
+ [8, -3, 2],
+ [1, 3]
+ ),
+ 0.01
+ );
+ }
+
+ public function testSimplexBasicFeasible() : void
+ {
+ $simplex = new Simplex();
+ self::assertEqualsWithDelta(
+ [
+ [1.0, 0.0, 0.0, 0.0],
+ 5.0,
+ ],
+ $simplex->solve(
+ [
+ [-1, 1],
+ [-2, -1],
+ ],
+ [1, 2],
+ [5, -3]
+ ),
+ 0.0
+ );
+ }
+
+ public function testSimplexLPInfeasible() : void
+ {
+ $simplex = new Simplex();
+ self::assertEquals(
+ [
+ [-2, -2, -2, -2, -2],
+ \INF,
+ ],
+ $simplex->solve(
+ [
+ [-1, -1],
+ [2, 2],
+ ],
+ [2, -10],
+ [3, -2]
+ )
+ );
+ }
+
+ public function testSimplexLPUnbound() : void
+ {
+ $simplex = new Simplex();
+ self::assertEqualsWithDelta(
+ [
+ [-1, -1, -1, -1],
+ \INF,
+ ],
+ $simplex->solve(
+ [
+ [2, -1],
+ [1, 2],
+ ],
+ [-1, -2],
+ [1, -1]
+ ),
+ 0.01
+ );
+ }
+}
diff --git a/tests/Math/Solver/Root/BisectionTest.php b/tests/Math/Solver/Root/BisectionTest.php
new file mode 100644
index 000000000..830452251
--- /dev/null
+++ b/tests/Math/Solver/Root/BisectionTest.php
@@ -0,0 +1,34 @@
+ 3, 'y' => 4, 'z' => 0], ['x' => 4, 'y' => 4, 'z' => 2]),
+ 0.1
+ );
+ }
+
/**
* @testdox The bray-curtis distance can be calculated
* @covers phpOMS\Math\Topology\MetricsND
@@ -193,6 +207,18 @@ final class MetricsNDTest extends \PHPUnit\Framework\TestCase
MetricsND::canberra([3, 6, 4], [4, 6, 8, 3]);
}
+ /**
+ * @testdox Different dimension sizes for the coordinates in the cosine metric throw a InvalidDimensionException
+ * @covers phpOMS\Math\Topology\MetricsND
+ * @group framework
+ */
+ public function testInvalidCosineDimension() : void
+ {
+ $this->expectException(\phpOMS\Math\Matrix\Exception\InvalidDimensionException::class);
+
+ MetricsND::cosine([3, 6, 4], [4, 6, 8, 3]);
+ }
+
/**
* @testdox Different dimension sizes for the coordinates in the Bray Curtis metric throw a InvalidDimensionException
* @covers phpOMS\Math\Topology\MetricsND
diff --git a/tests/Message/HeaderAbstractTest.php b/tests/Message/HeaderAbstractTest.php
index f2f3c9ea3..c303e4100 100755
--- a/tests/Message/HeaderAbstractTest.php
+++ b/tests/Message/HeaderAbstractTest.php
@@ -48,7 +48,7 @@ final class HeaderAbstractTest extends \PHPUnit\Framework\TestCase
return true;
}
- public function get(string $key = null) : array
+ public function get(?string $key = null) : array
{
return [];
}
diff --git a/tests/Message/Http/HttpRequestTest.php b/tests/Message/Http/HttpRequestTest.php
index f62d2f485..b90fb5d4b 100755
--- a/tests/Message/Http/HttpRequestTest.php
+++ b/tests/Message/Http/HttpRequestTest.php
@@ -14,7 +14,6 @@ declare(strict_types=1);
namespace phpOMS\tests\Message\Http;
-use phpOMS\Localization\ISO639x1Enum;
use phpOMS\Localization\Localization;
use phpOMS\Message\Http\BrowserType;
use phpOMS\Message\Http\HttpRequest;
@@ -150,21 +149,6 @@ final class HttpRequestTest extends \PHPUnit\Framework\TestCase
self::assertEquals('http://www.google.com/test/path', $request->__toString());
}
- /**
- * @testdox The request langauge can be returned
- * @covers phpOMS\Message\Http\HttpRequest
- * @group framework
- */
- public function testLangaugeOutput() : void
- {
- $request = new HttpRequest(new HttpUri('http://www.google.com/test/path'), $l11n = new Localization());
-
- $request->header->l11n = new Localization();
- $request->header->l11n->setLanguage(ISO639x1Enum::_DE);
-
- self::assertEquals(ISO639x1Enum::_DE, $request->header->l11n->language);
- }
-
/**
* @testdox The url hashes for the different paths get correctly generated
* @covers phpOMS\Message\Http\HttpRequest
@@ -231,7 +215,7 @@ final class HttpRequestTest extends \PHPUnit\Framework\TestCase
*/
public function testDataJsonRead() : void
{
- $request = new HttpRequest(new HttpUri(''));
+ $request = new HttpRequest();
$data = [
1, 2, 3,
@@ -250,7 +234,7 @@ final class HttpRequestTest extends \PHPUnit\Framework\TestCase
*/
public function testEmptyDataJsonRead() : void
{
- $request = new HttpRequest(new HttpUri(''));
+ $request = new HttpRequest();
self::assertEquals([], $request->getDataJson('def'));
}
@@ -262,7 +246,7 @@ final class HttpRequestTest extends \PHPUnit\Framework\TestCase
*/
public function testInvalidDataJsonRead() : void
{
- $request = new HttpRequest(new HttpUri(''));
+ $request = new HttpRequest();
$data = [
"0" => 1, "1" => 2, "2" => 3,
@@ -281,7 +265,7 @@ final class HttpRequestTest extends \PHPUnit\Framework\TestCase
*/
public function testDataList() : void
{
- $request = new HttpRequest(new HttpUri(''));
+ $request = new HttpRequest();
$data = [
1, 2, 3,
@@ -299,7 +283,7 @@ final class HttpRequestTest extends \PHPUnit\Framework\TestCase
*/
public function testEmptyDataList() : void
{
- $request = new HttpRequest(new HttpUri(''));
+ $request = new HttpRequest();
self::assertEquals([], $request->getDataList('def'));
}
@@ -311,7 +295,7 @@ final class HttpRequestTest extends \PHPUnit\Framework\TestCase
*/
public function testDataLike() : void
{
- $request = new HttpRequest(new HttpUri(''));
+ $request = new HttpRequest();
$data = 'this is a test';
@@ -327,7 +311,7 @@ final class HttpRequestTest extends \PHPUnit\Framework\TestCase
*/
public function testInvalidDataLikeMatch() : void
{
- $request = new HttpRequest(new HttpUri(''));
+ $request = new HttpRequest();
$data = 'this is a test';
diff --git a/tests/Message/Http/HttpResponseTest.php b/tests/Message/Http/HttpResponseTest.php
index 571c327ad..0352ccf50 100755
--- a/tests/Message/Http/HttpResponseTest.php
+++ b/tests/Message/Http/HttpResponseTest.php
@@ -14,8 +14,6 @@ declare(strict_types=1);
namespace phpOMS\tests\Message\Http;
-use phpOMS\Localization\ISO639x1Enum;
-use phpOMS\Localization\Localization;
use phpOMS\Message\Http\HttpResponse;
use phpOMS\System\MimeType;
@@ -105,19 +103,6 @@ final class HttpResponseTest extends \PHPUnit\Framework\TestCase
self::assertEquals($start, \ob_get_level());
}
- /**
- * @testdox The response langauge can be returned
- * @covers phpOMS\Message\Http\HttpResponse
- * @group framework
- */
- public function testLangaugeOutput() : void
- {
- $this->response->header->l11n = new Localization();
- $this->response->header->l11n->setLanguage(ISO639x1Enum::_DE);
-
- self::assertEquals(ISO639x1Enum::_DE, $this->response->header->l11n->language);
- }
-
/**
* @testdox Response data can be turned into an array
* @covers phpOMS\Message\Http\HttpResponse
diff --git a/tests/Message/Mail/MailHandlerMailTrait.php b/tests/Message/Mail/MailHandlerMailTrait.php
index 81b554660..d49c729c3 100755
--- a/tests/Message/Mail/MailHandlerMailTrait.php
+++ b/tests/Message/Mail/MailHandlerMailTrait.php
@@ -308,10 +308,10 @@ trait MailHandlerMailTrait
$mail->confirmationAddress = 'test1@jingga.app';
$mail->setFrom('test1@jingga.app', 'Dennis Eichhorn');
$mail->addTo('test@jingga.app', 'Dennis Eichhorn');
- $mail->subject = 'testSendICalAltWithMail';
- $mail->body = 'Ical test';
- $mail->bodyAlt = 'Ical test';
- $mail->ical = 'BEGIN:VCALENDAR'
+ $mail->subject = 'testSendICalAltWithMail';
+ $mail->body = 'Ical test';
+ $mail->bodyAlt = 'Ical test';
+ $mail->ical = 'BEGIN:VCALENDAR'
. "\r\nVERSION:2.0"
. "\r\nPRODID:-//phpOMS//Karaka Calendar//EN"
. $methodLine
@@ -366,10 +366,10 @@ trait MailHandlerMailTrait
$mail->setFrom('test1@jingga.app', 'Dennis Eichhorn');
$mail->addTo('test@jingga.app', 'Dennis Eichhorn');
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
- $mail->subject = 'testSendICalAltAttachmentWithMail';
- $mail->body = 'Ical test';
- $mail->bodyAlt = 'Ical test';
- $mail->ical = 'BEGIN:VCALENDAR'
+ $mail->subject = 'testSendICalAltAttachmentWithMail';
+ $mail->body = 'Ical test';
+ $mail->bodyAlt = 'Ical test';
+ $mail->ical = 'BEGIN:VCALENDAR'
. "\r\nVERSION:2.0"
. "\r\nPRODID:-//phpOMS//Karaka Calendar//EN"
. $methodLine
diff --git a/tests/Message/Mail/MailHandlerSendmailTrait.php b/tests/Message/Mail/MailHandlerSendmailTrait.php
index 9e07c1481..737e33bdf 100755
--- a/tests/Message/Mail/MailHandlerSendmailTrait.php
+++ b/tests/Message/Mail/MailHandlerSendmailTrait.php
@@ -282,10 +282,10 @@ trait MailHandlerSendmailTrait
$mail->confirmationAddress = 'test1@jingga.app';
$mail->setFrom('test1@jingga.app', 'Dennis Eichhorn');
$mail->addTo('test@jingga.app', 'Dennis Eichhorn');
- $mail->subject = 'testSendICalAltWithSendmail';
- $mail->body = 'Ical test';
- $mail->bodyAlt = 'Ical test';
- $mail->ical = 'BEGIN:VCALENDAR'
+ $mail->subject = 'testSendICalAltWithSendmail';
+ $mail->body = 'Ical test';
+ $mail->bodyAlt = 'Ical test';
+ $mail->ical = 'BEGIN:VCALENDAR'
. "\r\nVERSION:2.0"
. "\r\nPRODID:-//phpOMS//Karaka Calendar//EN"
. $methodLine
@@ -338,10 +338,10 @@ trait MailHandlerSendmailTrait
$mail->setFrom('test1@jingga.app', 'Dennis Eichhorn');
$mail->addTo('test@jingga.app', 'Dennis Eichhorn');
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
- $mail->subject = 'testSendICalAltAttachmentWithSendmail';
- $mail->body = 'Ical test';
- $mail->bodyAlt = 'Ical test';
- $mail->ical = 'BEGIN:VCALENDAR'
+ $mail->subject = 'testSendICalAltAttachmentWithSendmail';
+ $mail->body = 'Ical test';
+ $mail->bodyAlt = 'Ical test';
+ $mail->ical = 'BEGIN:VCALENDAR'
. "\r\nVERSION:2.0"
. "\r\nPRODID:-//phpOMS//Karaka Calendar//EN"
. $methodLine
diff --git a/tests/Message/Mail/MailHandlerSmtpTrait.php b/tests/Message/Mail/MailHandlerSmtpTrait.php
index e14d2cff2..5a3e516c4 100755
--- a/tests/Message/Mail/MailHandlerSmtpTrait.php
+++ b/tests/Message/Mail/MailHandlerSmtpTrait.php
@@ -391,10 +391,10 @@ trait MailHandlerSmtpTrait
$mail->confirmationAddress = 'test1@jingga.app';
$mail->setFrom('test1@jingga.app', 'Dennis Eichhorn');
$mail->addTo('test@jingga.app', 'Dennis Eichhorn');
- $mail->subject = 'testSendICalAltWithSmtp';
- $mail->body = 'Ical test';
- $mail->bodyAlt = 'Ical test';
- $mail->ical = 'BEGIN:VCALENDAR'
+ $mail->subject = 'testSendICalAltWithSmtp';
+ $mail->body = 'Ical test';
+ $mail->bodyAlt = 'Ical test';
+ $mail->ical = 'BEGIN:VCALENDAR'
. "\r\nVERSION:2.0"
. "\r\nPRODID:-//phpOMS//Karaka Calendar//EN"
. $methodLine
@@ -456,10 +456,10 @@ trait MailHandlerSmtpTrait
$mail->setFrom('test1@jingga.app', 'Dennis Eichhorn');
$mail->addTo('test@jingga.app', 'Dennis Eichhorn');
$mail->addAttachment(__DIR__ . '/files/logo.png', 'logo');
- $mail->subject = 'testSendICalAltAttachmentWithSmtp';
- $mail->body = 'Ical test';
- $mail->bodyAlt = 'Ical test';
- $mail->ical = 'BEGIN:VCALENDAR'
+ $mail->subject = 'testSendICalAltAttachmentWithSmtp';
+ $mail->body = 'Ical test';
+ $mail->bodyAlt = 'Ical test';
+ $mail->ical = 'BEGIN:VCALENDAR'
. "\r\nVERSION:2.0"
. "\r\nPRODID:-//phpOMS//Karaka Calendar//EN"
. $methodLine
diff --git a/tests/Message/Mail/MailHandlerTest.php b/tests/Message/Mail/MailHandlerTest.php
index 0e5f40a7d..540ea0c68 100755
--- a/tests/Message/Mail/MailHandlerTest.php
+++ b/tests/Message/Mail/MailHandlerTest.php
@@ -42,9 +42,9 @@ final class MailHandlerTest extends \PHPUnit\Framework\TestCase
'countryName' => 'DE',
'stateOrProvinceName' => 'Hesse',
'localityName' => 'Frankfurt',
- 'organizationName' => 'Karaka',
+ 'organizationName' => 'Jingga',
'organizationalUnitName' => 'Framework',
- 'commonName' => 'Karaka Test',
+ 'commonName' => 'Jingga Test',
'emailAddress' => 'test@jingga.app',
];
$keyconfig = [
diff --git a/tests/Message/RequestAbstractTest.php b/tests/Message/RequestAbstractTest.php
index 7c6fd82fa..79c996aa7 100755
--- a/tests/Message/RequestAbstractTest.php
+++ b/tests/Message/RequestAbstractTest.php
@@ -96,4 +96,77 @@ final class RequestAbstractTest extends \PHPUnit\Framework\TestCase
$this->request->setData('key5', 1);
self::assertEquals(1, $this->request->getData('key5', 'invalid'));
}
+
+ public function testDataAllInputOutput() : void
+ {
+ $this->request->setData('asdf', false);
+ self::assertEquals(['asdf' => false], $this->request->getData());
+ }
+
+ /**
+ * @group framework
+ */
+ public function testDataJsonInputOutput() : void
+ {
+ $this->request->setData('asdf', '[1,2,3]');
+ self::assertEquals([1,2,3], $this->request->getDataJson('asdf'));
+ }
+
+ /**
+ * @group framework
+ */
+ public function testDataStringInputOutput() : void
+ {
+ $this->request->setData('asdf', 1);
+ self::assertEquals('1', $this->request->getDataString('asdf'));
+ self::assertEquals('1', $this->request->getData('asdf', 'string'));
+ }
+
+ /**
+ * @group framework
+ */
+ public function testDataBoolInputOutput() : void
+ {
+ $this->request->setData('asdf', 1);
+ self::assertTrue($this->request->getDataBool('asdf'));
+ self::assertTrue($this->request->getData('asdf', 'bool'));
+ }
+
+ /**
+ * @group framework
+ */
+ public function testDataFloatInputOutput() : void
+ {
+ $this->request->setData('asdf', 1);
+ self::assertEquals(1.0, $this->request->getDataFloat('asdf'));
+ self::assertEquals(1.0, $this->request->getData('asdf', 'float'));
+ }
+
+ /**
+ * @group framework
+ */
+ public function testDataDateTimeInputOutput() : void
+ {
+ $this->request->setData('asdf', '2023-01-01');
+ self::assertEquals((new \DateTime('2023-01-01'))->format('Y-m-d'), $this->request->getDataDateTime('asdf')->format('Y-m-d'));
+ self::assertEquals((new \DateTime('2023-01-01'))->format('Y-m-d'), $this->request->getData('asdf', 'DateTime')->format('Y-m-d'));
+ }
+
+ public function testDataInvalidTypeInputOutput() : void
+ {
+ $this->request->setData('asdf', 1);
+ self::assertEquals(1, $this->request->getData('asdf', 'invalid'));
+ }
+
+ /**
+ * @group framework
+ */
+ public function testInvalidDataTypeInputOutput() : void
+ {
+ self::assertNull($this->request->getDataString('a'));
+ self::assertNull($this->request->getDataBool('a'));
+ self::assertNull($this->request->getDataInt('a'));
+ self::assertNull($this->request->getDataFloat('a'));
+ self::assertNull($this->request->getDataDateTime('a'));
+ }
}
diff --git a/tests/Message/ResponseAbstractTest.php b/tests/Message/ResponseAbstractTest.php
index f4df8aab2..87530523b 100755
--- a/tests/Message/ResponseAbstractTest.php
+++ b/tests/Message/ResponseAbstractTest.php
@@ -67,6 +67,12 @@ final class ResponseAbstractTest extends \PHPUnit\Framework\TestCase
self::assertEquals([1], $this->response->jsonSerialize());
}
+ public function testDataAllInputOutput() : void
+ {
+ $this->response->set('asdf', false);
+ self::assertEquals(['asdf' => false], $this->response->getData());
+ }
+
/**
* @testdox Data can be set and returned for the response
* @covers phpOMS\Message\ResponseAbstract
@@ -77,4 +83,81 @@ final class ResponseAbstractTest extends \PHPUnit\Framework\TestCase
$this->response->set('asdf', false);
self::assertFalse($this->response->getData('asdf'));
}
+
+ /**
+ * @testdox Data can be set and returned for the response
+ * @covers phpOMS\Message\ResponseAbstract
+ * @group framework
+ */
+ public function testDataStringInputOutput() : void
+ {
+ $this->response->set('asdf', 1);
+ self::assertEquals('1', $this->response->getDataString('asdf'));
+ self::assertEquals('1', $this->response->getData('asdf', 'string'));
+ }
+
+ /**
+ * @testdox Data can be set and returned for the response
+ * @covers phpOMS\Message\ResponseAbstract
+ * @group framework
+ */
+ public function testDataBoolInputOutput() : void
+ {
+ $this->response->set('asdf', 1);
+ self::assertTrue($this->response->getDataBool('asdf'));
+ self::assertTrue($this->response->getData('asdf', 'bool'));
+ }
+
+ /**
+ * @testdox Data can be set and returned for the response
+ * @covers phpOMS\Message\ResponseAbstract
+ * @group framework
+ */
+ public function testDataFloatInputOutput() : void
+ {
+ $this->response->set('asdf', 1);
+ self::assertEquals(1.0, $this->response->getDataFloat('asdf'));
+ self::assertEquals(1.0, $this->response->getData('asdf', 'float'));
+ }
+
+ /**
+ * @group framework
+ */
+ public function testDataJsonInputOutput() : void
+ {
+ $this->response->set('asdf', '[1,2,3]');
+ self::assertEquals([1,2,3], $this->response->getDataJson('asdf'));
+ }
+
+ /**
+ * @testdox Data can be set and returned for the response
+ * @covers phpOMS\Message\ResponseAbstract
+ * @group framework
+ */
+ public function testDataDateTimeInputOutput() : void
+ {
+ $this->response->set('asdf', '2023-01-01');
+ self::assertEquals((new \DateTime('2023-01-01'))->format('Y-m-d'), $this->response->getDataDateTime('asdf')->format('Y-m-d'));
+ self::assertEquals((new \DateTime('2023-01-01'))->format('Y-m-d'), $this->response->getData('asdf', 'DateTime')->format('Y-m-d'));
+ }
+
+ public function testDataInvalidTypeInputOutput() : void
+ {
+ $this->response->set('asdf', 1);
+ self::assertEquals(1, $this->response->getData('asdf', 'invalid'));
+ }
+
+ /**
+ * @testdox Data can be set and returned for the response
+ * @covers phpOMS\Message\ResponseAbstract
+ * @group framework
+ */
+ public function testInvalidDataTypeInputOutput() : void
+ {
+ self::assertNull($this->response->getDataString('a'));
+ self::assertNull($this->response->getDataBool('a'));
+ self::assertNull($this->response->getDataInt('a'));
+ self::assertNull($this->response->getDataFloat('a'));
+ self::assertNull($this->response->getDataDateTime('a'));
+ }
}
diff --git a/tests/Model/Html/HeadTest.php b/tests/Model/Html/HeadTest.php
index 1639c91b1..4aea21376 100755
--- a/tests/Model/Html/HeadTest.php
+++ b/tests/Model/Html/HeadTest.php
@@ -43,7 +43,7 @@ final class HeadTest extends \PHPUnit\Framework\TestCase
{
self::assertInstanceOf('\phpOMS\Model\Html\Meta', $this->head->meta);
self::assertEquals('', $this->head->title);
- self::assertEquals('en', $this->head->getLanguage());
+ self::assertEquals('en', $this->head->language);
self::assertEquals([], $this->head->getStyleAll());
self::assertEquals([], $this->head->getScriptAll());
self::assertEquals('', $this->head->renderStyle());
@@ -86,17 +86,6 @@ final class HeadTest extends \PHPUnit\Framework\TestCase
self::assertEquals(['key' => 'console.log("msg");'], $this->head->getScriptAll());
}
- /**
- * @testdox The language can be set and returned
- * @covers phpOMS\Model\Html\Head
- * @group framework
- */
- public function testLanguageInputOutput() : void
- {
- $this->head->setLanguage('en');
- self::assertEquals('en', $this->head->getLanguage());
- }
-
/**
* @testdox The assets can be set and rendered
* @covers phpOMS\Model\Html\Head
diff --git a/tests/Model/Message/NotifyTest.php b/tests/Model/Message/NotifyTest.php
index b6335f910..40a17e6ab 100755
--- a/tests/Model/Message/NotifyTest.php
+++ b/tests/Model/Message/NotifyTest.php
@@ -48,7 +48,7 @@ final class NotifyTest extends \PHPUnit\Framework\TestCase
$obj->delay = 3;
$obj->stay = 5;
$obj->level = NotificationLevel::ERROR;
- $obj->message ='msg';
+ $obj->message = 'msg';
$obj->title = 'title';
self::assertEquals([
diff --git a/tests/Module/InstallerAbstractTest.php b/tests/Module/InstallerAbstractTest.php
index d66f88ab9..d3e1c4e02 100755
--- a/tests/Module/InstallerAbstractTest.php
+++ b/tests/Module/InstallerAbstractTest.php
@@ -61,12 +61,12 @@ final class InstallerAbstractTest extends \PHPUnit\Framework\TestCase
public function get(
mixed $ids = null,
- string | array $names = null,
- int $unit = null,
- int $app = null,
- string $module = null,
- int $group = null,
- int $account = null
+ string | array|null $names = null,
+ ?int $unit = null,
+ ?int $app = null,
+ ?string $module = null,
+ ?int $group = null,
+ ?int $account = null
) : mixed
{
return null;
diff --git a/tests/Module/ModuleAbstractTest.php b/tests/Module/ModuleAbstractTest.php
index c586e79bd..063e11a4d 100755
--- a/tests/Module/ModuleAbstractTest.php
+++ b/tests/Module/ModuleAbstractTest.php
@@ -26,7 +26,6 @@ use phpOMS\tests\DataStorage\Database\TestModel\BaseModel;
use phpOMS\tests\DataStorage\Database\TestModel\BaseModelMapper;
use phpOMS\tests\DataStorage\Database\TestModel\ManyToManyRelModel;
use phpOMS\tests\DataStorage\Database\TestModel\ManyToManyRelModelMapper;
-use phpOMS\Uri\HttpUri;
/**
* @testdox phpOMS\tests\Module\ModuleAbstractTest: Abstract module
@@ -102,7 +101,7 @@ final class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
$model1 = BaseModelMapper::get()->where('id', 1)->execute();
$model2 = ManyToManyRelModelMapper::get()->where('id', 1)->execute();
- $this->createModelRelation(1, $model1->getId(), $model2->id, BaseModelMapper::class, 'hasManyRelations', '', '127.0.0.1');
+ $this->createModelRelation(1, $model1->id, $model2->id, BaseModelMapper::class, 'hasManyRelations', '', '127.0.0.1');
}
public function deleteRelationDB() : void
@@ -110,7 +109,7 @@ final class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
$model1 = BaseModelMapper::get()->where('id', 1)->execute();
$model2 = ManyToManyRelModelMapper::get()->where('id', 1)->execute();
- $this->deleteModelRelation(1, $model1->getId(), $model2->id, BaseModelMapper::class, 'hasManyRelations', '', '127.0.0.1');
+ $this->deleteModelRelation(1, $model1->id, $model2->id, BaseModelMapper::class, 'hasManyRelations', '', '127.0.0.1');
}
public function creates() : void
@@ -246,7 +245,7 @@ final class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
*/
public function testFillJson() : void
{
- $request = new HttpRequest(new HttpUri(''));
+ $request = new HttpRequest();
$response = new HttpResponse();
$this->module->fillJson($request, $response, 'OK', 'Test Title', 'Test Message!', [1, 'test string', 'bool' => true]);
@@ -269,7 +268,7 @@ final class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
*/
public function testFillJsonRaw() : void
{
- $request = new HttpRequest(new HttpUri(''));
+ $request = new HttpRequest();
$response = new HttpResponse();
$this->module->fillJsonRaw($request, $response, [1, 'test string', 'bool' => true]);
@@ -285,21 +284,27 @@ final class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
*/
private function dbSetup() : void
{
+ \phpOMS\Log\FileLogger::getInstance()->verbose = true;
+
$GLOBALS['dbpool']->get()->con->prepare(
'CREATE TABLE `test_base` (
`test_base_id` int(11) NOT NULL AUTO_INCREMENT,
`test_base_string` varchar(254) NOT NULL,
+ `test_base_compress` BLOB NOT NULL,
+ `test_base_pstring` varchar(254) NOT NULL,
`test_base_int` int(11) NOT NULL,
`test_base_bool` tinyint(1) DEFAULT NULL,
`test_base_null` int(11) DEFAULT NULL,
`test_base_float` decimal(5, 4) DEFAULT NULL,
`test_base_belongs_to_one` int(11) DEFAULT NULL,
+ `test_base_belongs_top_one` int(11) DEFAULT NULL,
`test_base_owns_one_self` int(11) DEFAULT NULL,
+ `test_base_owns_onep_self` int(11) DEFAULT NULL,
`test_base_json` varchar(254) DEFAULT NULL,
`test_base_json_serializable` varchar(254) DEFAULT NULL,
`test_base_serializable` varchar(254) DEFAULT NULL,
`test_base_datetime` datetime DEFAULT NULL,
- `test_base_datetime_null` datetime DEFAULT NULL, /* There was a bug where it returned the current date because new \DateTime(null) === current date which is wrong, we want null as value! */
+ `test_base_datetime_null` datetime DEFAULT NULL,
PRIMARY KEY (`test_base_id`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
)->execute();
@@ -355,6 +360,49 @@ final class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
PRIMARY KEY (`test_has_many_rel_relations_id`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
)->execute();
+
+ // private
+ $GLOBALS['dbpool']->get()->con->prepare(
+ 'CREATE TABLE `test_has_many_directp` (
+ `test_has_many_directp_id` int(11) NOT NULL AUTO_INCREMENT,
+ `test_has_many_directp_string` varchar(254) NOT NULL,
+ `test_has_many_directp_to` int(11) NOT NULL,
+ PRIMARY KEY (`test_has_many_directp_id`)
+ )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
+ )->execute();
+
+ $GLOBALS['dbpool']->get()->con->prepare(
+ 'CREATE TABLE `test_has_many_relp` (
+ `test_has_many_relp_id` int(11) NOT NULL AUTO_INCREMENT,
+ `test_has_many_relp_string` varchar(254) NOT NULL,
+ PRIMARY KEY (`test_has_many_relp_id`)
+ )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
+ )->execute();
+
+ $GLOBALS['dbpool']->get()->con->prepare(
+ 'CREATE TABLE `test_has_many_rel_relationsp` (
+ `test_has_many_rel_relationsp_id` int(11) NOT NULL AUTO_INCREMENT,
+ `test_has_many_rel_relationsp_src` int(11) NOT NULL,
+ `test_has_many_rel_relationsp_dest` int(11) NOT NULL,
+ PRIMARY KEY (`test_has_many_rel_relationsp_id`)
+ )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
+ )->execute();
+
+ $GLOBALS['dbpool']->get()->con->prepare(
+ 'CREATE TABLE `test_belongs_to_onep` (
+ `test_belongs_to_onep_id` int(11) NOT NULL AUTO_INCREMENT,
+ `test_belongs_to_onep_string` varchar(254) NOT NULL,
+ PRIMARY KEY (`test_belongs_to_onep_id`)
+ )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
+ )->execute();
+
+ $GLOBALS['dbpool']->get()->con->prepare(
+ 'CREATE TABLE `test_owns_onep` (
+ `test_owns_onep_id` int(11) NOT NULL AUTO_INCREMENT,
+ `test_owns_onep_string` varchar(254) NOT NULL,
+ PRIMARY KEY (`test_owns_onep_id`)
+ )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 AUTO_INCREMENT=1;'
+ )->execute();
}
/**
@@ -369,6 +417,14 @@ final class ModuleAbstractTest extends \PHPUnit\Framework\TestCase
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_direct')->execute();
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_rel')->execute();
$GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_rel_relations')->execute();
+
+ $GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_directp')->execute();
+ $GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_relp')->execute();
+ $GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_has_many_rel_relationsp')->execute();
+ $GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_belongs_to_onep')->execute();
+ $GLOBALS['dbpool']->get()->con->prepare('DROP TABLE test_owns_onep')->execute();
+
+ \phpOMS\Log\FileLogger::getInstance()->verbose = false;
}
/**
diff --git a/tests/Module/ModuleInfoTest.php b/tests/Module/ModuleInfoTest.php
index 23964bfe3..0b749a749 100755
--- a/tests/Module/ModuleInfoTest.php
+++ b/tests/Module/ModuleInfoTest.php
@@ -112,7 +112,7 @@ final class ModuleInfoTest extends \PHPUnit\Framework\TestCase
$info = new ModuleInfo(__DIR__ . '/info-test.json');
$info->load();
- $testObj = new class() {
+ $testObj = new class() {
public $test = 1;
public function test() : void
diff --git a/tests/Module/ModuleManagerTest.php b/tests/Module/ModuleManagerTest.php
index 60adacf9c..79776bf28 100755
--- a/tests/Module/ModuleManagerTest.php
+++ b/tests/Module/ModuleManagerTest.php
@@ -45,7 +45,7 @@ final class ModuleManagerTest extends \PHPUnit\Framework\TestCase
*/
protected function setUp() : void
{
- $this->app = new class() extends ApplicationAbstract {
+ $this->app = new class() extends ApplicationAbstract {
protected string $appName = 'Api';
};
@@ -153,7 +153,7 @@ final class ModuleManagerTest extends \PHPUnit\Framework\TestCase
self::assertTrue($this->moduleManager->activate('TestModule'));
// this is normally done in the ApiController
- $module->setStatus(ModuleStatus::ACTIVE);
+ $module->status = ModuleStatus::ACTIVE;
ModuleMapper::update()->execute($module);
$queryLoad = new Builder($this->app->dbPool->get('insert'));
diff --git a/tests/Module/info-test.json b/tests/Module/info-test.json
index daf851593..92998de85 100755
--- a/tests/Module/info-test.json
+++ b/tests/Module/info-test.json
@@ -14,7 +14,6 @@
"name": "Jingga",
"website": "jingga.app"
},
- "description": "The administration module.",
"directory": "Admin",
"dependencies": [],
"providing": {
diff --git a/tests/Router/SocketRouterTest.php b/tests/Router/SocketRouterTest.php
index 72d7ebcdb..6d29465b9 100755
--- a/tests/Router/SocketRouterTest.php
+++ b/tests/Router/SocketRouterTest.php
@@ -108,7 +108,7 @@ final class SocketRouterTest extends \PHPUnit\Framework\TestCase
*/
public function testDynamicRouteAdding() : void
{
- $this->router->add('^.*backends_admin -settings=general.*$', 'Controller:test');
+ $this->router->add('^.*backends_admin -settings=general(\?.*$|$)', 'Controller:test');
self::assertEquals(
[['dest' => 'Controller:test']],
$this->router->route('backends_admin -settings=general -t 123')
@@ -219,7 +219,7 @@ final class SocketRouterTest extends \PHPUnit\Framework\TestCase
public function testDataValidation() : void
{
$this->router->add(
- '^.*backends_admin -settings=general.*$',
+ '^.*backends_admin -settings=general(\?.*$|$)',
'Controller:test',
validation: ['test_pattern' => '/^[a-z]*$/']
);
@@ -238,7 +238,7 @@ final class SocketRouterTest extends \PHPUnit\Framework\TestCase
public function testInvalidDataValidation() : void
{
$this->router->add(
- '^.*backends_admin -settings=general.*$',
+ '^.*backends_admin -settings=general(\?.*$|$)',
'Controller:test',
validation: ['test_pattern' => '/^[a-z]*$/']
);
@@ -257,7 +257,7 @@ final class SocketRouterTest extends \PHPUnit\Framework\TestCase
public function testDataFromPattern() : void
{
$this->router->add(
- '^.*-settings=general.*$',
+ '^.*-settings=general(\?.*$|$)',
'Controller:test',
dataPattern: '/^.*?(settings)=([a-z]*).*?$/'
);
diff --git a/tests/Router/WebRouterTest.php b/tests/Router/WebRouterTest.php
index ebe3ac000..041d1bd03 100755
--- a/tests/Router/WebRouterTest.php
+++ b/tests/Router/WebRouterTest.php
@@ -53,7 +53,7 @@ final class WebRouterTest extends \PHPUnit\Framework\TestCase
{
self::assertEmpty(
$this->router->route(
- (new HttpRequest(new HttpUri('')))->uri->getRoute()
+ (new HttpRequest())->uri->getRoute()
)
);
}
@@ -142,7 +142,7 @@ final class WebRouterTest extends \PHPUnit\Framework\TestCase
*/
public function testDynamicRouteAdding() : void
{
- $this->router->add('^.*/backends/admin/settings/general.*$', 'Controller:test', RouteVerb::GET | RouteVerb::SET);
+ $this->router->add('^.*/backends/admin/settings/general(\?.*$|$)', 'Controller:test', RouteVerb::GET | RouteVerb::SET);
self::assertEquals(
[['dest' => 'Controller:test']],
$this->router->route(
@@ -318,7 +318,7 @@ final class WebRouterTest extends \PHPUnit\Framework\TestCase
public function testDataValidation() : void
{
$this->router->add(
- '^.*/backends/admin/settings/general.*$',
+ '^.*/backends/admin/settings/general(\?.*$|$)',
'Controller:test',
RouteVerb::GET | RouteVerb::SET,
false,
@@ -335,14 +335,14 @@ final class WebRouterTest extends \PHPUnit\Framework\TestCase
}
/**
- * @testdox A data validation pattern invalidates missmatches
+ * @testdox A data validation pattern invalidates miss-matches
* @covers phpOMS\Router\WebRouter
* @group framework
*/
public function testInvalidDataValidation() : void
{
$this->router->add(
- '^.*/backends/admin/settings/general.*$',
+ '^.*/backends/admin/settings/general(\?.*$|$)',
'Controller:test',
RouteVerb::GET | RouteVerb::SET,
false,
@@ -366,7 +366,7 @@ final class WebRouterTest extends \PHPUnit\Framework\TestCase
public function testDataFromPattern() : void
{
$this->router->add(
- '^.*/backends/admin.*$',
+ '^.*/backends/admin(\?.*$|$)',
'Controller:test',
RouteVerb::GET | RouteVerb::SET,
false,
diff --git a/tests/Router/socketRouterTestFile.php b/tests/Router/socketRouterTestFile.php
index 9fb5e48d0..3a4b22f4e 100755
--- a/tests/Router/socketRouterTestFile.php
+++ b/tests/Router/socketRouterTestFile.php
@@ -1,7 +1,7 @@
[
+ '^.*backend_admin -settings=general(\?.*$|$)' => [
0 => [
'dest' => '\Modules\Admin\Controller:viewSettingsGeneral',
],
diff --git a/tests/Router/socketRouterTestFilePermission.php b/tests/Router/socketRouterTestFilePermission.php
index 359f24003..6e33a2e90 100755
--- a/tests/Router/socketRouterTestFilePermission.php
+++ b/tests/Router/socketRouterTestFilePermission.php
@@ -4,13 +4,13 @@ declare(strict_types=1);
use phpOMS\Account\PermissionType;
return [
- '^.*backend_admin -settings=general.*$' => [
+ '^.*backend_admin -settings=general(\?.*$|$)' => [
0 => [
'dest' => '\Modules\Admin\Controller:viewSettingsGeneral',
'permission' => [
- 'module' => 'TEST',
- 'type' => PermissionType::READ,
- 'category' => 1,
+ 'module' => 'TEST',
+ 'type' => PermissionType::READ,
+ 'category' => 1,
],
],
],
diff --git a/tests/Router/webRouteTestCsrf.php b/tests/Router/webRouteTestCsrf.php
index 693807819..43edd600e 100755
--- a/tests/Router/webRouteTestCsrf.php
+++ b/tests/Router/webRouteTestCsrf.php
@@ -1,7 +1,7 @@
[
+ '^.*/backend/admin/settings/csrf(\?.*$|$)' => [
0 => [
'dest' => '\Modules\Admin\Controller:viewCsrf',
'verb' => 1,
diff --git a/tests/Router/webRouterTestFile.php b/tests/Router/webRouterTestFile.php
index a6945522a..7f4fb925c 100755
--- a/tests/Router/webRouterTestFile.php
+++ b/tests/Router/webRouterTestFile.php
@@ -1,7 +1,7 @@
[
+ '^.*/backend/admin/settings/general(\?.*$|$)' => [
0 => [
'dest' => '\Modules\Admin\Controller:viewSettingsGeneral',
'verb' => 1,
diff --git a/tests/Router/webRouterTestFilePermission.php b/tests/Router/webRouterTestFilePermission.php
index b44c375c5..5441e72bf 100755
--- a/tests/Router/webRouterTestFilePermission.php
+++ b/tests/Router/webRouterTestFilePermission.php
@@ -5,14 +5,14 @@ use phpOMS\Account\PermissionType;
use phpOMS\Router\RouteVerb;
return [
- '^.*/backend/admin/settings/general.*$' => [
+ '^.*/backend/admin/settings/general(\?.*$|$)' => [
0 => [
'dest' => '\Modules\Admin\Controller:viewSettingsGeneral',
'verb' => RouteVerb::GET,
'permission' => [
- 'module' => 'TEST',
- 'type' => PermissionType::READ,
- 'category' => 1,
+ 'module' => 'TEST',
+ 'type' => PermissionType::READ,
+ 'category' => 1,
],
],
],
diff --git a/tests/Security/EncryptionHelperTest.php b/tests/Security/EncryptionHelperTest.php
index c3c82bc05..017dbb862 100644
--- a/tests/Security/EncryptionHelperTest.php
+++ b/tests/Security/EncryptionHelperTest.php
@@ -49,8 +49,8 @@ final class EncryptionHelperTest extends \PHPUnit\Framework\TestCase
public function testFileEncryption() : void
{
- if (\is_file(__DIR__ . '/encrytped.txt')) {
- \unlink(__DIR__ . '/encrytped.txt');
+ if (\is_file(__DIR__ . '/encrypted.txt')) {
+ \unlink(__DIR__ . '/encrypted.txt');
}
if (\is_file(__DIR__ . '/decrypted.txt')) {
@@ -58,22 +58,22 @@ final class EncryptionHelperTest extends \PHPUnit\Framework\TestCase
}
$key = EncryptionHelper::createSharedKey();
- self::assertTrue(EncryptionHelper::encryptFile(__DIR__ . '/plain.txt', __DIR__ . '/encrytped.txt', $key));
+ self::assertTrue(EncryptionHelper::encryptFile(__DIR__ . '/plain.txt', __DIR__ . '/encrypted.txt', $key));
self::assertNotEquals(
\file_get_contents(__DIR__ . '/plain.txt'),
- \file_get_contents(__DIR__ . '/encrytped.txt')
+ \file_get_contents(__DIR__ . '/encrypted.txt')
);
- self::assertTrue(EncryptionHelper::decryptFile(__DIR__ . '/encrytped.txt', __DIR__ . '/decrypted.txt', $key));
+ self::assertTrue(EncryptionHelper::decryptFile(__DIR__ . '/encrypted.txt', __DIR__ . '/decrypted.txt', $key));
self::assertEquals(
\file_get_contents(__DIR__ . '/plain.txt'),
\file_get_contents(__DIR__ . '/decrypted.txt')
);
- if (\is_file(__DIR__ . '/encrytped.txt')) {
- \unlink(__DIR__ . '/encrytped.txt');
+ if (\is_file(__DIR__ . '/encrypted.txt')) {
+ \unlink(__DIR__ . '/encrypted.txt');
}
if (\is_file(__DIR__ . '/decrypted.txt')) {
diff --git a/tests/Security/GuardTest.php b/tests/Security/GuardTest.php
index 89b80078f..8bac47439 100644
--- a/tests/Security/GuardTest.php
+++ b/tests/Security/GuardTest.php
@@ -56,4 +56,16 @@ final class GuardTest extends \PHPUnit\Framework\TestCase
)
);
}
+
+ /**
+ * @testdox A string can be validated for shell safety
+ * @covers phpOMS\Security\Guard
+ * @group framework
+ */
+ public function testIsShellSafe() : void
+ {
+ self::assertTrue(Guard::isShellSafe('asdf'));
+ self::assertFalse(Guard::isShellSafe('`|*?~<>^()[]{}$\\'));
+ self::assertFalse(Guard::isShellSafe('™'));
+ }
}
diff --git a/tests/Socket/Client/ClientTest.php b/tests/Socket/Client/ClientTest.php
index 719c3cfc1..c850dee93 100755
--- a/tests/Socket/Client/ClientTest.php
+++ b/tests/Socket/Client/ClientTest.php
@@ -59,18 +59,18 @@ final class ClientTest extends \PHPUnit\Framework\TestCase
protected string $appName = 'Socket';
};
- $this->app->logger = new FileLogger(__DIR__ . '/client.log', false);
- $this->app->dbPool = $GLOBALS['dbpool'];
- $this->app->unitId = 1;
- $this->app->cachePool = new CachePool($this->app->dbPool);
- $this->app->accountManager = new AccountManager($GLOBALS['session']);
- $this->app->appSettings = new CoreSettings();
- $this->app->moduleManager = new ModuleManager($this->app, __DIR__ . '/../../../../Modules/');
- $this->app->dispatcher = new Dispatcher($this->app);
- $this->app->eventManager = new EventManager($this->app->dispatcher);
+ $this->app->logger = new FileLogger(__DIR__ . '/client.log', false);
+ $this->app->dbPool = $GLOBALS['dbpool'];
+ $this->app->unitId = 1;
+ $this->app->cachePool = new CachePool($this->app->dbPool);
+ $this->app->accountManager = new AccountManager($GLOBALS['session']);
+ $this->app->appSettings = new CoreSettings();
+ $this->app->moduleManager = new ModuleManager($this->app, __DIR__ . '/../../../../Modules/');
+ $this->app->dispatcher = new Dispatcher($this->app);
+ $this->app->eventManager = new EventManager($this->app->dispatcher);
$this->app->eventManager->importFromFile(__DIR__ . '/../../../Socket/Hooks.php');
- $this->app->l11nManager = new L11nManager();
- $this->app->router = new SocketRouter();
+ $this->app->l11nManager = new L11nManager();
+ $this->app->router = new SocketRouter();
}
protected function tearDown() : void
diff --git a/tests/Socket/Client/ClientTestHelper.php b/tests/Socket/Client/ClientTestHelper.php
index 84700ab90..1728af467 100755
--- a/tests/Socket/Client/ClientTestHelper.php
+++ b/tests/Socket/Client/ClientTestHelper.php
@@ -49,18 +49,18 @@ $app = new class() extends ApplicationAbstract
protected string $appName = 'Socket';
};
-$app->logger = FileLogger::getInstance(__DIR__ . '/server.log', true);
-$app->dbPool = $GLOBALS['dbpool'];
-$app->unitId = 1;
-$app->cachePool = new CachePool($app->dbPool);
-$app->accountManager = new AccountManager($GLOBALS['session']);
-$app->appSettings = new CoreSettings($app->dbPool->get());
-$app->moduleManager = new ModuleManager($app, __DIR__ . '/../../../../Modules/');
-$app->dispatcher = new Dispatcher($app);
-$app->eventManager = new EventManager($app->dispatcher);
+$app->logger = FileLogger::getInstance(__DIR__ . '/server.log', true);
+$app->dbPool = $GLOBALS['dbpool'];
+$app->unitId = 1;
+$app->cachePool = new CachePool($app->dbPool);
+$app->accountManager = new AccountManager($GLOBALS['session']);
+$app->appSettings = new CoreSettings($app->dbPool->get());
+$app->moduleManager = new ModuleManager($app, __DIR__ . '/../../../../Modules/');
+$app->dispatcher = new Dispatcher($app);
+$app->eventManager = new EventManager($app->dispatcher);
$app->eventManager->importFromFile(__DIR__ . '/../../../Socket/Hooks.php');
-$app->l11nManager = new L11nManager();
-$app->router = new SocketRouter();
+$app->l11nManager = new L11nManager();
+$app->router = new SocketRouter();
$socket = new Server($app);
$socket->create('127.0.0.1', $config['socket']['master']['port']);
diff --git a/tests/Socket/Server/ServerTest.php b/tests/Socket/Server/ServerTest.php
index 247415a4e..a44349699 100755
--- a/tests/Socket/Server/ServerTest.php
+++ b/tests/Socket/Server/ServerTest.php
@@ -59,18 +59,18 @@ final class ServerTest extends \PHPUnit\Framework\TestCase
protected string $appName = 'Socket';
};
- $this->app->logger = new FileLogger(__DIR__ . '/server.log', false);
- $this->app->dbPool = $GLOBALS['dbpool'];
- $this->app->unitId = 1;
- $this->app->cachePool = new CachePool($this->app->dbPool);
- $this->app->accountManager = new AccountManager($GLOBALS['session']);
- $this->app->appSettings = new CoreSettings();
- $this->app->moduleManager = new ModuleManager($this->app, __DIR__ . '/../../../../Modules/');
- $this->app->dispatcher = new Dispatcher($this->app);
- $this->app->eventManager = new EventManager($this->app->dispatcher);
+ $this->app->logger = new FileLogger(__DIR__ . '/server.log', false);
+ $this->app->dbPool = $GLOBALS['dbpool'];
+ $this->app->unitId = 1;
+ $this->app->cachePool = new CachePool($this->app->dbPool);
+ $this->app->accountManager = new AccountManager($GLOBALS['session']);
+ $this->app->appSettings = new CoreSettings();
+ $this->app->moduleManager = new ModuleManager($this->app, __DIR__ . '/../../../../Modules/');
+ $this->app->dispatcher = new Dispatcher($this->app);
+ $this->app->eventManager = new EventManager($this->app->dispatcher);
$this->app->eventManager->importFromFile(__DIR__ . '/../../../Socket/Hooks.php');
- $this->app->l11nManager = new L11nManager();
- $this->app->router = new SocketRouter();
+ $this->app->l11nManager = new L11nManager();
+ $this->app->router = new SocketRouter();
}
protected function tearDown() : void
diff --git a/tests/Stdlib/Base/AddressTypeTest.php b/tests/Stdlib/Base/AddressTypeTest.php
index f1e89e61e..931513cf3 100755
--- a/tests/Stdlib/Base/AddressTypeTest.php
+++ b/tests/Stdlib/Base/AddressTypeTest.php
@@ -27,7 +27,7 @@ final class AddressTypeTest extends \PHPUnit\Framework\TestCase
*/
public function testEnumCount() : void
{
- self::assertCount(8, AddressType::getconstants());
+ self::assertCount(8, AddressType::getConstants());
}
/**
@@ -50,7 +50,6 @@ final class AddressTypeTest extends \PHPUnit\Framework\TestCase
self::assertEquals(3, AddressType::SHIPPING);
self::assertEquals(4, AddressType::BILLING);
self::assertEquals(5, AddressType::WORK);
- self::assertEquals(6, AddressType::CONTRACT);
self::assertEquals(7, AddressType::OTHER);
self::assertEquals(8, AddressType::EDUCATION);
}
diff --git a/tests/Stdlib/Base/LocationTest.php b/tests/Stdlib/Base/LocationTest.php
index 08bd21eb1..d5e4dd2f3 100755
--- a/tests/Stdlib/Base/LocationTest.php
+++ b/tests/Stdlib/Base/LocationTest.php
@@ -53,11 +53,11 @@ final class LocationTest extends \PHPUnit\Framework\TestCase
self::assertEquals('', $this->location->postal);
self::assertEquals('', $this->location->city);
- self::assertEquals('XX', $this->location->getCountry());
+ self::assertEquals('XX', $this->location->country);
self::assertEquals('', $this->location->address);
self::assertEquals('', $this->location->state);
- self::assertEquals(0, $this->location->getId());
- self::assertEquals(AddressType::HOME, $this->location->getType());
+ self::assertEquals(0, $this->location->id);
+ self::assertEquals(AddressType::HOME, $this->location->type);
self::assertEquals($expected, $this->location->toArray());
self::assertEquals($expected, $this->location->jsonSerialize());
}
@@ -73,17 +73,6 @@ final class LocationTest extends \PHPUnit\Framework\TestCase
self::assertEquals('0123456789', $this->location->postal);
}
- /**
- * @testdox The type can be set and returned
- * @covers phpOMS\Stdlib\Base\Location
- * @group framework
- */
- public function testTypeInputOutput() : void
- {
- $this->location->setType(AddressType::BUSINESS);
- self::assertEquals(AddressType::BUSINESS, $this->location->getType());
- }
-
/**
* @testdox The city can be set and returned
* @covers phpOMS\Stdlib\Base\Location
@@ -103,7 +92,7 @@ final class LocationTest extends \PHPUnit\Framework\TestCase
public function testCountryInputOutput() : void
{
$this->location->setCountry('Country');
- self::assertEquals('Country', $this->location->getCountry());
+ self::assertEquals('Country', $this->location->country);
}
/**
@@ -145,8 +134,8 @@ final class LocationTest extends \PHPUnit\Framework\TestCase
'lon' => 11.2,
];
- $this->location->postal = '0123456789';
- $this->location->setType(AddressType::BUSINESS);
+ $this->location->postal = '0123456789';
+ $this->location->type = AddressType::BUSINESS;
$this->location->city = 'city';
$this->location->address = 'Some address here';
$this->location->state = 'This is a state 123';
@@ -174,8 +163,8 @@ final class LocationTest extends \PHPUnit\Framework\TestCase
'lon' => 11.2,
];
- $this->location->postal = '0123456789';
- $this->location->setType(AddressType::BUSINESS);
+ $this->location->postal = '0123456789';
+ $this->location->type = AddressType::BUSINESS;
$this->location->city = 'city';
$this->location->address = 'Some address here';
$this->location->state = 'This is a state 123';
diff --git a/tests/Stdlib/Graph/NodeTest.php b/tests/Stdlib/Graph/NodeTest.php
index 953f19610..a399d7706 100755
--- a/tests/Stdlib/Graph/NodeTest.php
+++ b/tests/Stdlib/Graph/NodeTest.php
@@ -143,7 +143,8 @@ final class NodeTest extends \PHPUnit\Framework\TestCase
* @covers phpOMS\Stdlib\Graph\Node
* @group framework
*
- * @todo: is there bug where directed graphs return invalid neighbors?
+ * @bug Directed graphs may return invalid neighbors
+ * https://github.com/Karaka-Management/phpOMS/issues/366
*/
public function testNeighborsInputOutput() : void
{
diff --git a/tests/Stdlib/Tree/BinarySearchTreeTest.php b/tests/Stdlib/Tree/BinarySearchTreeTest.php
new file mode 100644
index 000000000..73276be49
--- /dev/null
+++ b/tests/Stdlib/Tree/BinarySearchTreeTest.php
@@ -0,0 +1,149 @@
+insert(new Node('D', 'D'));
+ $bst->insert(new Node('I', 'I'));
+ $bst->insert(new Node('N', 'N'));
+ $bst->insert(new Node('O', 'O'));
+ $bst->insert(new Node('S', 'S'));
+ $bst->insert(new Node('A', 'A'));
+ $bst->insert(new Node('U', 'U'));
+ $bst->insert(new Node('R', 'R'));
+
+ self::assertEquals(
+ [
+ 'key' => 'D',
+ 0 => [
+ 'key' => 'A',
+ 0 => null,
+ 1 => null,
+ ],
+ 1 => [
+ 'key' => 'I',
+ 0 => null,
+ 1 => [
+ 'key' => 'N',
+ 0 => null,
+ 1 => [
+ 'key' => 'O',
+ 0 => null,
+ 1 => [
+ 'key' => 'S',
+ 0 => [
+ 'key' => 'R',
+ 0 => null,
+ 1 => null,
+ ],
+ 1 => [
+ 'key' => 'U',
+ 0 => null,
+ 1 => null,
+ ],
+ ],
+ ],
+ ],
+ ],
+ ],
+ $bst->toArray()
+ );
+ }
+
+ public function testSearch() : void
+ {
+ $bst = new BinarySearchTree();
+ $bst->insert(new Node('D', 'D'));
+ $bst->insert(new Node('I', 'I'));
+ $bst->insert(new Node('N', 'N'));
+ $bst->insert(new Node('O', 'O'));
+ $bst->insert(new Node('S', 'S'));
+ $bst->insert(new Node('A', 'A'));
+ $bst->insert(new Node('U', 'U'));
+ $bst->insert(new Node('R', 'R'));
+
+ self::assertEquals('S', $bst->search('S')->key);
+ self::assertEquals('U', $bst->search('U')->key);
+ self::assertEquals('R', $bst->search('R')->key);
+ }
+
+ public function testDelete() : void
+ {
+ $bst = new BinarySearchTree();
+ $bst->insert(new Node('D', 'D'));
+ $bst->insert(new Node('I', 'I'));
+ $bst->insert(new Node('N', 'N'));
+ $bst->insert(new Node('O', 'O'));
+ $bst->insert(new Node('S', 'S'));
+ $bst->insert(new Node('A', 'A'));
+ $bst->insert(new Node('U', 'U'));
+ $bst->insert(new Node('R', 'R'));
+ $bst->delete($bst->search('I'));
+ $bst->insert(new Node('Z', 'Z'));
+ $bst->delete($bst->search('S'));
+ $bst->insert(new Node('T', 'T'));
+
+ self::assertEquals(
+ [
+ 'key' => 'D',
+ 0 => [
+ 'key' => 'A',
+ 0 => null,
+ 1 => null,
+ ],
+ 1 => [
+ 'key' => 'N',
+ 0 => null,
+ 1 => [
+ 'key' => 'O',
+ 0 => null,
+ 1 => [
+ 'key' => 'U',
+ 0 => [
+ 'key' => 'R',
+ 0 => null,
+ 1 => [
+ 'key' => 'T',
+ 0 => null,
+ 1 => null,
+ ],
+ ],
+ 1 => [
+ 'key' => 'Z',
+ 0 => null,
+ 1 => null,
+ ],
+ ],
+ ],
+ ],
+ ],
+ $bst->toArray()
+ );
+ }
+}
diff --git a/tests/System/File/Local/FileTest.php b/tests/System/File/Local/FileTest.php
index b7b2fd361..47a0b6c23 100755
--- a/tests/System/File/Local/FileTest.php
+++ b/tests/System/File/Local/FileTest.php
@@ -562,7 +562,7 @@ final class FileTest extends \PHPUnit\Framework\TestCase
\unlink($testFile);
}
- $newPath = __DIR__ . '/test2.txt';
+ $newPath = __DIR__ . '/test2.txt';
if (\is_file($newPath)) {
\unlink($newPath);
}
diff --git a/tests/System/SystemUtilsTest.php b/tests/System/SystemUtilsTest.php
index c9edcaf14..61750bee2 100755
--- a/tests/System/SystemUtilsTest.php
+++ b/tests/System/SystemUtilsTest.php
@@ -52,4 +52,9 @@ final class SystemUtilsTest extends \PHPUnit\Framework\TestCase
{
self::assertGreaterThan(0, SystemUtils::getCpuUsage());
}
+
+ public function testHostname() : void
+ {
+ self::assertGreaterThan(0, \strlen(SystemUtils::getHostname()));
+ }
}
diff --git a/tests/Utils/Converter/EnergyPowerTypeTest.php b/tests/Utils/Converter/EnergyPowerTypeTest.php
index 708e36149..e8b3106e0 100755
--- a/tests/Utils/Converter/EnergyPowerTypeTest.php
+++ b/tests/Utils/Converter/EnergyPowerTypeTest.php
@@ -45,13 +45,13 @@ final class EnergyPowerTypeTest extends \PHPUnit\Framework\TestCase
*/
public function testEnums() : void
{
- self::assertEquals('kWh', EnergyPowerType::KILOWATT_HOUERS);
- self::assertEquals('MWh', EnergyPowerType::MEGAWATT_HOUERS);
+ self::assertEquals('kWh', EnergyPowerType::KILOWATT_HOURS);
+ self::assertEquals('MWh', EnergyPowerType::MEGAWATT_HOURS);
self::assertEquals('kt', EnergyPowerType::KILOTONS);
- self::assertEquals('J', EnergyPowerType::JOULS);
+ self::assertEquals('J', EnergyPowerType::JOULES);
self::assertEquals('Cal', EnergyPowerType::CALORIES);
self::assertEquals('BTU', EnergyPowerType::BTU);
- self::assertEquals('kJ', EnergyPowerType::KILOJOULS);
+ self::assertEquals('kJ', EnergyPowerType::KILOJOULES);
self::assertEquals('thmEC', EnergyPowerType::THERMEC);
self::assertEquals('Nm', EnergyPowerType::NEWTON_METERS);
}
diff --git a/tests/Utils/Converter/MeasurementTest.php b/tests/Utils/Converter/MeasurementTest.php
index 9523eca04..5b49243cf 100755
--- a/tests/Utils/Converter/MeasurementTest.php
+++ b/tests/Utils/Converter/MeasurementTest.php
@@ -245,7 +245,7 @@ final class MeasurementTest extends \PHPUnit\Framework\TestCase
}
/**
- * @testdox Filesizes can be converted
+ * @testdox File sizes can be converted
* @covers phpOMS\Utils\Converter\Measurement
* @group framework
*/
@@ -490,7 +490,7 @@ final class MeasurementTest extends \PHPUnit\Framework\TestCase
{
$this->expectException(\InvalidArgumentException::class);
- Measurement::convertEnergy(1.1, 'invalid', EnergyPowerType::JOULS);
+ Measurement::convertEnergy(1.1, 'invalid', EnergyPowerType::JOULES);
}
/**
@@ -502,7 +502,7 @@ final class MeasurementTest extends \PHPUnit\Framework\TestCase
{
$this->expectException(\InvalidArgumentException::class);
- Measurement::convertEnergy(1.1, EnergyPowerType::JOULS, 'invalid');
+ Measurement::convertEnergy(1.1, EnergyPowerType::JOULES, 'invalid');
}
/**
diff --git a/tests/Utils/IO/Spreadsheet/SpreadsheetDatabaseMapperTest.php b/tests/Utils/IO/Spreadsheet/SpreadsheetDatabaseMapperTest.php
index b30db62f7..ceb645d00 100755
--- a/tests/Utils/IO/Spreadsheet/SpreadsheetDatabaseMapperTest.php
+++ b/tests/Utils/IO/Spreadsheet/SpreadsheetDatabaseMapperTest.php
@@ -14,9 +14,9 @@ declare(strict_types=1);
namespace phpOMS\tests\Utils\IO\Spreadsheet;
-use phpOMS\tests\Autoloader;
use phpOMS\DataStorage\Database\Connection\SQLiteConnection;
use phpOMS\DataStorage\Database\Query\Builder;
+use phpOMS\tests\Autoloader;
use phpOMS\Utils\IO\Spreadsheet\SpreadsheetDatabaseMapper;
use phpOMS\Utils\StringUtils;
@@ -79,7 +79,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->insert();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -91,7 +91,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -114,7 +114,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->insert();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -126,7 +126,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -149,7 +149,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->insert();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -161,7 +161,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -184,7 +184,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->insert();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -196,7 +196,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -211,7 +211,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->update();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -223,7 +223,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -246,7 +246,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->insert();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -258,7 +258,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -273,7 +273,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->update();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -285,7 +285,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -308,7 +308,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->insert();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -320,7 +320,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -335,7 +335,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->update();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -347,7 +347,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -374,7 +374,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->insert();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -386,7 +386,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -426,7 +426,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->insert();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -438,7 +438,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -478,7 +478,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
$mapper->insert();
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_1.*')->from('insert_1')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_1.*')->from('insert_1')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
@@ -490,7 +490,7 @@ final class SpreadsheetDatabaseMapperTest extends \PHPUnit\Framework\TestCase
);
$builder = new Builder($this->sqlite, true);
- $data = $builder->select('insert_2.*')->from('insert_2')->execute()->fetchAll(\PDO::FETCH_ASSOC);
+ $data = $builder->select('insert_2.*')->from('insert_2')->execute()?->fetchAll(\PDO::FETCH_ASSOC) ?? [];
self::assertEquals(
[
['id' => 1, 'int' => 2, 'decimal' => 2.0, 'bool' => 1, 'varchar' => 'Line 1', 'datetime' => '43631'],
diff --git a/tests/Utils/ImageUtilsTest.php b/tests/Utils/ImageUtilsTest.php
index 84eed2dc2..7d4aec704 100755
--- a/tests/Utils/ImageUtilsTest.php
+++ b/tests/Utils/ImageUtilsTest.php
@@ -39,16 +39,18 @@ final class ImageUtilsTest extends \PHPUnit\Framework\TestCase
public function testResize() : void
{
- ImageUtils::resize(__DIR__ . '/logo.png', __DIR__ . '/logo_resized.png', 256, 256);
- self::assertTrue(\is_file(__DIR__ . '/logo_resized.png'));
+ ImageUtils::resize(__DIR__ . '/img/logo.png', __DIR__ . '/img/logo_resized.png', 256, 256);
+ self::assertTrue(\is_file(__DIR__ . '/img/logo_resized.png'));
}
public function testDifference() : void
{
- $diff = ImageUtils::difference(__DIR__ . '/img1.png', __DIR__ . '/img2.png', __DIR__ . '/diff1.png', 0);
- $diff = ImageUtils::difference(__DIR__ . '/img1.png', __DIR__ . '/img2.png', __DIR__ . '/diff2.png', 1);
+ foreach (['png', 'gif'] as $type) {
+ $diff = ImageUtils::difference(__DIR__ . '/img/img1.' . $type, __DIR__ . '/img/img2.' . $type, __DIR__ . '/img/diff1.' . $type, 0);
+ $diff = ImageUtils::difference(__DIR__ . '/img/img1.' . $type, __DIR__ . '/img/img2.' . $type, __DIR__ . '/img/diff2.' . $type, 1);
- self::assertGreaterThan(0, $diff);
+ self::assertGreaterThan(0, $diff);
+ }
}
/**
@@ -59,7 +61,7 @@ final class ImageUtilsTest extends \PHPUnit\Framework\TestCase
public function testImage() : void
{
self::assertEquals(
- \file_get_contents(__DIR__ . '/logo.png'),
+ \file_get_contents(__DIR__ . '/img/logo.png'),
ImageUtils::decodeBase64Image(
''
)
diff --git a/tests/Utils/Parser/Calendar/ICalParserTest.php b/tests/Utils/Parser/Calendar/ICalParserTest.php
new file mode 100644
index 000000000..64ddafac2
--- /dev/null
+++ b/tests/Utils/Parser/Calendar/ICalParserTest.php
@@ -0,0 +1,42 @@
+toPdfString(__DIR__ . '/data/WordMpdf.pdf');
+ self::assertFalse(\is_file(__DIR__ . '/data/WordMpdf.pdf'));
+
+ \file_put_contents(__DIR__ . '/data/WordMpdf.pdf', $pdf);
+ self::assertTrue(\is_file(__DIR__ . '/data/WordMpdf.pdf'));
+ self::assertGreaterThan(100, \strlen(\file_get_contents(__DIR__ . '/data/WordMpdf.pdf')));
+ }
+}
diff --git a/tests/Utils/Parser/Document/data/Word.docx b/tests/Utils/Parser/Document/data/Word.docx
new file mode 100644
index 000000000..811baba61
Binary files /dev/null and b/tests/Utils/Parser/Document/data/Word.docx differ
diff --git a/tests/Utils/Parser/Document/data/Word.html b/tests/Utils/Parser/Document/data/Word.html
new file mode 100644
index 000000000..e69de29bb
diff --git a/tests/Utils/Parser/Markdown/MarkdownTest.php b/tests/Utils/Parser/Markdown/MarkdownTest.php
index 87fc643fb..50db61079 100755
--- a/tests/Utils/Parser/Markdown/MarkdownTest.php
+++ b/tests/Utils/Parser/Markdown/MarkdownTest.php
@@ -47,9 +47,142 @@ final class MarkdownTest extends \PHPUnit\Framework\TestCase
public function testSafeMode() : void
{
- $parser = new Markdown();
- $parser->setSafeMode(true);
+ $parser = new Markdown();
+ $parser->safeMode = true;
- self::assertTrue(\file_get_contents(__DIR__ . '/manualdata/xss_bad_url.html') === ($parsed = $parser->text(\file_get_contents(__DIR__ . '/manualdata/xss_bad_url.md'))), $parsed);
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/xss_bad_url.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/xss_bad_url.md'))
+ );
+ }
+
+ public function testTablespan() : void
+ {
+ $parser = new Markdown([
+ 'tables' => [
+ 'tablespan' => true,
+ ],
+ ]);
+
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/tablespan.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/tablespan.md'))
+ );
+ }
+
+ public function testMap() : void
+ {
+ $parser = new Markdown([
+ 'map' => true,
+ ]);
+
+ self::assertLessThan(9,
+ \levenshtein(
+ \file_get_contents(__DIR__ . '/manualdata/map.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/map.md'))
+ )
+ );
+ }
+
+ public function testContact() : void
+ {
+ $parser = new Markdown([
+ 'contact' => true,
+ ]);
+
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/contact.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/contact.md'))
+ );
+ }
+
+ public function testTypographer() : void
+ {
+ $parser = new Markdown([
+ 'typographer' => true,
+ ]);
+
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/typographer.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/typographer.md'))
+ );
+ }
+
+ public function testAddress() : void
+ {
+ $parser = new Markdown([
+ 'address' => true,
+ ]);
+
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/address.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/address.md'))
+ );
+ }
+
+ public function testProgress() : void
+ {
+ $parser = new Markdown([
+ 'progress' => true,
+ ]);
+
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/progress.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/progress.md'))
+ );
+ }
+
+ public function testEmbed() : void
+ {
+ $parser = new Markdown([
+ 'embeding' => true,
+ ]);
+
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/embed.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/embed.md'))
+ );
+ }
+
+ public function testMath() : void
+ {
+ $parser = new Markdown([
+ 'math' => true,
+ ]);
+
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/katex.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/katex.md'))
+ );
+ }
+
+ public function testTOC() : void
+ {
+ $parser = new Markdown([
+ 'toc' => true,
+ ]);
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/toc.md'));
+
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/toc.html'),
+ $parser->contentsList()
+ );
+ }
+
+ public function testSpoiler() : void
+ {
+ $parser = new Markdown([
+ 'spoiler' => true,
+ ]);
+
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/spoiler.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/spoiler.md'))
+ );
+
+ self::assertEquals(
+ \file_get_contents(__DIR__ . '/manualdata/spoiler_block.html'),
+ $parser->text(\file_get_contents(__DIR__ . '/manualdata/spoiler_block.md'))
+ );
}
}
diff --git a/tests/Utils/Parser/Markdown/data/chartjs.html b/tests/Utils/Parser/Markdown/data/chartjs.html
new file mode 100644
index 000000000..c173ca4d7
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/chartjs.html
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/chartjs.md b/tests/Utils/Parser/Markdown/data/chartjs.md
new file mode 100644
index 000000000..6ff76ccd9
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/chartjs.md
@@ -0,0 +1,2 @@
+```chart
+```
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/checkbox.html b/tests/Utils/Parser/Markdown/data/checkbox.html
new file mode 100644
index 000000000..2fe532fb7
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/checkbox.html
@@ -0,0 +1,4 @@
+
+
Unchecked
+
Checked
+
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/checkbox.md b/tests/Utils/Parser/Markdown/data/checkbox.md
new file mode 100644
index 000000000..1949d401f
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/checkbox.md
@@ -0,0 +1,2 @@
+- [ ] Unchecked
+- [x] Checked
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/em_strong.html b/tests/Utils/Parser/Markdown/data/em_strong.html
index c2cddc0fc..d16606cd8 100755
--- a/tests/Utils/Parser/Markdown/data/em_strong.html
+++ b/tests/Utils/Parser/Markdown/data/em_strong.html
@@ -1,8 +1,4 @@
-
em strong
-
em strong strong
-
strong em strong
-
strong em strong strong
-
em strong
-
em strong strong
-
strong em strong
-
strong em strong strong
\ No newline at end of file
+
em underline
+
underline em
+
strong em
+
strong em
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/em_strong.md b/tests/Utils/Parser/Markdown/data/em_strong.md
index 9abeb3fd4..224cf308d 100755
--- a/tests/Utils/Parser/Markdown/data/em_strong.md
+++ b/tests/Utils/Parser/Markdown/data/em_strong.md
@@ -1,15 +1,7 @@
-___em strong___
+___em underline___
-___em strong_ strong__
+__*underline em*__
-__strong _em strong___
+***strong em***
-__strong _em strong_ strong__
-
-***em strong***
-
-***em strong* strong**
-
-**strong *em strong***
-
-**strong *em strong* strong**
\ No newline at end of file
+**_strong em_**
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/emoji.html b/tests/Utils/Parser/Markdown/data/emoji.html
new file mode 100644
index 000000000..d4de04c55
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/emoji.html
@@ -0,0 +1 @@
+
📹
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/emoji.md b/tests/Utils/Parser/Markdown/data/emoji.md
new file mode 100644
index 000000000..914af9824
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/emoji.md
@@ -0,0 +1 @@
+:video_camera:
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/emphasis.html b/tests/Utils/Parser/Markdown/data/emphasis.html
index 60ff4bd8b..4571c85f8 100755
--- a/tests/Utils/Parser/Markdown/data/emphasis.html
+++ b/tests/Utils/Parser/Markdown/data/emphasis.html
@@ -1,4 +1,4 @@
-
underscore, asterisk, one two, three four, a, b
+
underscore, asterisk, one two, three four, a, b
strong and em and strong and em
line
line
diff --git a/tests/Utils/Parser/Markdown/data/emphasis.md b/tests/Utils/Parser/Markdown/data/emphasis.md
index 85b9d2299..99073ae5c 100755
--- a/tests/Utils/Parser/Markdown/data/emphasis.md
+++ b/tests/Utils/Parser/Markdown/data/emphasis.md
@@ -1,10 +1,10 @@
-_underscore_, *asterisk*, _one two_, *three four*, _a_, *b*
+__underscore__, *asterisk*, _one two_, *three four*, _a_, *b*
**strong** and *em* and **strong** and *em*
-_line
+*line
line
-line_
+line*
this_is_not_an_emphasis
diff --git a/tests/Utils/Parser/Markdown/data/keystroke.html b/tests/Utils/Parser/Markdown/data/keystroke.html
new file mode 100644
index 000000000..8e6d5ca4d
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/keystroke.html
@@ -0,0 +1 @@
+
ctrl + shift + A
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/keystroke.md b/tests/Utils/Parser/Markdown/data/keystroke.md
new file mode 100644
index 000000000..281e60490
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/keystroke.md
@@ -0,0 +1 @@
+[[ctrl]] + [[shift]] + [[A]]
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/mark.html b/tests/Utils/Parser/Markdown/data/mark.html
new file mode 100644
index 000000000..2b6624130
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/mark.html
@@ -0,0 +1 @@
+
Text with Mark test inline.
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/mark.md b/tests/Utils/Parser/Markdown/data/mark.md
new file mode 100644
index 000000000..efefef266
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/mark.md
@@ -0,0 +1 @@
+Text with ==Mark test== inline.
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/mermaidjs.html b/tests/Utils/Parser/Markdown/data/mermaidjs.html
new file mode 100644
index 000000000..a49f1d1b3
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/mermaidjs.html
@@ -0,0 +1,11 @@
+
sequenceDiagram
+ participant Alice
+ participant Bob
+ Alice->>John: Hello John, how are you?
+ loop Healthcheck
+ John->>John: Fight against hypochondria
+ end
+ Note right of John: Rational thoughts<br/>prevail...
+ John-->>Alice: Great!
+ John->>Bob: How about you?
+ Bob-->>John: Jolly good!
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/data/mermaidjs.md b/tests/Utils/Parser/Markdown/data/mermaidjs.md
new file mode 100644
index 000000000..b9c32ff04
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/data/mermaidjs.md
@@ -0,0 +1,13 @@
+```mermaid
+sequenceDiagram
+ participant Alice
+ participant Bob
+ Alice->>John: Hello John, how are you?
+ loop Healthcheck
+ John->>John: Fight against hypochondria
+ end
+ Note right of John: Rational thoughts prevail...
+ John-->>Alice: Great!
+ John->>Bob: How about you?
+ Bob-->>John: Jolly good!
+```
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/address.html b/tests/Utils/Parser/Markdown/manualdata/address.html
new file mode 100644
index 000000000..7a6a79b3b
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/address.html
@@ -0,0 +1,7 @@
+
+AddrName
+Addr
+AddrZip
+AddrCity
+AddrCoutry
+
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/address.md b/tests/Utils/Parser/Markdown/manualdata/address.md
new file mode 100644
index 000000000..ed1c1e308
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/address.md
@@ -0,0 +1 @@
+[addr name="AddrName" address="Addr" city="AddrCity" country="AddrCoutry" zip="AddrZip"]
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/contact.html b/tests/Utils/Parser/Markdown/manualdata/contact.html
new file mode 100644
index 000000000..92760f913
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/contact.html
@@ -0,0 +1,36 @@
+
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/contact.md b/tests/Utils/Parser/Markdown/manualdata/contact.md
new file mode 100644
index 000000000..3b56536b9
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/contact.md
@@ -0,0 +1,9 @@
+[contact phone="+49 123 456 789"]
+[contact facebook="@jinggaApp"]
+[contact discord="jingga"]
+[contact email="test@email.com"]
+[contact twitter="@jinggaApp"]
+[contact youtube="@jinggaApp"]
+[contact instagram="jinggaApp"]
+[contact slack="jinggaApp"]
+[contact teams="jinggaApp"]
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/embed.html b/tests/Utils/Parser/Markdown/manualdata/embed.html
new file mode 100644
index 000000000..d30d6762c
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/embed.html
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/embed.md b/tests/Utils/Parser/Markdown/manualdata/embed.md
new file mode 100644
index 000000000..58e47889a
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/embed.md
@@ -0,0 +1,5 @@
+[video src="https://www.youtube.com/watch?v=dQw4w9WgXcQ&ab_channel=RickAstley"]
+[video src="https://vimeo.com/874474957"]
+[video src="https://www.dailymotion.com/video/x3w7rss"]
+[video src="test.mp4"]
+[audio src="test.mp3"]
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/katex.html b/tests/Utils/Parser/Markdown/manualdata/katex.html
new file mode 100644
index 000000000..4df09dc60
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/katex.html
@@ -0,0 +1,2 @@
+$$
+ x = {-b \pm \sqrt{b^2-4ac} \over 2a}.$$
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/katex.md b/tests/Utils/Parser/Markdown/manualdata/katex.md
new file mode 100644
index 000000000..2c583e1c0
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/katex.md
@@ -0,0 +1,3 @@
+$$
+ x = {-b \pm \sqrt{b^2-4ac} \over 2a}.
+$$
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/map.html b/tests/Utils/Parser/Markdown/manualdata/map.html
new file mode 100644
index 000000000..c6f54ef15
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/map.html
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/map.md b/tests/Utils/Parser/Markdown/manualdata/map.md
new file mode 100644
index 000000000..a7963e89a
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/map.md
@@ -0,0 +1 @@
+[map lat="1.0" lon="1.0"]
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/progress.html b/tests/Utils/Parser/Markdown/manualdata/progress.html
new file mode 100644
index 000000000..24ae75383
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/progress.html
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/progress.md b/tests/Utils/Parser/Markdown/manualdata/progress.md
new file mode 100644
index 000000000..579e077e5
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/progress.md
@@ -0,0 +1 @@
+[progress value="33"]
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/spoiler.html b/tests/Utils/Parser/Markdown/manualdata/spoiler.html
new file mode 100644
index 000000000..2085a4d8e
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/spoiler.html
@@ -0,0 +1,4 @@
+
This is a
+
+test spoiler
+ in text.
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/spoiler.md b/tests/Utils/Parser/Markdown/manualdata/spoiler.md
new file mode 100644
index 000000000..011c08b14
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/spoiler.md
@@ -0,0 +1 @@
+This is a >!test spoiler!< in text.
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/spoiler_block.html b/tests/Utils/Parser/Markdown/manualdata/spoiler_block.html
new file mode 100644
index 000000000..067b6cdb3
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/spoiler_block.html
@@ -0,0 +1,5 @@
+
+Test summary
+
+This is a test spoiler.
+
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/spoiler_block.md b/tests/Utils/Parser/Markdown/manualdata/spoiler_block.md
new file mode 100644
index 000000000..f855f1231
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/spoiler_block.md
@@ -0,0 +1,3 @@
+???Test summary
+This is a test spoiler.
+???
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/tablespan.html b/tests/Utils/Parser/Markdown/manualdata/tablespan.html
new file mode 100644
index 000000000..83d411ac2
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/tablespan.html
@@ -0,0 +1,36 @@
+
+
+
+
Colspan
+
for thead
+
+
+
+
+
Lorem
+
ipsum
+
dolor
+
sit
+
amet
+
+
+
-
+
right align
+
.
+
+
+
,
+
center align
+
2x2 cell
+
+
+
another 2x2
+
+
+
+
+
+
+
!
+
+
+
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/tablespan.md b/tests/Utils/Parser/Markdown/manualdata/tablespan.md
new file mode 100644
index 000000000..3b35723eb
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/tablespan.md
@@ -0,0 +1,7 @@
+| > | > | Colspan | > | for thead |
+| ----- | :---------: | -----------: | ----------- | --------- |
+| Lorem | ipsum | dolor | sit | amet |
+| ^ | - | > | right align | . |
+| , | > | center align | > | 2x2 cell |
+| > | another 2x2 | + | > | ^ |
+| > | ^ | | | ! |
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/toc.html b/tests/Utils/Parser/Markdown/manualdata/toc.html
new file mode 100644
index 000000000..b7951fe2c
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/toc.html
@@ -0,0 +1,10 @@
+
\ No newline at end of file
diff --git a/tests/Utils/Parser/Markdown/manualdata/toc.md b/tests/Utils/Parser/Markdown/manualdata/toc.md
new file mode 100644
index 000000000..156f263f0
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/toc.md
@@ -0,0 +1,7 @@
+# A
+
+## 1
+
+### i
+
+# B
diff --git a/tests/Utils/Parser/Markdown/manualdata/typographer.html b/tests/Utils/Parser/Markdown/manualdata/typographer.html
new file mode 100644
index 000000000..ea5570267
--- /dev/null
+++ b/tests/Utils/Parser/Markdown/manualdata/typographer.html
@@ -0,0 +1 @@
+