nur-sery/nur_tbin/base/test-msg.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);
}
}
}
}
}
});