161 lines
5.4 KiB
PHP
161 lines
5.4 KiB
PHP
<?php # -*- coding: utf-8 mode: php -*- vim:sw=2:sts=2:et:ai:si:sta:fenc=utf-8
|
|
require(__DIR__.'/../vendor/autoload.php');
|
|
|
|
use nur\A;
|
|
use nur\b\UserException;
|
|
use nur\cli\Application;
|
|
use nur\config;
|
|
use nur\msg;
|
|
|
|
Application::run(new class extends Application {
|
|
const ARGS = [
|
|
"merge" => Application::ARGS,
|
|
["-l:", "--level"],
|
|
["-t:", "--type"],
|
|
["-r:", "--result"],
|
|
["-s:", "--suite"],
|
|
];
|
|
private $args;
|
|
private $level, $type, $result, $suite, $noColor;
|
|
|
|
const LEVEL_MAP = [
|
|
"1" => msg::CRITICAL, "c" => msg::CRITICAL,
|
|
"2" => msg::MAJOR, "M" => msg::MAJOR,
|
|
"3" => msg::NORMAL, "n" => msg::NORMAL,
|
|
"4" => msg::MINOR, "m" => msg::MINOR,
|
|
];
|
|
const TYPE_MAP = [
|
|
"1" => msg::ERROR, "e" => msg::ERROR,
|
|
"2" => msg::WARNING, "w" => msg::WARNING,
|
|
"3" => msg::INFO, "i" => msg::INFO,
|
|
"4" => msg::DEBUG, "d" => msg::DEBUG,
|
|
];
|
|
const RESULT_MAP = [
|
|
"0" => msg::NONE, "n" => msg::NONE,
|
|
"1" => msg::NEUTRAL, "s" => msg::NEUTRAL,
|
|
"2" => msg::SUCCESS, "ok" => msg::SUCCESS,
|
|
"3" => msg::FAILURE, "ko" => msg::FAILURE,
|
|
];
|
|
|
|
const LEVELS = [
|
|
msg::CRITICAL => "critical",
|
|
msg::MAJOR => "major",
|
|
msg::NORMAL => "normal",
|
|
msg::MINOR => "minor",
|
|
];
|
|
|
|
const TYPES = [
|
|
msg::ERROR => "error",
|
|
msg::WARNING => "warning",
|
|
msg::INFO => "info",
|
|
msg::DEBUG => "debug",
|
|
];
|
|
|
|
const RESULTS = [msg::NONE, msg::NEUTRAL, msg::SUCCESS, msg::FAILURE];
|
|
|
|
function main() {
|
|
msg::info("current profile is " . config::get_profile());
|
|
|
|
$level = A::get(self::LEVEL_MAP, $this->level);
|
|
$levels = A::with($level);
|
|
if (!$levels) $levels = array_keys(self::LEVELS);
|
|
|
|
$type = A::get(self::TYPE_MAP, $this->type);
|
|
$types = A::with($type);
|
|
if (!$types) $types = array_keys(self::TYPES);
|
|
|
|
$result = A::get(self::RESULT_MAP, $this->result);
|
|
$results = A::with($result);
|
|
if (!$results) $results = self::RESULTS;
|
|
|
|
$suite = $this->suite;
|
|
|
|
$msg = msg::get();
|
|
foreach (self::LEVELS as $level => $levelName) {
|
|
if (!in_array($level, $levels)) continue;
|
|
|
|
if ($suite === null || $suite == "1") {
|
|
msg::section("$levelName messages -- user only", $level, msg::INFO);
|
|
foreach (self::TYPES as $type => $typeName) {
|
|
if (!in_array($type, $types)) continue;
|
|
foreach ($results as $result) {
|
|
$msg->addMessage("user only $levelName $typeName", $type + $result, $level);
|
|
}
|
|
}
|
|
}
|
|
if ($suite === null || $suite == "2") {
|
|
msg::section("$levelName messages -- user + tech", $level, msg::INFO);
|
|
foreach (self::TYPES as $type => $typeName) {
|
|
if (!in_array($type, $types)) continue;
|
|
foreach ($results as $result) {
|
|
$msg->addMessage([
|
|
"user $levelName $typeName",
|
|
"tech $levelName $typeName",
|
|
], $type + $result, $level);
|
|
}
|
|
}
|
|
}
|
|
if ($suite === null || $suite == "3") {
|
|
msg::section("$levelName messages -- UserException", $level, msg::INFO);
|
|
$e = new UserException(["e_user", "e_tech"]);
|
|
foreach (self::TYPES as $type => $typeName) {
|
|
if (!in_array($type, $types)) continue;
|
|
foreach ($results as $result) {
|
|
$msg->addMessage($e, $type + $result, $level);
|
|
}
|
|
}
|
|
}
|
|
if ($suite === null || $suite == "4") {
|
|
msg::section("$levelName messages -- Exception", $level, msg::INFO);
|
|
$e = new Exception("e_message");
|
|
foreach (self::TYPES as $type => $typeName) {
|
|
if (!in_array($type, $types)) continue;
|
|
foreach ($results as $result) {
|
|
$msg->addMessage($e, $type + $result, $level);
|
|
}
|
|
}
|
|
}
|
|
if ($suite === null || $suite == "5") {
|
|
msg::section("$levelName messages -- user, Exception", $level, msg::INFO);
|
|
$e = new Exception("e_message");
|
|
foreach (self::TYPES as $type => $typeName) {
|
|
if (!in_array($type, $types)) continue;
|
|
foreach ($results as $result) {
|
|
$msg->addMessage(["user", $e], $type + $result, $level);
|
|
}
|
|
}
|
|
}
|
|
if ($suite === null || $suite == "6") {
|
|
msg::section("$levelName messages -- user, tech, Exception", $level, msg::INFO);
|
|
$e = new Exception("e_message");
|
|
foreach (self::TYPES as $type => $typeName) {
|
|
if (!in_array($type, $types)) continue;
|
|
foreach ($results as $result) {
|
|
$msg->addMessage(["user", "tech", $e], $type + $result, $level);
|
|
}
|
|
}
|
|
}
|
|
if ($suite === null || $suite == "7") {
|
|
msg::section("$levelName messages -- user, UserException", $level, msg::INFO);
|
|
$e = new UserException(["e_user", "e_tech"]);
|
|
foreach (self::TYPES as $type => $typeName) {
|
|
if (!in_array($type, $types)) continue;
|
|
foreach ($results as $result) {
|
|
$msg->addMessage(["user", $e], $type + $result, $level);
|
|
}
|
|
}
|
|
}
|
|
if ($suite === null || $suite == "8") {
|
|
msg::section("$levelName messages -- user, tech, UserException", $level, msg::INFO);
|
|
$e = new UserException(["e_user", "e_tech"]);
|
|
foreach (self::TYPES as $type => $typeName) {
|
|
if (!in_array($type, $types)) continue;
|
|
foreach ($results as $result) {
|
|
$msg->addMessage(["user", "tech", $e], $type + $result, $level);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
});
|