From 400f990929db667f03da5b64b412c5b469b0bac1 Mon Sep 17 00:00:00 2001 From: vladutmargineanu Date: Tue, 23 Jan 2024 19:58:20 +0200 Subject: [PATCH] added jUnit tests with Mockito and added more checks for lambda methods --- .../matcher/service/PlayerService.java | 56 +- .../assembler/PlayerAssemblerTest.java | 56 + .../matcher/command/PlayerCommandTest.java | 36 + .../controller/PlayerControllerTest.java | 84 + .../matcher/service/CampaignServiceTest.java | 39 + .../matcher/service/PlayerServiceTest.java | 103 ++ resources/JUnitReport/css/coverage.css | 154 ++ resources/JUnitReport/css/idea.min.css | 118 ++ resources/JUnitReport/img/arrowDown.gif | Bin 0 -> 89 bytes resources/JUnitReport/img/arrowUp.gif | Bin 0 -> 91 bytes resources/JUnitReport/index.html | 439 ++++++ .../JUnitReport/index_SORT_BY_BLOCK.html | 439 ++++++ .../JUnitReport/index_SORT_BY_BLOCK_DESC.html | 439 ++++++ .../JUnitReport/index_SORT_BY_CLASS.html | 439 ++++++ .../JUnitReport/index_SORT_BY_CLASS_DESC.html | 439 ++++++ resources/JUnitReport/index_SORT_BY_LINE.html | 439 ++++++ .../JUnitReport/index_SORT_BY_LINE_DESC.html | 439 ++++++ .../JUnitReport/index_SORT_BY_METHOD.html | 439 ++++++ .../index_SORT_BY_METHOD_DESC.html | 439 ++++++ .../JUnitReport/index_SORT_BY_NAME_DESC.html | 439 ++++++ resources/JUnitReport/js/highlight.min.js | 1388 +++++++++++++++++ .../js/highlightjs-line-numbers.min.js | 24 + resources/JUnitReport/ns-1/index.html | 143 ++ .../JUnitReport/ns-1/index_SORT_BY_BLOCK.html | 143 ++ .../ns-1/index_SORT_BY_BLOCK_DESC.html | 143 ++ .../JUnitReport/ns-1/index_SORT_BY_CLASS.html | 143 ++ .../ns-1/index_SORT_BY_CLASS_DESC.html | 143 ++ .../JUnitReport/ns-1/index_SORT_BY_LINE.html | 143 ++ .../ns-1/index_SORT_BY_LINE_DESC.html | 143 ++ .../ns-1/index_SORT_BY_METHOD.html | 143 ++ .../ns-1/index_SORT_BY_METHOD_DESC.html | 143 ++ .../ns-1/index_SORT_BY_NAME_DESC.html | 143 ++ .../JUnitReport/ns-1/sources/source-1.html | 133 ++ resources/JUnitReport/ns-2/index.html | 278 ++++ .../JUnitReport/ns-2/index_SORT_BY_BLOCK.html | 278 ++++ .../ns-2/index_SORT_BY_BLOCK_DESC.html | 278 ++++ .../JUnitReport/ns-2/index_SORT_BY_CLASS.html | 278 ++++ .../ns-2/index_SORT_BY_CLASS_DESC.html | 278 ++++ .../JUnitReport/ns-2/index_SORT_BY_LINE.html | 278 ++++ .../ns-2/index_SORT_BY_LINE_DESC.html | 278 ++++ .../ns-2/index_SORT_BY_METHOD.html | 278 ++++ .../ns-2/index_SORT_BY_METHOD_DESC.html | 278 ++++ .../ns-2/index_SORT_BY_NAME_DESC.html | 278 ++++ .../JUnitReport/ns-2/sources/source-1.html | 113 ++ .../JUnitReport/ns-2/sources/source-2.html | 121 ++ .../JUnitReport/ns-2/sources/source-3.html | 117 ++ .../JUnitReport/ns-2/sources/source-4.html | 139 ++ .../JUnitReport/ns-2/sources/source-5.html | 119 ++ .../JUnitReport/ns-2/sources/source-6.html | 108 ++ resources/JUnitReport/ns-3/index.html | 224 +++ .../JUnitReport/ns-3/index_SORT_BY_BLOCK.html | 224 +++ .../ns-3/index_SORT_BY_BLOCK_DESC.html | 224 +++ .../JUnitReport/ns-3/index_SORT_BY_CLASS.html | 224 +++ .../ns-3/index_SORT_BY_CLASS_DESC.html | 224 +++ .../JUnitReport/ns-3/index_SORT_BY_LINE.html | 224 +++ .../ns-3/index_SORT_BY_LINE_DESC.html | 224 +++ .../ns-3/index_SORT_BY_METHOD.html | 224 +++ .../ns-3/index_SORT_BY_METHOD_DESC.html | 224 +++ .../ns-3/index_SORT_BY_NAME_DESC.html | 224 +++ .../JUnitReport/ns-3/sources/source-1.html | 141 ++ .../JUnitReport/ns-3/sources/source-2.html | 144 ++ .../JUnitReport/ns-3/sources/source-3.html | 149 ++ .../JUnitReport/ns-3/sources/source-4.html | 178 +++ resources/JUnitReport/ns-4/index.html | 143 ++ .../JUnitReport/ns-4/index_SORT_BY_BLOCK.html | 143 ++ .../ns-4/index_SORT_BY_BLOCK_DESC.html | 143 ++ .../JUnitReport/ns-4/index_SORT_BY_CLASS.html | 143 ++ .../ns-4/index_SORT_BY_CLASS_DESC.html | 143 ++ .../JUnitReport/ns-4/index_SORT_BY_LINE.html | 143 ++ .../ns-4/index_SORT_BY_LINE_DESC.html | 143 ++ .../ns-4/index_SORT_BY_METHOD.html | 143 ++ .../ns-4/index_SORT_BY_METHOD_DESC.html | 143 ++ .../ns-4/index_SORT_BY_NAME_DESC.html | 143 ++ .../JUnitReport/ns-4/sources/source-1.html | 131 ++ resources/JUnitReport/ns-5/index.html | 143 ++ .../JUnitReport/ns-5/index_SORT_BY_BLOCK.html | 143 ++ .../ns-5/index_SORT_BY_BLOCK_DESC.html | 143 ++ .../JUnitReport/ns-5/index_SORT_BY_CLASS.html | 143 ++ .../ns-5/index_SORT_BY_CLASS_DESC.html | 143 ++ .../JUnitReport/ns-5/index_SORT_BY_LINE.html | 143 ++ .../ns-5/index_SORT_BY_LINE_DESC.html | 143 ++ .../ns-5/index_SORT_BY_METHOD.html | 143 ++ .../ns-5/index_SORT_BY_METHOD_DESC.html | 143 ++ .../ns-5/index_SORT_BY_NAME_DESC.html | 143 ++ .../JUnitReport/ns-5/sources/source-1.html | 146 ++ resources/JUnitReport/ns-6/index.html | 143 ++ .../JUnitReport/ns-6/index_SORT_BY_BLOCK.html | 143 ++ .../ns-6/index_SORT_BY_BLOCK_DESC.html | 143 ++ .../JUnitReport/ns-6/index_SORT_BY_CLASS.html | 143 ++ .../ns-6/index_SORT_BY_CLASS_DESC.html | 143 ++ .../JUnitReport/ns-6/index_SORT_BY_LINE.html | 143 ++ .../ns-6/index_SORT_BY_LINE_DESC.html | 143 ++ .../ns-6/index_SORT_BY_METHOD.html | 143 ++ .../ns-6/index_SORT_BY_METHOD_DESC.html | 143 ++ .../ns-6/index_SORT_BY_NAME_DESC.html | 143 ++ .../JUnitReport/ns-6/sources/source-1.html | 240 +++ resources/JUnitReport/ns-7/index.html | 224 +++ .../JUnitReport/ns-7/index_SORT_BY_BLOCK.html | 224 +++ .../ns-7/index_SORT_BY_BLOCK_DESC.html | 224 +++ .../JUnitReport/ns-7/index_SORT_BY_CLASS.html | 224 +++ .../ns-7/index_SORT_BY_CLASS_DESC.html | 224 +++ .../JUnitReport/ns-7/index_SORT_BY_LINE.html | 224 +++ .../ns-7/index_SORT_BY_LINE_DESC.html | 224 +++ .../ns-7/index_SORT_BY_METHOD.html | 224 +++ .../ns-7/index_SORT_BY_METHOD_DESC.html | 224 +++ .../ns-7/index_SORT_BY_NAME_DESC.html | 224 +++ .../JUnitReport/ns-7/sources/source-1.html | 127 ++ .../JUnitReport/ns-7/sources/source-2.html | 128 ++ .../JUnitReport/ns-7/sources/source-3.html | 133 ++ .../JUnitReport/ns-7/sources/source-4.html | 167 ++ resources/JUnitReport/ns-8/index.html | 143 ++ .../JUnitReport/ns-8/index_SORT_BY_BLOCK.html | 143 ++ .../ns-8/index_SORT_BY_BLOCK_DESC.html | 143 ++ .../JUnitReport/ns-8/index_SORT_BY_CLASS.html | 143 ++ .../ns-8/index_SORT_BY_CLASS_DESC.html | 143 ++ .../JUnitReport/ns-8/index_SORT_BY_LINE.html | 143 ++ .../ns-8/index_SORT_BY_LINE_DESC.html | 143 ++ .../ns-8/index_SORT_BY_METHOD.html | 143 ++ .../ns-8/index_SORT_BY_METHOD_DESC.html | 143 ++ .../ns-8/index_SORT_BY_NAME_DESC.html | 143 ++ .../JUnitReport/ns-8/sources/source-1.html | 181 +++ resources/JUnitReport/ns-9/index.html | 251 +++ .../JUnitReport/ns-9/index_SORT_BY_BLOCK.html | 251 +++ .../ns-9/index_SORT_BY_BLOCK_DESC.html | 251 +++ .../JUnitReport/ns-9/index_SORT_BY_CLASS.html | 251 +++ .../ns-9/index_SORT_BY_CLASS_DESC.html | 251 +++ .../JUnitReport/ns-9/index_SORT_BY_LINE.html | 251 +++ .../ns-9/index_SORT_BY_LINE_DESC.html | 251 +++ .../ns-9/index_SORT_BY_METHOD.html | 251 +++ .../ns-9/index_SORT_BY_METHOD_DESC.html | 251 +++ .../ns-9/index_SORT_BY_NAME_DESC.html | 251 +++ .../JUnitReport/ns-9/sources/source-1.html | 158 ++ .../JUnitReport/ns-9/sources/source-2.html | 164 ++ .../JUnitReport/ns-9/sources/source-3.html | 166 ++ .../JUnitReport/ns-9/sources/source-4.html | 161 ++ .../JUnitReport/ns-9/sources/source-5.html | 215 +++ resources/JUnitReport/ns-a/index.html | 197 +++ .../JUnitReport/ns-a/index_SORT_BY_BLOCK.html | 197 +++ .../ns-a/index_SORT_BY_BLOCK_DESC.html | 197 +++ .../JUnitReport/ns-a/index_SORT_BY_CLASS.html | 197 +++ .../ns-a/index_SORT_BY_CLASS_DESC.html | 197 +++ .../JUnitReport/ns-a/index_SORT_BY_LINE.html | 197 +++ .../ns-a/index_SORT_BY_LINE_DESC.html | 197 +++ .../ns-a/index_SORT_BY_METHOD.html | 197 +++ .../ns-a/index_SORT_BY_METHOD_DESC.html | 197 +++ .../ns-a/index_SORT_BY_NAME_DESC.html | 197 +++ .../JUnitReport/ns-a/sources/source-1.html | 119 ++ .../JUnitReport/ns-a/sources/source-2.html | 119 ++ .../JUnitReport/ns-a/sources/source-3.html | 118 ++ resources/JUnitReport/ns-b/index.html | 170 ++ .../JUnitReport/ns-b/index_SORT_BY_BLOCK.html | 170 ++ .../ns-b/index_SORT_BY_BLOCK_DESC.html | 170 ++ .../JUnitReport/ns-b/index_SORT_BY_CLASS.html | 170 ++ .../ns-b/index_SORT_BY_CLASS_DESC.html | 170 ++ .../JUnitReport/ns-b/index_SORT_BY_LINE.html | 170 ++ .../ns-b/index_SORT_BY_LINE_DESC.html | 170 ++ .../ns-b/index_SORT_BY_METHOD.html | 170 ++ .../ns-b/index_SORT_BY_METHOD_DESC.html | 170 ++ .../ns-b/index_SORT_BY_NAME_DESC.html | 170 ++ .../JUnitReport/ns-b/sources/source-1.html | 253 +++ .../JUnitReport/ns-b/sources/source-2.html | 286 ++++ resources/JUnitReport/ns-c/index.html | 170 ++ .../JUnitReport/ns-c/index_SORT_BY_BLOCK.html | 170 ++ .../ns-c/index_SORT_BY_BLOCK_DESC.html | 170 ++ .../JUnitReport/ns-c/index_SORT_BY_CLASS.html | 170 ++ .../ns-c/index_SORT_BY_CLASS_DESC.html | 170 ++ .../JUnitReport/ns-c/index_SORT_BY_LINE.html | 170 ++ .../ns-c/index_SORT_BY_LINE_DESC.html | 170 ++ .../ns-c/index_SORT_BY_METHOD.html | 170 ++ .../ns-c/index_SORT_BY_METHOD_DESC.html | 170 ++ .../ns-c/index_SORT_BY_NAME_DESC.html | 170 ++ .../JUnitReport/ns-c/sources/source-1.html | 147 ++ .../JUnitReport/ns-c/sources/source-2.html | 121 ++ resources/JUnitReport/ns-d/index.html | 68 + .../JUnitReport/ns-d/index_SORT_BY_BLOCK.html | 68 + .../ns-d/index_SORT_BY_BLOCK_DESC.html | 68 + .../JUnitReport/ns-d/index_SORT_BY_CLASS.html | 68 + .../ns-d/index_SORT_BY_CLASS_DESC.html | 68 + .../JUnitReport/ns-d/index_SORT_BY_LINE.html | 68 + .../ns-d/index_SORT_BY_LINE_DESC.html | 68 + .../ns-d/index_SORT_BY_METHOD.html | 68 + .../ns-d/index_SORT_BY_METHOD_DESC.html | 68 + .../ns-d/index_SORT_BY_NAME_DESC.html | 68 + .../JUnitReport/ns-d/sources/source-1.html | 86 + .../JUnitReport/ns-d/sources/source-2.html | 91 ++ 185 files changed, 34320 insertions(+), 17 deletions(-) create mode 100644 matcher/src/test/java/com/profile/matcher/assembler/PlayerAssemblerTest.java create mode 100644 matcher/src/test/java/com/profile/matcher/command/PlayerCommandTest.java create mode 100644 matcher/src/test/java/com/profile/matcher/controller/PlayerControllerTest.java create mode 100644 matcher/src/test/java/com/profile/matcher/service/CampaignServiceTest.java create mode 100644 matcher/src/test/java/com/profile/matcher/service/PlayerServiceTest.java create mode 100644 resources/JUnitReport/css/coverage.css create mode 100644 resources/JUnitReport/css/idea.min.css create mode 100644 resources/JUnitReport/img/arrowDown.gif create mode 100644 resources/JUnitReport/img/arrowUp.gif create mode 100644 resources/JUnitReport/index.html create mode 100644 resources/JUnitReport/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/js/highlight.min.js create mode 100644 resources/JUnitReport/js/highlightjs-line-numbers.min.js create mode 100644 resources/JUnitReport/ns-1/index.html create mode 100644 resources/JUnitReport/ns-1/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-1/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-1/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-1/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-1/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-1/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-1/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-1/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-1/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-1/sources/source-1.html create mode 100644 resources/JUnitReport/ns-2/index.html create mode 100644 resources/JUnitReport/ns-2/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-2/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-2/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-2/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-2/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-2/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-2/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-2/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-2/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-2/sources/source-1.html create mode 100644 resources/JUnitReport/ns-2/sources/source-2.html create mode 100644 resources/JUnitReport/ns-2/sources/source-3.html create mode 100644 resources/JUnitReport/ns-2/sources/source-4.html create mode 100644 resources/JUnitReport/ns-2/sources/source-5.html create mode 100644 resources/JUnitReport/ns-2/sources/source-6.html create mode 100644 resources/JUnitReport/ns-3/index.html create mode 100644 resources/JUnitReport/ns-3/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-3/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-3/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-3/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-3/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-3/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-3/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-3/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-3/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-3/sources/source-1.html create mode 100644 resources/JUnitReport/ns-3/sources/source-2.html create mode 100644 resources/JUnitReport/ns-3/sources/source-3.html create mode 100644 resources/JUnitReport/ns-3/sources/source-4.html create mode 100644 resources/JUnitReport/ns-4/index.html create mode 100644 resources/JUnitReport/ns-4/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-4/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-4/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-4/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-4/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-4/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-4/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-4/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-4/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-4/sources/source-1.html create mode 100644 resources/JUnitReport/ns-5/index.html create mode 100644 resources/JUnitReport/ns-5/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-5/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-5/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-5/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-5/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-5/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-5/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-5/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-5/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-5/sources/source-1.html create mode 100644 resources/JUnitReport/ns-6/index.html create mode 100644 resources/JUnitReport/ns-6/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-6/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-6/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-6/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-6/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-6/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-6/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-6/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-6/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-6/sources/source-1.html create mode 100644 resources/JUnitReport/ns-7/index.html create mode 100644 resources/JUnitReport/ns-7/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-7/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-7/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-7/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-7/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-7/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-7/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-7/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-7/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-7/sources/source-1.html create mode 100644 resources/JUnitReport/ns-7/sources/source-2.html create mode 100644 resources/JUnitReport/ns-7/sources/source-3.html create mode 100644 resources/JUnitReport/ns-7/sources/source-4.html create mode 100644 resources/JUnitReport/ns-8/index.html create mode 100644 resources/JUnitReport/ns-8/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-8/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-8/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-8/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-8/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-8/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-8/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-8/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-8/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-8/sources/source-1.html create mode 100644 resources/JUnitReport/ns-9/index.html create mode 100644 resources/JUnitReport/ns-9/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-9/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-9/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-9/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-9/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-9/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-9/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-9/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-9/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-9/sources/source-1.html create mode 100644 resources/JUnitReport/ns-9/sources/source-2.html create mode 100644 resources/JUnitReport/ns-9/sources/source-3.html create mode 100644 resources/JUnitReport/ns-9/sources/source-4.html create mode 100644 resources/JUnitReport/ns-9/sources/source-5.html create mode 100644 resources/JUnitReport/ns-a/index.html create mode 100644 resources/JUnitReport/ns-a/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-a/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-a/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-a/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-a/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-a/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-a/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-a/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-a/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-a/sources/source-1.html create mode 100644 resources/JUnitReport/ns-a/sources/source-2.html create mode 100644 resources/JUnitReport/ns-a/sources/source-3.html create mode 100644 resources/JUnitReport/ns-b/index.html create mode 100644 resources/JUnitReport/ns-b/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-b/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-b/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-b/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-b/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-b/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-b/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-b/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-b/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-b/sources/source-1.html create mode 100644 resources/JUnitReport/ns-b/sources/source-2.html create mode 100644 resources/JUnitReport/ns-c/index.html create mode 100644 resources/JUnitReport/ns-c/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-c/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-c/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-c/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-c/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-c/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-c/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-c/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-c/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-c/sources/source-1.html create mode 100644 resources/JUnitReport/ns-c/sources/source-2.html create mode 100644 resources/JUnitReport/ns-d/index.html create mode 100644 resources/JUnitReport/ns-d/index_SORT_BY_BLOCK.html create mode 100644 resources/JUnitReport/ns-d/index_SORT_BY_BLOCK_DESC.html create mode 100644 resources/JUnitReport/ns-d/index_SORT_BY_CLASS.html create mode 100644 resources/JUnitReport/ns-d/index_SORT_BY_CLASS_DESC.html create mode 100644 resources/JUnitReport/ns-d/index_SORT_BY_LINE.html create mode 100644 resources/JUnitReport/ns-d/index_SORT_BY_LINE_DESC.html create mode 100644 resources/JUnitReport/ns-d/index_SORT_BY_METHOD.html create mode 100644 resources/JUnitReport/ns-d/index_SORT_BY_METHOD_DESC.html create mode 100644 resources/JUnitReport/ns-d/index_SORT_BY_NAME_DESC.html create mode 100644 resources/JUnitReport/ns-d/sources/source-1.html create mode 100644 resources/JUnitReport/ns-d/sources/source-2.html diff --git a/matcher/src/main/java/com/profile/matcher/service/PlayerService.java b/matcher/src/main/java/com/profile/matcher/service/PlayerService.java index 019b279..171c5a7 100644 --- a/matcher/src/main/java/com/profile/matcher/service/PlayerService.java +++ b/matcher/src/main/java/com/profile/matcher/service/PlayerService.java @@ -15,6 +15,7 @@ import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; +import java.util.Collections; import java.util.List; import java.util.Optional; import java.util.UUID; @@ -85,9 +86,12 @@ public Optional getPlayerDetails(String idPlayer) { * @return */ public static boolean checkNewCampaignForPlayer(Player player, CampaignDto campaignDto) { - return player.getCampaigns() - .stream() - .noneMatch(campaign -> campaign.getName().equals(campaignDto.getName())); + if (!CollectionUtils.isEmpty(player.getCampaigns())) { + return player.getCampaigns() + .stream() + .noneMatch(campaign -> campaign.getName().equals(campaignDto.getName())); + } + return true; } /** @@ -111,40 +115,58 @@ public static boolean matchCurrentCampaign(Player player, CampaignDto campaign) * */ private static final BiPredicate matchLevel = (player, campaign) -> { - int playerLevel = player.getLevel(); - int minLevel = campaign.getMatchers().getLevel().getMin(); - int maxLevel = campaign.getMatchers().getLevel().getMax(); - - return playerLevel >= minLevel && playerLevel <= maxLevel; + if (null != player.getLevel()) { + int playerLevel = player.getLevel(); + ; + int minLevel = campaign.getMatchers() != null && campaign.getMatchers().getLevel() != null ? + campaign.getMatchers().getLevel().getMin() : Integer.MAX_VALUE; + int maxLevel = campaign.getMatchers() != null && campaign.getMatchers().getLevel() != null ? + campaign.getMatchers().getLevel().getMax() : Integer.MIN_VALUE; + + return playerLevel >= minLevel && playerLevel <= maxLevel; + } + return false; }; /** * */ private static final BiPredicate matchCountry = (player, campaign) -> { - String playerCountry = player.getCountry(); - List campaignCountries = campaign.getMatchers().getHas().getCountry(); + if (null != player.getCountry()) { + String playerCountry = player.getCountry(); + List campaignCountries = null != campaign.getMatchers() && null != campaign.getMatchers().getHas() ? + campaign.getMatchers().getHas().getCountry() : Collections.emptyList(); - return campaignCountries.contains(playerCountry); + return campaignCountries.contains(playerCountry); + } + return false; }; /** * */ private static final BiPredicate matchItems = (player, campaign) -> { - List playerItems = player.getInventory().getItems(); - List campaignItems = campaign.getMatchers().getHas().getItems(); + if (null != player.getInventory() && !CollectionUtils.isEmpty(player.getInventory().getItems())) { + List playerItems = player.getInventory().getItems(); + List campaignItems = null != campaign.getMatchers() && null != campaign.getMatchers().getHas() ? + campaign.getMatchers().getHas().getItems() : Collections.emptyList(); - return playerItems.stream().map(Item::getName).anyMatch(campaignItems::contains); + return playerItems.stream().map(Item::getName).anyMatch(campaignItems::contains); + } + return false; }; /** * */ private static final BiPredicate matchDoesNotHaveItems = (player, campaign) -> { - List playerItems = player.getInventory().getItems(); - List campaignDoesNotHaveItems = campaign.getMatchers().getDoesNotHave().getItems(); + if (null != player.getInventory() && !CollectionUtils.isEmpty(player.getInventory().getItems())) { + List playerItems = player.getInventory().getItems(); + List campaignDoesNotHaveItems = null != campaign.getMatchers() && null != campaign.getMatchers().getDoesNotHave() ? + campaign.getMatchers().getDoesNotHave().getItems() : Collections.emptyList(); - return playerItems.stream().map(Item::getName).noneMatch(campaignDoesNotHaveItems::contains); + return playerItems.stream().map(Item::getName).noneMatch(campaignDoesNotHaveItems::contains); + } + return false; }; } diff --git a/matcher/src/test/java/com/profile/matcher/assembler/PlayerAssemblerTest.java b/matcher/src/test/java/com/profile/matcher/assembler/PlayerAssemblerTest.java new file mode 100644 index 0000000..1f8dad6 --- /dev/null +++ b/matcher/src/test/java/com/profile/matcher/assembler/PlayerAssemblerTest.java @@ -0,0 +1,56 @@ +package com.profile.matcher.assembler; + +import com.profile.matcher.dto.player.ClanDto; +import com.profile.matcher.dto.player.DeviceDto; +import com.profile.matcher.entity.campaign.Campaign; +import com.profile.matcher.entity.player.Clan; +import com.profile.matcher.entity.player.Device; +import com.profile.matcher.entity.player.Inventory; +import com.profile.matcher.entity.player.Player; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.mockito.InjectMocks; +import org.mockito.Mock; +import org.mockito.MockitoAnnotations; + +import java.util.Collections; +import java.util.HashMap; + +import static org.junit.jupiter.api.Assertions.assertNotNull; +import static org.mockito.Mockito.when; + +public class PlayerAssemblerTest { + + @InjectMocks + private PlayerAssembler assembler; + + @Mock + private DeviceAssembler deviceAssembler; + @Mock + private InventoryAssembler inventoryAssembler; + @Mock + private ClanAssembler clanAssembler; + + @BeforeEach + public void setUp() { + assembler = new PlayerAssembler(); + MockitoAnnotations.initMocks(this); + } + + @Test + void toResourceTest() { + Player player = new Player(); + player.setClan(new Clan()); + player.setDevices(Collections.singletonList(new Device())); + player.setInventory(new Inventory()); + Campaign campaign = new Campaign(); + campaign.setName("mygame"); + player.setCampaigns(Collections.singletonList(campaign)); + + when(deviceAssembler.toCollectionResource(player.getDevices())).thenReturn(Collections.singletonList(new DeviceDto())); + when(inventoryAssembler.toResource(player.getInventory())).thenReturn(new HashMap<>(Collections.singletonMap("item_22", "34"))); + when(clanAssembler.toResource(player.getClan())).thenReturn(new ClanDto()); + + assertNotNull(assembler.toResource(player)); + } +} diff --git a/matcher/src/test/java/com/profile/matcher/command/PlayerCommandTest.java b/matcher/src/test/java/com/profile/matcher/command/PlayerCommandTest.java new file mode 100644 index 0000000..37786e3 --- /dev/null +++ b/matcher/src/test/java/com/profile/matcher/command/PlayerCommandTest.java @@ -0,0 +1,36 @@ +package com.profile.matcher.command; + +import com.profile.matcher.entity.player.Player; +import com.profile.matcher.service.PlayerService; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.mockito.InjectMocks; +import org.mockito.Mock; +import org.mockito.MockitoAnnotations; + +import java.util.Optional; + +import static org.junit.jupiter.api.Assertions.assertNotNull; +import static org.mockito.Mockito.when; + +public class PlayerCommandTest { + @InjectMocks + private PlayerCommand command; + + @Mock + private PlayerService playerService; + + private final String idPlayer = "test"; + + @BeforeEach + public void setUp() { + command = new PlayerCommand(idPlayer); + MockitoAnnotations.initMocks(this); + } + + @Test + public void doExecuteTest() { + when(playerService.getPlayerDetails(idPlayer)).thenReturn(Optional.of(new Player())); + assertNotNull(command.doExecute()); + } +} diff --git a/matcher/src/test/java/com/profile/matcher/controller/PlayerControllerTest.java b/matcher/src/test/java/com/profile/matcher/controller/PlayerControllerTest.java new file mode 100644 index 0000000..bcbc1da --- /dev/null +++ b/matcher/src/test/java/com/profile/matcher/controller/PlayerControllerTest.java @@ -0,0 +1,84 @@ +package com.profile.matcher.controller; + +import com.profile.matcher.assembler.PlayerAssembler; +import com.profile.matcher.command.PlayerCommand; +import com.profile.matcher.dto.campaign.CampaignDto; +import com.profile.matcher.dto.player.ClanDto; +import com.profile.matcher.dto.player.DeviceDto; +import com.profile.matcher.dto.player.PlayerDto; +import com.profile.matcher.entity.campaign.Campaign; +import com.profile.matcher.entity.player.Clan; +import com.profile.matcher.entity.player.Device; +import com.profile.matcher.entity.player.Inventory; +import com.profile.matcher.entity.player.Player; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.mockito.InjectMocks; +import org.mockito.Mock; +import org.mockito.MockitoAnnotations; +import org.springframework.beans.factory.BeanFactory; +import org.springframework.http.ResponseEntity; + +import java.util.Collections; +import java.util.Objects; +import java.util.Optional; + +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; +import static org.mockito.Mockito.when; + +public class PlayerControllerTest { + @InjectMocks + private PlayerController controller; + + @Mock + private PlayerAssembler playerAssembler; + + @Mock + private PlayerCommand playerCommand; + + @Mock + protected BeanFactory beanFactory; + + @BeforeEach + public void setUp() { + controller = new PlayerController(); + MockitoAnnotations.initMocks(this); + } + + @Test + public void getClientConfigTest() { + Player player = new Player(); + player.setClan(new Clan()); + player.setDevices(Collections.singletonList(new Device())); + player.setInventory(new Inventory()); + Campaign campaign = new Campaign(); + campaign.setName("mygame"); + player.setCampaigns(Collections.singletonList(campaign)); + + PlayerDto playerDto = new PlayerDto(); + playerDto.setClan(new ClanDto()); + playerDto.setDevices(Collections.singletonList(new DeviceDto())); + playerDto.setInventory(Collections.singletonMap("item_22", "45")); + CampaignDto campaignDto = new CampaignDto(); + campaignDto.setName("mygame"); + playerDto.setActive_campaigns(Collections.singletonList(campaignDto.getName())); + + when(beanFactory.getBean(PlayerCommand.class, "test")).thenReturn(playerCommand); + when(playerCommand.execute()).thenReturn(Optional.of(player)); + when(playerAssembler.toResource(player)).thenReturn(playerDto); + + ResponseEntity playerDtoResponseEntity = controller.getClientConfig("test"); + assertNotNull(playerDtoResponseEntity); + assertEquals(Objects.requireNonNull(playerDtoResponseEntity.getBody()).getActive_campaigns(), playerDto.getActive_campaigns()); + } + + @Test + public void getClientConfigTest_EmptyResponse() { + when(beanFactory.getBean(PlayerCommand.class, "test")).thenReturn(playerCommand); + when(playerCommand.execute()).thenReturn(Optional.empty()); + + ResponseEntity playerDtoResponseEntity = controller.getClientConfig("test"); + assertNotNull(playerDtoResponseEntity); + } +} diff --git a/matcher/src/test/java/com/profile/matcher/service/CampaignServiceTest.java b/matcher/src/test/java/com/profile/matcher/service/CampaignServiceTest.java new file mode 100644 index 0000000..122b1b0 --- /dev/null +++ b/matcher/src/test/java/com/profile/matcher/service/CampaignServiceTest.java @@ -0,0 +1,39 @@ +package com.profile.matcher.service; + +import com.profile.matcher.dto.campaign.CampaignDto; +import com.profile.matcher.repository.CampaignRepository; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.mockito.InjectMocks; +import org.mockito.Mock; +import org.mockito.MockitoAnnotations; + +import java.util.List; + +import static org.junit.jupiter.api.Assertions.assertNotNull; + +public class CampaignServiceTest { + @InjectMocks + private CampaignService service; + + @Mock + private CampaignRepository campaignRepository; + + @BeforeEach + public void setUp() { + service = new CampaignService(); + MockitoAnnotations.initMocks(this); + } + + @Test + public void getCurrentCampaignsMockedServiceTest() { + List response = service.getCurrentCampaignsMockedService(); + assertNotNull(response); + } + + @Test + public void getCurrentCampaignsRealServiceTest() { + List response = service.getCurrentCampaignsRealService(); + assertNotNull(response); + } +} diff --git a/matcher/src/test/java/com/profile/matcher/service/PlayerServiceTest.java b/matcher/src/test/java/com/profile/matcher/service/PlayerServiceTest.java new file mode 100644 index 0000000..e145858 --- /dev/null +++ b/matcher/src/test/java/com/profile/matcher/service/PlayerServiceTest.java @@ -0,0 +1,103 @@ +package com.profile.matcher.service; + +import com.profile.matcher.dto.campaign.CampaignDto; +import com.profile.matcher.entity.player.*; +import com.profile.matcher.repository.PlayerRepository; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.mockito.InjectMocks; +import org.mockito.Mock; +import org.mockito.MockitoAnnotations; + +import java.util.Collections; +import java.util.Optional; +import java.util.UUID; + +import static org.junit.jupiter.api.Assertions.*; +import static org.mockito.Mockito.when; + +public class PlayerServiceTest { + @InjectMocks + private PlayerService service; + + @Mock + private CampaignService campaignService; + @Mock + private PlayerRepository playerRepository; + + @BeforeEach + public void setUp() { + service = new PlayerService(); + MockitoAnnotations.initMocks(this); + } + + @Test + public void getPlayerDetailsTest() { + Player player = new Player(); + player.setClan(new Clan()); + player.setDevices(Collections.singletonList(new Device())); + player.setInventory(new Inventory()); + + CampaignDto campaignDto = new CampaignDto(); + campaignDto.setName("mygame"); + + when(campaignService.getCurrentCampaignsMockedService()).thenReturn(Collections.singletonList(campaignDto)); + when(playerRepository.findByIdPlayer(UUID.fromString("37483be2-98b7-11e7-90cf-082e5f28d836"))).thenReturn(Optional.of(player)); + + Optional response = service.getPlayerDetails("37483be2-98b7-11e7-90cf-082e5f28d836"); + assertNotNull(response); + } + + @Test + public void getPlayerDetailsTest_Matchers() { + Player player = new Player(); + player.setClan(new Clan()); + player.setDevices(Collections.singletonList(new Device())); + Inventory inventory = new Inventory(); + Item item = new Item(); + item.setName("item_1"); + inventory.setItems(Collections.singletonList(item)); + player.setInventory(inventory); + player.setLevel(3); + player.setCountry("RO"); + + CampaignDto campaignDto = new CampaignDto(); + campaignDto.setName("mygame"); + CampaignDto.Matchers matchers = new CampaignDto.Matchers(); + CampaignDto.Matchers.Range range = new CampaignDto.Matchers.Range(); + range.setMax(3); + range.setMin(1); + matchers.setLevel(range); + CampaignDto.Matchers.Has has = new CampaignDto.Matchers.Has(); + has.setCountry(Collections.singletonList("RO")); + has.setItems(Collections.singletonList("item_1")); + matchers.setHas(has); + CampaignDto.Matchers.DoesNotHave doesNotHave = new CampaignDto.Matchers.DoesNotHave(); + doesNotHave.setItems(Collections.singletonList("item_4")); + matchers.setDoesNotHave(doesNotHave); + campaignDto.setMatchers(matchers); + + when(campaignService.getCurrentCampaignsMockedService()).thenReturn(Collections.singletonList(campaignDto)); + when(playerRepository.findByIdPlayer(UUID.fromString("37483be2-98b7-11e7-90cf-082e5f28d836"))).thenReturn(Optional.of(player)); + + Optional optionalPlayer = service.getPlayerDetails("37483be2-98b7-11e7-90cf-082e5f28d836"); + assertNotNull(optionalPlayer); + Player responsePlayer = optionalPlayer.orElse(new Player()); + assertEquals(responsePlayer.getLevel(), player.getLevel()); + } + + @Test + public void getPlayerDetailsTest_PlayerException() { + when(playerRepository.findByIdPlayer(UUID.fromString("37483be2-98b7-11e7-90cf-082e5f28d836"))).thenThrow(new RuntimeException("Player not found")); + + assertThrows(Exception.class, () -> service.getPlayerDetails("37483be2-98b7-11e7-90cf-082e5f28d836")); + } + + @Test + public void getPlayerDetailsTest_CampaignException() { + when(playerRepository.findByIdPlayer(UUID.fromString("37483be2-98b7-11e7-90cf-082e5f28d836"))).thenReturn(Optional.of(new Player())); + when(campaignService.getCurrentCampaignsMockedService()).thenThrow(new RuntimeException("Current campaign not found")); + + assertThrows(Exception.class, () -> service.getPlayerDetails("37483be2-98b7-11e7-90cf-082e5f28d836")); + } +} diff --git a/resources/JUnitReport/css/coverage.css b/resources/JUnitReport/css/coverage.css new file mode 100644 index 0000000..cef7765 --- /dev/null +++ b/resources/JUnitReport/css/coverage.css @@ -0,0 +1,154 @@ +/* + * Copyright 2000-2021 JetBrains s.r.o. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +* { + margin: 0; + padding: 0; +} + +body { + background-color: #fff; + font-family: helvetica neue, tahoma, arial, sans-serif; + font-size: 82%; + color: #151515; +} + +h1 { + margin: 0.5em 0; + color: #010101; + font-weight: normal; + font-size: 18px; +} + +h2 { + margin: 0.5em 0; + color: #010101; + font-weight: normal; + font-size: 16px; +} + +a { + color: #1564C2; + text-decoration: none; +} + +a:hover { + text-decoration: underline; +} + +span.separator { + color: #9BA9BA; + padding-left: 5px; + padding-right: 5px; +} + +div.content { + width: 99%; +} + +table.coverageStats { + width: 100%; + border-collapse: collapse; +} + +table.overallStats { + width: 20%; +} + +table.coverageStats td, table.coverageStats th { + padding: 4px 2px; + border-bottom: 1px solid #ccc; +} + +table.coverageStats th { + background-color: #959BA4; + border: none; + font-weight: bold; + text-align: left; + color: #FFF; +} + +table.coverageStats th.coverageStat { + width: 15%; +} + +table.coverageStats th a { + color: #FFF; +} + +table.coverageStats th a:hover { + text-decoration: none; +} + +table.coverageStats th.sortedDesc a { + background: url(../img/arrowDown.gif) no-repeat 100% 2px; + padding-right: 20px; +} + +table.coverageStats th.sortedAsc a { + background: url(../img/arrowUp.gif) no-repeat 100% 2px; + padding-right: 20px; +} + +div.footer { + margin: 2em .5em; + font-size: 85%; + text-align: left; + line-height: 140%; +} + +code.sourceCode { + width: 100%; + border: 1px solid #ccc; + font: normal 12px 'Menlo', 'Bitstream Vera Sans Mono', 'Courier New', 'Courier', monospace; + white-space: pre; +} + +code.sourceCode b { + font-weight: normal; +} + +code.sourceCode span.number { + color: #151515; +} + +code.sourceCode .fc { + background-color: #cfc; +} + +code.sourceCode .pc { + background-color: #ffc; +} + +code.sourceCode .nc { + background-color: #fcc; +} + +.percent, .absValue { + font-size: 90%; +} + +.percent .green, .absValue .green { + color: #32cc32; +} + +.percent .red, .absValue .red { + color: #f00; +} + +.percent .totalDiff { + color: #3f3f3f; +} diff --git a/resources/JUnitReport/css/idea.min.css b/resources/JUnitReport/css/idea.min.css new file mode 100644 index 0000000..a8d5292 --- /dev/null +++ b/resources/JUnitReport/css/idea.min.css @@ -0,0 +1,118 @@ +/* + * Copyright 2000-2021 JetBrains s.r.o. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* +Intellij Idea-like styling (c) Vasily Polovnyov +*/ + +.hljs { + color: #000; + background: #fff; +} + +.hljs-subst, +.hljs-title { + font-weight: normal; + color: #000; +} + +.hljs-comment, +.hljs-quote { + color: #808080; + font-style: italic; +} + +.hljs-meta { + color: #808000; +} + +.hljs-tag { + background: #efefef; +} + +.hljs-section, +.hljs-name, +.hljs-literal, +.hljs-keyword, +.hljs-selector-tag, +.hljs-type, +.hljs-selector-id, +.hljs-selector-class { + font-weight: bold; + color: #000080; +} + +.hljs-attribute, +.hljs-number, +.hljs-regexp, +.hljs-link { + font-weight: bold; + color: #0000ff; +} + +.hljs-number, +.hljs-regexp, +.hljs-link { + font-weight: normal; +} + +.hljs-string { + color: #008000; + font-weight: bold; +} + +.hljs-symbol, +.hljs-bullet, +.hljs-formula { + color: #000; + background: #d0eded; + font-style: italic; +} + +.hljs-doctag { + text-decoration: underline; +} + +.hljs-variable, +.hljs-template-variable { + color: #660e7a; +} + +.hljs-addition { + background: #baeeba; +} + +.hljs-deletion { + background: #ffc8bd; +} + +.hljs-emphasis { + font-style: italic; +} + +.hljs-strong { + font-weight: bold; +} + +.hljs-ln-numbers { + display: block; + float: left; + width: 3em; + border-right: 1px solid #ccc; + font-style: normal; + text-align: right; + background-color: #eee; +} diff --git a/resources/JUnitReport/img/arrowDown.gif b/resources/JUnitReport/img/arrowDown.gif new file mode 100644 index 0000000000000000000000000000000000000000..a4ac9b4b0f5eee9fc82deb7f03d0cc7f197b01c7 GIT binary patch literal 89 zcmZ?wbhEHbv%yJ&P?))?G g5?!@7agD+*@rGjs@joUks8}}Ha%HfNHz$KN0Orjd82|tP literal 0 HcmV?d00001 diff --git a/resources/JUnitReport/img/arrowUp.gif b/resources/JUnitReport/img/arrowUp.gif new file mode 100644 index 0000000000000000000000000000000000000000..d488db0089f15409b83a6f39718384cac89ea3c9 GIT binary patch literal 91 zcmZ?wbhEHbv%nBa6?))=2 j#jeJ<$W6!S$=vG=3s*2Wu3C5I!M+a(XH6zEFjxZs9OxeQ literal 0 HcmV?d00001 diff --git a/resources/JUnitReport/index.html b/resources/JUnitReport/index.html new file mode 100644 index 0000000..0f55621 --- /dev/null +++ b/resources/JUnitReport/index.html @@ -0,0 +1,439 @@ + + + + + + + Coverage Report > Summary + + + + + + +
+ + +

Overall Coverage Summary

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
all classes + + 89.2% + + + (33/37) + + + + 62.1% + + + (128/206) + + + + 62.2% + + + (245/394) + +
+ +
+

Coverage Breakdown

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+
+ + + + + + + diff --git a/resources/JUnitReport/index_SORT_BY_BLOCK.html b/resources/JUnitReport/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..10ee4d8 --- /dev/null +++ b/resources/JUnitReport/index_SORT_BY_BLOCK.html @@ -0,0 +1,439 @@ + + + + + + + Coverage Report > Summary + + + + + + +
+ + +

Overall Coverage Summary

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
all classes + + 89.2% + + + (33/37) + + + + 62.1% + + + (128/206) + + + + 62.2% + + + (245/394) + +
+ +
+

Coverage Breakdown

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+
+ + + + + + + diff --git a/resources/JUnitReport/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..8613718 --- /dev/null +++ b/resources/JUnitReport/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,439 @@ + + + + + + + Coverage Report > Summary + + + + + + +
+ + +

Overall Coverage Summary

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
all classes + + 89.2% + + + (33/37) + + + + 62.1% + + + (128/206) + + + + 62.2% + + + (245/394) + +
+ +
+

Coverage Breakdown

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+
+ + + + + + + diff --git a/resources/JUnitReport/index_SORT_BY_CLASS.html b/resources/JUnitReport/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..d95b8b5 --- /dev/null +++ b/resources/JUnitReport/index_SORT_BY_CLASS.html @@ -0,0 +1,439 @@ + + + + + + + Coverage Report > Summary + + + + + + +
+ + +

Overall Coverage Summary

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
all classes + + 89.2% + + + (33/37) + + + + 62.1% + + + (128/206) + + + + 62.2% + + + (245/394) + +
+ +
+

Coverage Breakdown

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+
+ + + + + + + diff --git a/resources/JUnitReport/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..043d892 --- /dev/null +++ b/resources/JUnitReport/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,439 @@ + + + + + + + Coverage Report > Summary + + + + + + +
+ + +

Overall Coverage Summary

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
all classes + + 89.2% + + + (33/37) + + + + 62.1% + + + (128/206) + + + + 62.2% + + + (245/394) + +
+ +
+

Coverage Breakdown

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+
+ + + + + + + diff --git a/resources/JUnitReport/index_SORT_BY_LINE.html b/resources/JUnitReport/index_SORT_BY_LINE.html new file mode 100644 index 0000000..444c471 --- /dev/null +++ b/resources/JUnitReport/index_SORT_BY_LINE.html @@ -0,0 +1,439 @@ + + + + + + + Coverage Report > Summary + + + + + + +
+ + +

Overall Coverage Summary

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
all classes + + 89.2% + + + (33/37) + + + + 62.1% + + + (128/206) + + + + 62.2% + + + (245/394) + +
+ +
+

Coverage Breakdown

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+
+ + + + + + + diff --git a/resources/JUnitReport/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..7fee1c7 --- /dev/null +++ b/resources/JUnitReport/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,439 @@ + + + + + + + Coverage Report > Summary + + + + + + +
+ + +

Overall Coverage Summary

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
all classes + + 89.2% + + + (33/37) + + + + 62.1% + + + (128/206) + + + + 62.2% + + + (245/394) + +
+ +
+

Coverage Breakdown

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+
+ + + + + + + diff --git a/resources/JUnitReport/index_SORT_BY_METHOD.html b/resources/JUnitReport/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..b42b173 --- /dev/null +++ b/resources/JUnitReport/index_SORT_BY_METHOD.html @@ -0,0 +1,439 @@ + + + + + + + Coverage Report > Summary + + + + + + +
+ + +

Overall Coverage Summary

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
all classes + + 89.2% + + + (33/37) + + + + 62.1% + + + (128/206) + + + + 62.2% + + + (245/394) + +
+ +
+

Coverage Breakdown

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+
+ + + + + + + diff --git a/resources/JUnitReport/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..ec5181b --- /dev/null +++ b/resources/JUnitReport/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,439 @@ + + + + + + + Coverage Report > Summary + + + + + + +
+ + +

Overall Coverage Summary

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
all classes + + 89.2% + + + (33/37) + + + + 62.1% + + + (128/206) + + + + 62.2% + + + (245/394) + +
+ +
+

Coverage Breakdown

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+
+ + + + + + + diff --git a/resources/JUnitReport/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..d4a0e87 --- /dev/null +++ b/resources/JUnitReport/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,439 @@ + + + + + + + Coverage Report > Summary + + + + + + +
+ + +

Overall Coverage Summary

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
all classes + + 89.2% + + + (33/37) + + + + 62.1% + + + (128/206) + + + + 62.2% + + + (245/394) + +
+ +
+

Coverage Breakdown

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+
+ + + + + + + diff --git a/resources/JUnitReport/js/highlight.min.js b/resources/JUnitReport/js/highlight.min.js new file mode 100644 index 0000000..e887315 --- /dev/null +++ b/resources/JUnitReport/js/highlight.min.js @@ -0,0 +1,1388 @@ +/* + Highlight.js 10.7.2 (00233d63) + License: BSD-3-Clause + Copyright (c) 2006-2021, Ivan Sagalaev + + BSD 3-Clause License + + Copyright (c) 2006-2021, Ivan Sagalaev. + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + + * Neither the name of the copyright holder nor the names of its + contributors may be used to endorse or promote products derived from + this software without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE + FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER + CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, + OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +*/ +var hljs=function(){"use strict";function e(t){ +return t instanceof Map?t.clear=t.delete=t.set=()=>{ +throw Error("map is read-only")}:t instanceof Set&&(t.add=t.clear=t.delete=()=>{ +throw Error("set is read-only") +}),Object.freeze(t),Object.getOwnPropertyNames(t).forEach((n=>{var i=t[n] +;"object"!=typeof i||Object.isFrozen(i)||e(i)})),t}var t=e,n=e;t.default=n +;class i{constructor(e){ +void 0===e.data&&(e.data={}),this.data=e.data,this.isMatchIgnored=!1} +ignoreMatch(){this.isMatchIgnored=!0}}function s(e){ +return e.replace(/&/g,"&").replace(//g,">").replace(/"/g,""").replace(/'/g,"'") +}function a(e,...t){const n=Object.create(null);for(const t in e)n[t]=e[t] +;return t.forEach((e=>{for(const t in e)n[t]=e[t]})),n}const r=e=>!!e.kind +;class l{constructor(e,t){ +this.buffer="",this.classPrefix=t.classPrefix,e.walk(this)}addText(e){ +this.buffer+=s(e)}openNode(e){if(!r(e))return;let t=e.kind +;e.sublanguage||(t=`${this.classPrefix}${t}`),this.span(t)}closeNode(e){ +r(e)&&(this.buffer+="")}value(){return this.buffer}span(e){ +this.buffer+=``}}class o{constructor(){this.rootNode={ +children:[]},this.stack=[this.rootNode]}get top(){ +return this.stack[this.stack.length-1]}get root(){return this.rootNode}add(e){ +this.top.children.push(e)}openNode(e){const t={kind:e,children:[]} +;this.add(t),this.stack.push(t)}closeNode(){ +if(this.stack.length>1)return this.stack.pop()}closeAllNodes(){ +for(;this.closeNode(););}toJSON(){return JSON.stringify(this.rootNode,null,4)} +walk(e){return this.constructor._walk(e,this.rootNode)}static _walk(e,t){ +return"string"==typeof t?e.addText(t):t.children&&(e.openNode(t), +t.children.forEach((t=>this._walk(e,t))),e.closeNode(t)),e}static _collapse(e){ +"string"!=typeof e&&e.children&&(e.children.every((e=>"string"==typeof e))?e.children=[e.children.join("")]:e.children.forEach((e=>{ +o._collapse(e)})))}}class c extends o{constructor(e){super(),this.options=e} +addKeyword(e,t){""!==e&&(this.openNode(t),this.addText(e),this.closeNode())} +addText(e){""!==e&&this.add(e)}addSublanguage(e,t){const n=e.root +;n.kind=t,n.sublanguage=!0,this.add(n)}toHTML(){ +return new l(this,this.options).value()}finalize(){return!0}}function g(e){ +return e?"string"==typeof e?e:e.source:null} +const u=/\[(?:[^\\\]]|\\.)*\]|\(\??|\\([1-9][0-9]*)|\\./,h="[a-zA-Z]\\w*",d="[a-zA-Z_]\\w*",f="\\b\\d+(\\.\\d+)?",p="(-?)(\\b0[xX][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)",m="\\b(0b[01]+)",b={ +begin:"\\\\[\\s\\S]",relevance:0},E={className:"string",begin:"'",end:"'", +illegal:"\\n",contains:[b]},x={className:"string",begin:'"',end:'"', +illegal:"\\n",contains:[b]},v={ +begin:/\b(a|an|the|are|I'm|isn't|don't|doesn't|won't|but|just|should|pretty|simply|enough|gonna|going|wtf|so|such|will|you|your|they|like|more)\b/ +},w=(e,t,n={})=>{const i=a({className:"comment",begin:e,end:t,contains:[]},n) +;return i.contains.push(v),i.contains.push({className:"doctag", +begin:"(?:TODO|FIXME|NOTE|BUG|OPTIMIZE|HACK|XXX):",relevance:0}),i +},y=w("//","$"),N=w("/\\*","\\*/"),R=w("#","$");var _=Object.freeze({ +__proto__:null,MATCH_NOTHING_RE:/\b\B/,IDENT_RE:h,UNDERSCORE_IDENT_RE:d, +NUMBER_RE:f,C_NUMBER_RE:p,BINARY_NUMBER_RE:m, +RE_STARTERS_RE:"!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|-|-=|/=|/|:|;|<<|<<=|<=|<|===|==|=|>>>=|>>=|>=|>>>|>>|>|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~", +SHEBANG:(e={})=>{const t=/^#![ ]*\// +;return e.binary&&(e.begin=((...e)=>e.map((e=>g(e))).join(""))(t,/.*\b/,e.binary,/\b.*/)), +a({className:"meta",begin:t,end:/$/,relevance:0,"on:begin":(e,t)=>{ +0!==e.index&&t.ignoreMatch()}},e)},BACKSLASH_ESCAPE:b,APOS_STRING_MODE:E, +QUOTE_STRING_MODE:x,PHRASAL_WORDS_MODE:v,COMMENT:w,C_LINE_COMMENT_MODE:y, +C_BLOCK_COMMENT_MODE:N,HASH_COMMENT_MODE:R,NUMBER_MODE:{className:"number", +begin:f,relevance:0},C_NUMBER_MODE:{className:"number",begin:p,relevance:0}, +BINARY_NUMBER_MODE:{className:"number",begin:m,relevance:0},CSS_NUMBER_MODE:{ +className:"number", +begin:f+"(%|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc|px|deg|grad|rad|turn|s|ms|Hz|kHz|dpi|dpcm|dppx)?", +relevance:0},REGEXP_MODE:{begin:/(?=\/[^/\n]*\/)/,contains:[{className:"regexp", +begin:/\//,end:/\/[gimuy]*/,illegal:/\n/,contains:[b,{begin:/\[/,end:/\]/, +relevance:0,contains:[b]}]}]},TITLE_MODE:{className:"title",begin:h,relevance:0 +},UNDERSCORE_TITLE_MODE:{className:"title",begin:d,relevance:0},METHOD_GUARD:{ +begin:"\\.\\s*[a-zA-Z_]\\w*",relevance:0},END_SAME_AS_BEGIN:e=>Object.assign(e,{ +"on:begin":(e,t)=>{t.data._beginMatch=e[1]},"on:end":(e,t)=>{ +t.data._beginMatch!==e[1]&&t.ignoreMatch()}})});function k(e,t){ +"."===e.input[e.index-1]&&t.ignoreMatch()}function M(e,t){ +t&&e.beginKeywords&&(e.begin="\\b("+e.beginKeywords.split(" ").join("|")+")(?!\\.)(?=\\b|\\s)", +e.__beforeBegin=k,e.keywords=e.keywords||e.beginKeywords,delete e.beginKeywords, +void 0===e.relevance&&(e.relevance=0))}function O(e,t){ +Array.isArray(e.illegal)&&(e.illegal=((...e)=>"("+e.map((e=>g(e))).join("|")+")")(...e.illegal)) +}function A(e,t){if(e.match){ +if(e.begin||e.end)throw Error("begin & end are not supported with match") +;e.begin=e.match,delete e.match}}function L(e,t){ +void 0===e.relevance&&(e.relevance=1)} +const I=["of","and","for","in","not","or","if","then","parent","list","value"] +;function j(e,t,n="keyword"){const i={} +;return"string"==typeof e?s(n,e.split(" ")):Array.isArray(e)?s(n,e):Object.keys(e).forEach((n=>{ +Object.assign(i,j(e[n],t,n))})),i;function s(e,n){ +t&&(n=n.map((e=>e.toLowerCase()))),n.forEach((t=>{const n=t.split("|") +;i[n[0]]=[e,B(n[0],n[1])]}))}}function B(e,t){ +return t?Number(t):(e=>I.includes(e.toLowerCase()))(e)?0:1} +function T(e,{plugins:t}){function n(t,n){ +return RegExp(g(t),"m"+(e.case_insensitive?"i":"")+(n?"g":""))}class i{ +constructor(){ +this.matchIndexes={},this.regexes=[],this.matchAt=1,this.position=0} +addRule(e,t){ +t.position=this.position++,this.matchIndexes[this.matchAt]=t,this.regexes.push([t,e]), +this.matchAt+=(e=>RegExp(e.toString()+"|").exec("").length-1)(e)+1}compile(){ +0===this.regexes.length&&(this.exec=()=>null) +;const e=this.regexes.map((e=>e[1]));this.matcherRe=n(((e,t="|")=>{let n=0 +;return e.map((e=>{n+=1;const t=n;let i=g(e),s="";for(;i.length>0;){ +const e=u.exec(i);if(!e){s+=i;break} +s+=i.substring(0,e.index),i=i.substring(e.index+e[0].length), +"\\"===e[0][0]&&e[1]?s+="\\"+(Number(e[1])+t):(s+=e[0],"("===e[0]&&n++)}return s +})).map((e=>`(${e})`)).join(t)})(e),!0),this.lastIndex=0}exec(e){ +this.matcherRe.lastIndex=this.lastIndex;const t=this.matcherRe.exec(e) +;if(!t)return null +;const n=t.findIndex(((e,t)=>t>0&&void 0!==e)),i=this.matchIndexes[n] +;return t.splice(0,n),Object.assign(t,i)}}class s{constructor(){ +this.rules=[],this.multiRegexes=[], +this.count=0,this.lastIndex=0,this.regexIndex=0}getMatcher(e){ +if(this.multiRegexes[e])return this.multiRegexes[e];const t=new i +;return this.rules.slice(e).forEach((([e,n])=>t.addRule(e,n))), +t.compile(),this.multiRegexes[e]=t,t}resumingScanAtSamePosition(){ +return 0!==this.regexIndex}considerAll(){this.regexIndex=0}addRule(e,t){ +this.rules.push([e,t]),"begin"===t.type&&this.count++}exec(e){ +const t=this.getMatcher(this.regexIndex);t.lastIndex=this.lastIndex +;let n=t.exec(e) +;if(this.resumingScanAtSamePosition())if(n&&n.index===this.lastIndex);else{ +const t=this.getMatcher(0);t.lastIndex=this.lastIndex+1,n=t.exec(e)} +return n&&(this.regexIndex+=n.position+1, +this.regexIndex===this.count&&this.considerAll()),n}} +if(e.compilerExtensions||(e.compilerExtensions=[]), +e.contains&&e.contains.includes("self"))throw Error("ERR: contains `self` is not supported at the top-level of a language. See documentation.") +;return e.classNameAliases=a(e.classNameAliases||{}),function t(i,r){const l=i +;if(i.isCompiled)return l +;[A].forEach((e=>e(i,r))),e.compilerExtensions.forEach((e=>e(i,r))), +i.__beforeBegin=null,[M,O,L].forEach((e=>e(i,r))),i.isCompiled=!0;let o=null +;if("object"==typeof i.keywords&&(o=i.keywords.$pattern, +delete i.keywords.$pattern), +i.keywords&&(i.keywords=j(i.keywords,e.case_insensitive)), +i.lexemes&&o)throw Error("ERR: Prefer `keywords.$pattern` to `mode.lexemes`, BOTH are not allowed. (see mode reference) ") +;return o=o||i.lexemes||/\w+/, +l.keywordPatternRe=n(o,!0),r&&(i.begin||(i.begin=/\B|\b/), +l.beginRe=n(i.begin),i.endSameAsBegin&&(i.end=i.begin), +i.end||i.endsWithParent||(i.end=/\B|\b/), +i.end&&(l.endRe=n(i.end)),l.terminatorEnd=g(i.end)||"", +i.endsWithParent&&r.terminatorEnd&&(l.terminatorEnd+=(i.end?"|":"")+r.terminatorEnd)), +i.illegal&&(l.illegalRe=n(i.illegal)), +i.contains||(i.contains=[]),i.contains=[].concat(...i.contains.map((e=>(e=>(e.variants&&!e.cachedVariants&&(e.cachedVariants=e.variants.map((t=>a(e,{ +variants:null},t)))),e.cachedVariants?e.cachedVariants:S(e)?a(e,{ +starts:e.starts?a(e.starts):null +}):Object.isFrozen(e)?a(e):e))("self"===e?i:e)))),i.contains.forEach((e=>{t(e,l) +})),i.starts&&t(i.starts,r),l.matcher=(e=>{const t=new s +;return e.contains.forEach((e=>t.addRule(e.begin,{rule:e,type:"begin" +}))),e.terminatorEnd&&t.addRule(e.terminatorEnd,{type:"end" +}),e.illegal&&t.addRule(e.illegal,{type:"illegal"}),t})(l),l}(e)}function S(e){ +return!!e&&(e.endsWithParent||S(e.starts))}function P(e){const t={ +props:["language","code","autodetect"],data:()=>({detectedLanguage:"", +unknownLanguage:!1}),computed:{className(){ +return this.unknownLanguage?"":"hljs "+this.detectedLanguage},highlighted(){ +if(!this.autoDetect&&!e.getLanguage(this.language))return console.warn(`The language "${this.language}" you specified could not be found.`), +this.unknownLanguage=!0,s(this.code);let t={} +;return this.autoDetect?(t=e.highlightAuto(this.code), +this.detectedLanguage=t.language):(t=e.highlight(this.language,this.code,this.ignoreIllegals), +this.detectedLanguage=this.language),t.value},autoDetect(){ +return!(this.language&&(e=this.autodetect,!e&&""!==e));var e}, +ignoreIllegals:()=>!0},render(e){return e("pre",{},[e("code",{ +class:this.className,domProps:{innerHTML:this.highlighted}})])}};return{ +Component:t,VuePlugin:{install(e){e.component("highlightjs",t)}}}}const D={ +"after:highlightElement":({el:e,result:t,text:n})=>{const i=H(e) +;if(!i.length)return;const a=document.createElement("div") +;a.innerHTML=t.value,t.value=((e,t,n)=>{let i=0,a="";const r=[];function l(){ +return e.length&&t.length?e[0].offset!==t[0].offset?e[0].offset"}function c(e){ +a+=""}function g(e){("start"===e.event?o:c)(e.node)} +for(;e.length||t.length;){let t=l() +;if(a+=s(n.substring(i,t[0].offset)),i=t[0].offset,t===e){r.reverse().forEach(c) +;do{g(t.splice(0,1)[0]),t=l()}while(t===e&&t.length&&t[0].offset===i) +;r.reverse().forEach(o) +}else"start"===t[0].event?r.push(t[0].node):r.pop(),g(t.splice(0,1)[0])} +return a+s(n.substr(i))})(i,H(a),n)}};function C(e){ +return e.nodeName.toLowerCase()}function H(e){const t=[];return function e(n,i){ +for(let s=n.firstChild;s;s=s.nextSibling)3===s.nodeType?i+=s.nodeValue.length:1===s.nodeType&&(t.push({ +event:"start",offset:i,node:s}),i=e(s,i),C(s).match(/br|hr|img|input/)||t.push({ +event:"stop",offset:i,node:s}));return i}(e,0),t}const $={},U=e=>{ +console.error(e)},z=(e,...t)=>{console.log("WARN: "+e,...t)},K=(e,t)=>{ +$[`${e}/${t}`]||(console.log(`Deprecated as of ${e}. ${t}`),$[`${e}/${t}`]=!0) +},G=s,V=a,W=Symbol("nomatch");return(e=>{ +const n=Object.create(null),s=Object.create(null),a=[];let r=!0 +;const l=/(^(<[^>]+>|\t|)+|\n)/gm,o="Could not find the language '{}', did you forget to load/include a language module?",g={ +disableAutodetect:!0,name:"Plain text",contains:[]};let u={ +noHighlightRe:/^(no-?highlight)$/i, +languageDetectRe:/\blang(?:uage)?-([\w-]+)\b/i,classPrefix:"hljs-", +tabReplace:null,useBR:!1,languages:null,__emitter:c};function h(e){ +return u.noHighlightRe.test(e)}function d(e,t,n,i){let s="",a="" +;"object"==typeof t?(s=e, +n=t.ignoreIllegals,a=t.language,i=void 0):(K("10.7.0","highlight(lang, code, ...args) has been deprecated."), +K("10.7.0","Please use highlight(code, options) instead.\nhttps://github.com/highlightjs/highlight.js/issues/2277"), +a=e,s=t);const r={code:s,language:a};M("before:highlight",r) +;const l=r.result?r.result:f(r.language,r.code,n,i) +;return l.code=r.code,M("after:highlight",l),l}function f(e,t,s,l){ +function c(e,t){const n=v.case_insensitive?t[0].toLowerCase():t[0] +;return Object.prototype.hasOwnProperty.call(e.keywords,n)&&e.keywords[n]} +function g(){null!=R.subLanguage?(()=>{if(""===M)return;let e=null +;if("string"==typeof R.subLanguage){ +if(!n[R.subLanguage])return void k.addText(M) +;e=f(R.subLanguage,M,!0,_[R.subLanguage]),_[R.subLanguage]=e.top +}else e=p(M,R.subLanguage.length?R.subLanguage:null) +;R.relevance>0&&(O+=e.relevance),k.addSublanguage(e.emitter,e.language) +})():(()=>{if(!R.keywords)return void k.addText(M);let e=0 +;R.keywordPatternRe.lastIndex=0;let t=R.keywordPatternRe.exec(M),n="";for(;t;){ +n+=M.substring(e,t.index);const i=c(R,t);if(i){const[e,s]=i +;if(k.addText(n),n="",O+=s,e.startsWith("_"))n+=t[0];else{ +const n=v.classNameAliases[e]||e;k.addKeyword(t[0],n)}}else n+=t[0] +;e=R.keywordPatternRe.lastIndex,t=R.keywordPatternRe.exec(M)} +n+=M.substr(e),k.addText(n)})(),M=""}function h(e){ +return e.className&&k.openNode(v.classNameAliases[e.className]||e.className), +R=Object.create(e,{parent:{value:R}}),R}function d(e,t,n){let s=((e,t)=>{ +const n=e&&e.exec(t);return n&&0===n.index})(e.endRe,n);if(s){if(e["on:end"]){ +const n=new i(e);e["on:end"](t,n),n.isMatchIgnored&&(s=!1)}if(s){ +for(;e.endsParent&&e.parent;)e=e.parent;return e}} +if(e.endsWithParent)return d(e.parent,t,n)}function m(e){ +return 0===R.matcher.regexIndex?(M+=e[0],1):(I=!0,0)}function b(e){ +const n=e[0],i=t.substr(e.index),s=d(R,e,i);if(!s)return W;const a=R +;a.skip?M+=n:(a.returnEnd||a.excludeEnd||(M+=n),g(),a.excludeEnd&&(M=n));do{ +R.className&&k.closeNode(),R.skip||R.subLanguage||(O+=R.relevance),R=R.parent +}while(R!==s.parent) +;return s.starts&&(s.endSameAsBegin&&(s.starts.endRe=s.endRe), +h(s.starts)),a.returnEnd?0:n.length}let E={};function x(n,a){const l=a&&a[0] +;if(M+=n,null==l)return g(),0 +;if("begin"===E.type&&"end"===a.type&&E.index===a.index&&""===l){ +if(M+=t.slice(a.index,a.index+1),!r){const t=Error("0 width match regex") +;throw t.languageName=e,t.badRule=E.rule,t}return 1} +if(E=a,"begin"===a.type)return function(e){ +const t=e[0],n=e.rule,s=new i(n),a=[n.__beforeBegin,n["on:begin"]] +;for(const n of a)if(n&&(n(e,s),s.isMatchIgnored))return m(t) +;return n&&n.endSameAsBegin&&(n.endRe=RegExp(t.replace(/[-/\\^$*+?.()|[\]{}]/g,"\\$&"),"m")), +n.skip?M+=t:(n.excludeBegin&&(M+=t), +g(),n.returnBegin||n.excludeBegin||(M=t)),h(n),n.returnBegin?0:t.length}(a) +;if("illegal"===a.type&&!s){ +const e=Error('Illegal lexeme "'+l+'" for mode "'+(R.className||"")+'"') +;throw e.mode=R,e}if("end"===a.type){const e=b(a);if(e!==W)return e} +if("illegal"===a.type&&""===l)return 1 +;if(L>1e5&&L>3*a.index)throw Error("potential infinite loop, way more iterations than matches") +;return M+=l,l.length}const v=N(e) +;if(!v)throw U(o.replace("{}",e)),Error('Unknown language: "'+e+'"') +;const w=T(v,{plugins:a});let y="",R=l||w;const _={},k=new u.__emitter(u);(()=>{ +const e=[];for(let t=R;t!==v;t=t.parent)t.className&&e.unshift(t.className) +;e.forEach((e=>k.openNode(e)))})();let M="",O=0,A=0,L=0,I=!1;try{ +for(R.matcher.considerAll();;){ +L++,I?I=!1:R.matcher.considerAll(),R.matcher.lastIndex=A +;const e=R.matcher.exec(t);if(!e)break;const n=x(t.substring(A,e.index),e) +;A=e.index+n}return x(t.substr(A)),k.closeAllNodes(),k.finalize(),y=k.toHTML(),{ +relevance:Math.floor(O),value:y,language:e,illegal:!1,emitter:k,top:R}}catch(n){ +if(n.message&&n.message.includes("Illegal"))return{illegal:!0,illegalBy:{ +msg:n.message,context:t.slice(A-100,A+100),mode:n.mode},sofar:y,relevance:0, +value:G(t),emitter:k};if(r)return{illegal:!1,relevance:0,value:G(t),emitter:k, +language:e,top:R,errorRaised:n};throw n}}function p(e,t){ +t=t||u.languages||Object.keys(n);const i=(e=>{const t={relevance:0, +emitter:new u.__emitter(u),value:G(e),illegal:!1,top:g} +;return t.emitter.addText(e),t})(e),s=t.filter(N).filter(k).map((t=>f(t,e,!1))) +;s.unshift(i);const a=s.sort(((e,t)=>{ +if(e.relevance!==t.relevance)return t.relevance-e.relevance +;if(e.language&&t.language){if(N(e.language).supersetOf===t.language)return 1 +;if(N(t.language).supersetOf===e.language)return-1}return 0})),[r,l]=a,o=r +;return o.second_best=l,o}const m={"before:highlightElement":({el:e})=>{ +u.useBR&&(e.innerHTML=e.innerHTML.replace(/\n/g,"").replace(//g,"\n")) +},"after:highlightElement":({result:e})=>{ +u.useBR&&(e.value=e.value.replace(/\n/g,"
"))}},b=/^(<[^>]+>|\t)+/gm,E={ +"after:highlightElement":({result:e})=>{ +u.tabReplace&&(e.value=e.value.replace(b,(e=>e.replace(/\t/g,u.tabReplace))))}} +;function x(e){let t=null;const n=(e=>{let t=e.className+" " +;t+=e.parentNode?e.parentNode.className:"";const n=u.languageDetectRe.exec(t) +;if(n){const t=N(n[1]) +;return t||(z(o.replace("{}",n[1])),z("Falling back to no-highlight mode for this block.",e)), +t?n[1]:"no-highlight"}return t.split(/\s+/).find((e=>h(e)||N(e)))})(e) +;if(h(n))return;M("before:highlightElement",{el:e,language:n}),t=e +;const i=t.textContent,a=n?d(i,{language:n,ignoreIllegals:!0}):p(i) +;M("after:highlightElement",{el:e,result:a,text:i +}),e.innerHTML=a.value,((e,t,n)=>{const i=t?s[t]:n +;e.classList.add("hljs"),i&&e.classList.add(i)})(e,n,a.language),e.result={ +language:a.language,re:a.relevance,relavance:a.relevance +},a.second_best&&(e.second_best={language:a.second_best.language, +re:a.second_best.relevance,relavance:a.second_best.relevance})}const v=()=>{ +v.called||(v.called=!0, +K("10.6.0","initHighlighting() is deprecated. Use highlightAll() instead."), +document.querySelectorAll("pre code").forEach(x))};let w=!1;function y(){ +"loading"!==document.readyState?document.querySelectorAll("pre code").forEach(x):w=!0 +}function N(e){return e=(e||"").toLowerCase(),n[e]||n[s[e]]} +function R(e,{languageName:t}){"string"==typeof e&&(e=[e]),e.forEach((e=>{ +s[e.toLowerCase()]=t}))}function k(e){const t=N(e) +;return t&&!t.disableAutodetect}function M(e,t){const n=e;a.forEach((e=>{ +e[n]&&e[n](t)}))} +"undefined"!=typeof window&&window.addEventListener&&window.addEventListener("DOMContentLoaded",(()=>{ +w&&y()}),!1),Object.assign(e,{highlight:d,highlightAuto:p,highlightAll:y, +fixMarkup:e=>{ +return K("10.2.0","fixMarkup will be removed entirely in v11.0"),K("10.2.0","Please see https://github.com/highlightjs/highlight.js/issues/2534"), +t=e, +u.tabReplace||u.useBR?t.replace(l,(e=>"\n"===e?u.useBR?"
":e:u.tabReplace?e.replace(/\t/g,u.tabReplace):e)):t +;var t},highlightElement:x, +highlightBlock:e=>(K("10.7.0","highlightBlock will be removed entirely in v12.0"), +K("10.7.0","Please use highlightElement now."),x(e)),configure:e=>{ +e.useBR&&(K("10.3.0","'useBR' will be removed entirely in v11.0"), +K("10.3.0","Please see https://github.com/highlightjs/highlight.js/issues/2559")), +u=V(u,e)},initHighlighting:v,initHighlightingOnLoad:()=>{ +K("10.6.0","initHighlightingOnLoad() is deprecated. Use highlightAll() instead."), +w=!0},registerLanguage:(t,i)=>{let s=null;try{s=i(e)}catch(e){ +if(U("Language definition for '{}' could not be registered.".replace("{}",t)), +!r)throw e;U(e),s=g} +s.name||(s.name=t),n[t]=s,s.rawDefinition=i.bind(null,e),s.aliases&&R(s.aliases,{ +languageName:t})},unregisterLanguage:e=>{delete n[e] +;for(const t of Object.keys(s))s[t]===e&&delete s[t]}, +listLanguages:()=>Object.keys(n),getLanguage:N,registerAliases:R, +requireLanguage:e=>{ +K("10.4.0","requireLanguage will be removed entirely in v11."), +K("10.4.0","Please see https://github.com/highlightjs/highlight.js/pull/2844") +;const t=N(e);if(t)return t +;throw Error("The '{}' language is required, but not loaded.".replace("{}",e))}, +autoDetection:k,inherit:V,addPlugin:e=>{(e=>{ +e["before:highlightBlock"]&&!e["before:highlightElement"]&&(e["before:highlightElement"]=t=>{ +e["before:highlightBlock"](Object.assign({block:t.el},t)) +}),e["after:highlightBlock"]&&!e["after:highlightElement"]&&(e["after:highlightElement"]=t=>{ +e["after:highlightBlock"](Object.assign({block:t.el},t))})})(e),a.push(e)}, +vuePlugin:P(e).VuePlugin}),e.debugMode=()=>{r=!1},e.safeMode=()=>{r=!0 +},e.versionString="10.7.2";for(const e in _)"object"==typeof _[e]&&t(_[e]) +;return Object.assign(e,_),e.addPlugin(m),e.addPlugin(D),e.addPlugin(E),e})({}) +}();"object"==typeof exports&&"undefined"!=typeof module&&(module.exports=hljs); +hljs.registerLanguage("apache",(()=>{"use strict";return e=>{const n={ +className:"number",begin:/\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}(:\d{1,5})?/} +;return{name:"Apache config",aliases:["apacheconf"],case_insensitive:!0, +contains:[e.HASH_COMMENT_MODE,{className:"section",begin:/<\/?/,end:/>/, +contains:[n,{className:"number",begin:/:\d{1,5}/ +},e.inherit(e.QUOTE_STRING_MODE,{relevance:0})]},{className:"attribute", +begin:/\w+/,relevance:0,keywords:{ +nomarkup:"order deny allow setenv rewriterule rewriteengine rewritecond documentroot sethandler errordocument loadmodule options header listen serverroot servername" +},starts:{end:/$/,relevance:0,keywords:{literal:"on off all deny allow"}, +contains:[{className:"meta",begin:/\s\[/,end:/\]$/},{className:"variable", +begin:/[\$%]\{/,end:/\}/,contains:["self",{className:"number",begin:/[$%]\d+/}] +},n,{className:"number",begin:/\d+/},e.QUOTE_STRING_MODE]}}],illegal:/\S/}} +})()); +hljs.registerLanguage("bash",(()=>{"use strict";function e(...e){ +return e.map((e=>{return(s=e)?"string"==typeof s?s:s.source:null;var s +})).join("")}return s=>{const n={},t={begin:/\$\{/,end:/\}/,contains:["self",{ +begin:/:-/,contains:[n]}]};Object.assign(n,{className:"variable",variants:[{ +begin:e(/\$[\w\d#@][\w\d_]*/,"(?![\\w\\d])(?![$])")},t]});const a={ +className:"subst",begin:/\$\(/,end:/\)/,contains:[s.BACKSLASH_ESCAPE]},i={ +begin:/<<-?\s*(?=\w+)/,starts:{contains:[s.END_SAME_AS_BEGIN({begin:/(\w+)/, +end:/(\w+)/,className:"string"})]}},c={className:"string",begin:/"/,end:/"/, +contains:[s.BACKSLASH_ESCAPE,n,a]};a.contains.push(c);const o={begin:/\$\(\(/, +end:/\)\)/,contains:[{begin:/\d+#[0-9a-f]+/,className:"number"},s.NUMBER_MODE,n] +},r=s.SHEBANG({binary:"(fish|bash|zsh|sh|csh|ksh|tcsh|dash|scsh)",relevance:10 +}),l={className:"function",begin:/\w[\w\d_]*\s*\(\s*\)\s*\{/,returnBegin:!0, +contains:[s.inherit(s.TITLE_MODE,{begin:/\w[\w\d_]*/})],relevance:0};return{ +name:"Bash",aliases:["sh","zsh"],keywords:{$pattern:/\b[a-z._-]+\b/, +keyword:"if then else elif fi for while in do done case esac function", +literal:"true false", +built_in:"break cd continue eval exec exit export getopts hash pwd readonly return shift test times trap umask unset alias bind builtin caller command declare echo enable help let local logout mapfile printf read readarray source type typeset ulimit unalias set shopt autoload bg bindkey bye cap chdir clone comparguments compcall compctl compdescribe compfiles compgroups compquote comptags comptry compvalues dirs disable disown echotc echoti emulate fc fg float functions getcap getln history integer jobs kill limit log noglob popd print pushd pushln rehash sched setcap setopt stat suspend ttyctl unfunction unhash unlimit unsetopt vared wait whence where which zcompile zformat zftp zle zmodload zparseopts zprof zpty zregexparse zsocket zstyle ztcp" +},contains:[r,s.SHEBANG(),l,o,s.HASH_COMMENT_MODE,i,c,{className:"",begin:/\\"/ +},{className:"string",begin:/'/,end:/'/},n]}}})()); +hljs.registerLanguage("c",(()=>{"use strict";function e(e){ +return((...e)=>e.map((e=>(e=>e?"string"==typeof e?e:e.source:null)(e))).join(""))("(",e,")?") +}return t=>{const n=t.COMMENT("//","$",{contains:[{begin:/\\\n/}] +}),r="[a-zA-Z_]\\w*::",a="(decltype\\(auto\\)|"+e(r)+"[a-zA-Z_]\\w*"+e("<[^<>]+>")+")",i={ +className:"keyword",begin:"\\b[a-z\\d_]*_t\\b"},s={className:"string", +variants:[{begin:'(u8?|U|L)?"',end:'"',illegal:"\\n", +contains:[t.BACKSLASH_ESCAPE]},{ +begin:"(u8?|U|L)?'(\\\\(x[0-9A-Fa-f]{2}|u[0-9A-Fa-f]{4,8}|[0-7]{3}|\\S)|.)", +end:"'",illegal:"."},t.END_SAME_AS_BEGIN({ +begin:/(?:u8?|U|L)?R"([^()\\ ]{0,16})\(/,end:/\)([^()\\ ]{0,16})"/})]},o={ +className:"number",variants:[{begin:"\\b(0b[01']+)"},{ +begin:"(-?)\\b([\\d']+(\\.[\\d']*)?|\\.[\\d']+)((ll|LL|l|L)(u|U)?|(u|U)(ll|LL|l|L)?|f|F|b|B)" +},{ +begin:"(-?)(\\b0[xX][a-fA-F0-9']+|(\\b[\\d']+(\\.[\\d']*)?|\\.[\\d']+)([eE][-+]?[\\d']+)?)" +}],relevance:0},c={className:"meta",begin:/#\s*[a-z]+\b/,end:/$/,keywords:{ +"meta-keyword":"if else elif endif define undef warning error line pragma _Pragma ifdef ifndef include" +},contains:[{begin:/\\\n/,relevance:0},t.inherit(s,{className:"meta-string"}),{ +className:"meta-string",begin:/<.*?>/},n,t.C_BLOCK_COMMENT_MODE]},l={ +className:"title",begin:e(r)+t.IDENT_RE,relevance:0 +},d=e(r)+t.IDENT_RE+"\\s*\\(",u={ +keyword:"int float while private char char8_t char16_t char32_t catch import module export virtual operator sizeof dynamic_cast|10 typedef const_cast|10 const for static_cast|10 union namespace unsigned long volatile static protected bool template mutable if public friend do goto auto void enum else break extern using asm case typeid wchar_t short reinterpret_cast|10 default double register explicit signed typename try this switch continue inline delete alignas alignof constexpr consteval constinit decltype concept co_await co_return co_yield requires noexcept static_assert thread_local restrict final override atomic_bool atomic_char atomic_schar atomic_uchar atomic_short atomic_ushort atomic_int atomic_uint atomic_long atomic_ulong atomic_llong atomic_ullong new throw return and and_eq bitand bitor compl not not_eq or or_eq xor xor_eq", +built_in:"std string wstring cin cout cerr clog stdin stdout stderr stringstream istringstream ostringstream auto_ptr deque list queue stack vector map set pair bitset multiset multimap unordered_set unordered_map unordered_multiset unordered_multimap priority_queue make_pair array shared_ptr abort terminate abs acos asin atan2 atan calloc ceil cosh cos exit exp fabs floor fmod fprintf fputs free frexp fscanf future isalnum isalpha iscntrl isdigit isgraph islower isprint ispunct isspace isupper isxdigit tolower toupper labs ldexp log10 log malloc realloc memchr memcmp memcpy memset modf pow printf putchar puts scanf sinh sin snprintf sprintf sqrt sscanf strcat strchr strcmp strcpy strcspn strlen strncat strncmp strncpy strpbrk strrchr strspn strstr tanh tan vfprintf vprintf vsprintf endl initializer_list unique_ptr _Bool complex _Complex imaginary _Imaginary", +literal:"true false nullptr NULL"},m=[c,i,n,t.C_BLOCK_COMMENT_MODE,o,s],p={ +variants:[{begin:/=/,end:/;/},{begin:/\(/,end:/\)/},{ +beginKeywords:"new throw return else",end:/;/}],keywords:u,contains:m.concat([{ +begin:/\(/,end:/\)/,keywords:u,contains:m.concat(["self"]),relevance:0}]), +relevance:0},_={className:"function",begin:"("+a+"[\\*&\\s]+)+"+d, +returnBegin:!0,end:/[{;=]/,excludeEnd:!0,keywords:u,illegal:/[^\w\s\*&:<>.]/, +contains:[{begin:"decltype\\(auto\\)",keywords:u,relevance:0},{begin:d, +returnBegin:!0,contains:[l],relevance:0},{className:"params",begin:/\(/, +end:/\)/,keywords:u,relevance:0,contains:[n,t.C_BLOCK_COMMENT_MODE,s,o,i,{ +begin:/\(/,end:/\)/,keywords:u,relevance:0, +contains:["self",n,t.C_BLOCK_COMMENT_MODE,s,o,i]}] +},i,n,t.C_BLOCK_COMMENT_MODE,c]};return{name:"C",aliases:["h"],keywords:u, +disableAutodetect:!0,illegal:"",keywords:u,contains:["self",i]},{begin:t.IDENT_RE+"::",keywords:u},{ +className:"class",beginKeywords:"enum class struct union",end:/[{;:<>=]/, +contains:[{beginKeywords:"final class struct"},t.TITLE_MODE]}]),exports:{ +preprocessor:c,strings:s,keywords:u}}}})()); +hljs.registerLanguage("coffeescript",(()=>{"use strict" +;const e=["as","in","of","if","for","while","finally","var","new","function","do","return","void","else","break","catch","instanceof","with","throw","case","default","try","switch","continue","typeof","delete","let","yield","const","class","debugger","async","await","static","import","from","export","extends"],n=["true","false","null","undefined","NaN","Infinity"],a=[].concat(["setInterval","setTimeout","clearInterval","clearTimeout","require","exports","eval","isFinite","isNaN","parseFloat","parseInt","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape"],["arguments","this","super","console","window","document","localStorage","module","global"],["Intl","DataView","Number","Math","Date","String","RegExp","Object","Function","Boolean","Error","Symbol","Set","Map","WeakSet","WeakMap","Proxy","Reflect","JSON","Promise","Float64Array","Int16Array","Int32Array","Int8Array","Uint16Array","Uint32Array","Float32Array","Array","Uint8Array","Uint8ClampedArray","ArrayBuffer","BigInt64Array","BigUint64Array","BigInt"],["EvalError","InternalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError"]) +;return r=>{const t={ +keyword:e.concat(["then","unless","until","loop","by","when","and","or","is","isnt","not"]).filter((i=["var","const","let","function","static"], +e=>!i.includes(e))),literal:n.concat(["yes","no","on","off"]), +built_in:a.concat(["npm","print"])};var i;const s="[A-Za-z$_][0-9A-Za-z$_]*",o={ +className:"subst",begin:/#\{/,end:/\}/,keywords:t +},c=[r.BINARY_NUMBER_MODE,r.inherit(r.C_NUMBER_MODE,{starts:{end:"(\\s*/)?", +relevance:0}}),{className:"string",variants:[{begin:/'''/,end:/'''/, +contains:[r.BACKSLASH_ESCAPE]},{begin:/'/,end:/'/,contains:[r.BACKSLASH_ESCAPE] +},{begin:/"""/,end:/"""/,contains:[r.BACKSLASH_ESCAPE,o]},{begin:/"/,end:/"/, +contains:[r.BACKSLASH_ESCAPE,o]}]},{className:"regexp",variants:[{begin:"///", +end:"///",contains:[o,r.HASH_COMMENT_MODE]},{begin:"//[gim]{0,3}(?=\\W)", +relevance:0},{begin:/\/(?![ *]).*?(?![\\]).\/[gim]{0,3}(?=\W)/}]},{begin:"@"+s +},{subLanguage:"javascript",excludeBegin:!0,excludeEnd:!0,variants:[{ +begin:"```",end:"```"},{begin:"`",end:"`"}]}];o.contains=c +;const l=r.inherit(r.TITLE_MODE,{begin:s}),d="(\\(.*\\)\\s*)?\\B[-=]>",g={ +className:"params",begin:"\\([^\\(]",returnBegin:!0,contains:[{begin:/\(/, +end:/\)/,keywords:t,contains:["self"].concat(c)}]};return{name:"CoffeeScript", +aliases:["coffee","cson","iced"],keywords:t,illegal:/\/\*/, +contains:c.concat([r.COMMENT("###","###"),r.HASH_COMMENT_MODE,{ +className:"function",begin:"^\\s*"+s+"\\s*=\\s*"+d,end:"[-=]>",returnBegin:!0, +contains:[l,g]},{begin:/[:\(,=]\s*/,relevance:0,contains:[{className:"function", +begin:d,end:"[-=]>",returnBegin:!0,contains:[g]}]},{className:"class", +beginKeywords:"class",end:"$",illegal:/[:="\[\]]/,contains:[{ +beginKeywords:"extends",endsWithParent:!0,illegal:/[:="\[\]]/,contains:[l]},l] +},{begin:s+":",end:":",returnBegin:!0,returnEnd:!0,relevance:0}])}}})()); +hljs.registerLanguage("cpp",(()=>{"use strict";function e(e){ +return t("(",e,")?")}function t(...e){return e.map((e=>{ +return(t=e)?"string"==typeof t?t:t.source:null;var t})).join("")}return n=>{ +const r=n.COMMENT("//","$",{contains:[{begin:/\\\n/}] +}),a="[a-zA-Z_]\\w*::",i="(decltype\\(auto\\)|"+e(a)+"[a-zA-Z_]\\w*"+e("<[^<>]+>")+")",s={ +className:"keyword",begin:"\\b[a-z\\d_]*_t\\b"},c={className:"string", +variants:[{begin:'(u8?|U|L)?"',end:'"',illegal:"\\n", +contains:[n.BACKSLASH_ESCAPE]},{ +begin:"(u8?|U|L)?'(\\\\(x[0-9A-Fa-f]{2}|u[0-9A-Fa-f]{4,8}|[0-7]{3}|\\S)|.)", +end:"'",illegal:"."},n.END_SAME_AS_BEGIN({ +begin:/(?:u8?|U|L)?R"([^()\\ ]{0,16})\(/,end:/\)([^()\\ ]{0,16})"/})]},o={ +className:"number",variants:[{begin:"\\b(0b[01']+)"},{ +begin:"(-?)\\b([\\d']+(\\.[\\d']*)?|\\.[\\d']+)((ll|LL|l|L)(u|U)?|(u|U)(ll|LL|l|L)?|f|F|b|B)" +},{ +begin:"(-?)(\\b0[xX][a-fA-F0-9']+|(\\b[\\d']+(\\.[\\d']*)?|\\.[\\d']+)([eE][-+]?[\\d']+)?)" +}],relevance:0},l={className:"meta",begin:/#\s*[a-z]+\b/,end:/$/,keywords:{ +"meta-keyword":"if else elif endif define undef warning error line pragma _Pragma ifdef ifndef include" +},contains:[{begin:/\\\n/,relevance:0},n.inherit(c,{className:"meta-string"}),{ +className:"meta-string",begin:/<.*?>/},r,n.C_BLOCK_COMMENT_MODE]},d={ +className:"title",begin:e(a)+n.IDENT_RE,relevance:0 +},u=e(a)+n.IDENT_RE+"\\s*\\(",m={ +keyword:"int float while private char char8_t char16_t char32_t catch import module export virtual operator sizeof dynamic_cast|10 typedef const_cast|10 const for static_cast|10 union namespace unsigned long volatile static protected bool template mutable if public friend do goto auto void enum else break extern using asm case typeid wchar_t short reinterpret_cast|10 default double register explicit signed typename try this switch continue inline delete alignas alignof constexpr consteval constinit decltype concept co_await co_return co_yield requires noexcept static_assert thread_local restrict final override atomic_bool atomic_char atomic_schar atomic_uchar atomic_short atomic_ushort atomic_int atomic_uint atomic_long atomic_ulong atomic_llong atomic_ullong new throw return and and_eq bitand bitor compl not not_eq or or_eq xor xor_eq", +built_in:"_Bool _Complex _Imaginary", +_relevance_hints:["asin","atan2","atan","calloc","ceil","cosh","cos","exit","exp","fabs","floor","fmod","fprintf","fputs","free","frexp","auto_ptr","deque","list","queue","stack","vector","map","set","pair","bitset","multiset","multimap","unordered_set","fscanf","future","isalnum","isalpha","iscntrl","isdigit","isgraph","islower","isprint","ispunct","isspace","isupper","isxdigit","tolower","toupper","labs","ldexp","log10","log","malloc","realloc","memchr","memcmp","memcpy","memset","modf","pow","printf","putchar","puts","scanf","sinh","sin","snprintf","sprintf","sqrt","sscanf","strcat","strchr","strcmp","strcpy","strcspn","strlen","strncat","strncmp","strncpy","strpbrk","strrchr","strspn","strstr","tanh","tan","unordered_map","unordered_multiset","unordered_multimap","priority_queue","make_pair","array","shared_ptr","abort","terminate","abs","acos","vfprintf","vprintf","vsprintf","endl","initializer_list","unique_ptr","complex","imaginary","std","string","wstring","cin","cout","cerr","clog","stdin","stdout","stderr","stringstream","istringstream","ostringstream"], +literal:"true false nullptr NULL"},p={className:"function.dispatch",relevance:0, +keywords:m, +begin:t(/\b/,/(?!decltype)/,/(?!if)/,/(?!for)/,/(?!while)/,n.IDENT_RE,(_=/\s*\(/, +t("(?=",_,")")))};var _;const g=[p,l,s,r,n.C_BLOCK_COMMENT_MODE,o,c],b={ +variants:[{begin:/=/,end:/;/},{begin:/\(/,end:/\)/},{ +beginKeywords:"new throw return else",end:/;/}],keywords:m,contains:g.concat([{ +begin:/\(/,end:/\)/,keywords:m,contains:g.concat(["self"]),relevance:0}]), +relevance:0},f={className:"function",begin:"("+i+"[\\*&\\s]+)+"+u, +returnBegin:!0,end:/[{;=]/,excludeEnd:!0,keywords:m,illegal:/[^\w\s\*&:<>.]/, +contains:[{begin:"decltype\\(auto\\)",keywords:m,relevance:0},{begin:u, +returnBegin:!0,contains:[d],relevance:0},{begin:/::/,relevance:0},{begin:/:/, +endsWithParent:!0,contains:[c,o]},{className:"params",begin:/\(/,end:/\)/, +keywords:m,relevance:0,contains:[r,n.C_BLOCK_COMMENT_MODE,c,o,s,{begin:/\(/, +end:/\)/,keywords:m,relevance:0,contains:["self",r,n.C_BLOCK_COMMENT_MODE,c,o,s] +}]},s,r,n.C_BLOCK_COMMENT_MODE,l]};return{name:"C++", +aliases:["cc","c++","h++","hpp","hh","hxx","cxx"],keywords:m,illegal:"",keywords:m,contains:["self",s]},{begin:n.IDENT_RE+"::",keywords:m},{ +className:"class",beginKeywords:"enum class struct union",end:/[{;:<>=]/, +contains:[{beginKeywords:"final class struct"},n.TITLE_MODE]}]),exports:{ +preprocessor:l,strings:c,keywords:m}}}})()); +hljs.registerLanguage("csharp",(()=>{"use strict";return e=>{const n={ +keyword:["abstract","as","base","break","case","class","const","continue","do","else","event","explicit","extern","finally","fixed","for","foreach","goto","if","implicit","in","interface","internal","is","lock","namespace","new","operator","out","override","params","private","protected","public","readonly","record","ref","return","sealed","sizeof","stackalloc","static","struct","switch","this","throw","try","typeof","unchecked","unsafe","using","virtual","void","volatile","while"].concat(["add","alias","and","ascending","async","await","by","descending","equals","from","get","global","group","init","into","join","let","nameof","not","notnull","on","or","orderby","partial","remove","select","set","unmanaged","value|0","var","when","where","with","yield"]), +built_in:["bool","byte","char","decimal","delegate","double","dynamic","enum","float","int","long","nint","nuint","object","sbyte","short","string","ulong","uint","ushort"], +literal:["default","false","null","true"]},a=e.inherit(e.TITLE_MODE,{ +begin:"[a-zA-Z](\\.?\\w)*"}),i={className:"number",variants:[{ +begin:"\\b(0b[01']+)"},{ +begin:"(-?)\\b([\\d']+(\\.[\\d']*)?|\\.[\\d']+)(u|U|l|L|ul|UL|f|F|b|B)"},{ +begin:"(-?)(\\b0[xX][a-fA-F0-9']+|(\\b[\\d']+(\\.[\\d']*)?|\\.[\\d']+)([eE][-+]?[\\d']+)?)" +}],relevance:0},s={className:"string",begin:'@"',end:'"',contains:[{begin:'""'}] +},t=e.inherit(s,{illegal:/\n/}),r={className:"subst",begin:/\{/,end:/\}/, +keywords:n},l=e.inherit(r,{illegal:/\n/}),c={className:"string",begin:/\$"/, +end:'"',illegal:/\n/,contains:[{begin:/\{\{/},{begin:/\}\}/ +},e.BACKSLASH_ESCAPE,l]},o={className:"string",begin:/\$@"/,end:'"',contains:[{ +begin:/\{\{/},{begin:/\}\}/},{begin:'""'},r]},d=e.inherit(o,{illegal:/\n/, +contains:[{begin:/\{\{/},{begin:/\}\}/},{begin:'""'},l]}) +;r.contains=[o,c,s,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,i,e.C_BLOCK_COMMENT_MODE], +l.contains=[d,c,t,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,i,e.inherit(e.C_BLOCK_COMMENT_MODE,{ +illegal:/\n/})];const g={variants:[o,c,s,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE] +},E={begin:"<",end:">",contains:[{beginKeywords:"in out"},a] +},_=e.IDENT_RE+"(<"+e.IDENT_RE+"(\\s*,\\s*"+e.IDENT_RE+")*>)?(\\[\\])?",b={ +begin:"@"+e.IDENT_RE,relevance:0};return{name:"C#",aliases:["cs","c#"], +keywords:n,illegal:/::/,contains:[e.COMMENT("///","$",{returnBegin:!0, +contains:[{className:"doctag",variants:[{begin:"///",relevance:0},{ +begin:"\x3c!--|--\x3e"},{begin:""}]}] +}),e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,{className:"meta",begin:"#", +end:"$",keywords:{ +"meta-keyword":"if else elif endif define undef warning error line region endregion pragma checksum" +}},g,i,{beginKeywords:"class interface",relevance:0,end:/[{;=]/, +illegal:/[^\s:,]/,contains:[{beginKeywords:"where class" +},a,E,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},{beginKeywords:"namespace", +relevance:0,end:/[{;=]/,illegal:/[^\s:]/, +contains:[a,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},{ +beginKeywords:"record",relevance:0,end:/[{;=]/,illegal:/[^\s:]/, +contains:[a,E,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},{className:"meta", +begin:"^\\s*\\[",excludeBegin:!0,end:"\\]",excludeEnd:!0,contains:[{ +className:"meta-string",begin:/"/,end:/"/}]},{ +beginKeywords:"new return throw await else",relevance:0},{className:"function", +begin:"("+_+"\\s+)+"+e.IDENT_RE+"\\s*(<.+>\\s*)?\\(",returnBegin:!0, +end:/\s*[{;=]/,excludeEnd:!0,keywords:n,contains:[{ +beginKeywords:"public private protected static internal protected abstract async extern override unsafe virtual new sealed partial", +relevance:0},{begin:e.IDENT_RE+"\\s*(<.+>\\s*)?\\(",returnBegin:!0, +contains:[e.TITLE_MODE,E],relevance:0},{className:"params",begin:/\(/,end:/\)/, +excludeBegin:!0,excludeEnd:!0,keywords:n,relevance:0, +contains:[g,i,e.C_BLOCK_COMMENT_MODE] +},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},b]}}})()); +hljs.registerLanguage("css",(()=>{"use strict" +;const e=["a","abbr","address","article","aside","audio","b","blockquote","body","button","canvas","caption","cite","code","dd","del","details","dfn","div","dl","dt","em","fieldset","figcaption","figure","footer","form","h1","h2","h3","h4","h5","h6","header","hgroup","html","i","iframe","img","input","ins","kbd","label","legend","li","main","mark","menu","nav","object","ol","p","q","quote","samp","section","span","strong","summary","sup","table","tbody","td","textarea","tfoot","th","thead","time","tr","ul","var","video"],t=["any-hover","any-pointer","aspect-ratio","color","color-gamut","color-index","device-aspect-ratio","device-height","device-width","display-mode","forced-colors","grid","height","hover","inverted-colors","monochrome","orientation","overflow-block","overflow-inline","pointer","prefers-color-scheme","prefers-contrast","prefers-reduced-motion","prefers-reduced-transparency","resolution","scan","scripting","update","width","min-width","max-width","min-height","max-height"],i=["active","any-link","blank","checked","current","default","defined","dir","disabled","drop","empty","enabled","first","first-child","first-of-type","fullscreen","future","focus","focus-visible","focus-within","has","host","host-context","hover","indeterminate","in-range","invalid","is","lang","last-child","last-of-type","left","link","local-link","not","nth-child","nth-col","nth-last-child","nth-last-col","nth-last-of-type","nth-of-type","only-child","only-of-type","optional","out-of-range","past","placeholder-shown","read-only","read-write","required","right","root","scope","target","target-within","user-invalid","valid","visited","where"],o=["after","backdrop","before","cue","cue-region","first-letter","first-line","grammar-error","marker","part","placeholder","selection","slotted","spelling-error"],r=["align-content","align-items","align-self","animation","animation-delay","animation-direction","animation-duration","animation-fill-mode","animation-iteration-count","animation-name","animation-play-state","animation-timing-function","auto","backface-visibility","background","background-attachment","background-clip","background-color","background-image","background-origin","background-position","background-repeat","background-size","border","border-bottom","border-bottom-color","border-bottom-left-radius","border-bottom-right-radius","border-bottom-style","border-bottom-width","border-collapse","border-color","border-image","border-image-outset","border-image-repeat","border-image-slice","border-image-source","border-image-width","border-left","border-left-color","border-left-style","border-left-width","border-radius","border-right","border-right-color","border-right-style","border-right-width","border-spacing","border-style","border-top","border-top-color","border-top-left-radius","border-top-right-radius","border-top-style","border-top-width","border-width","bottom","box-decoration-break","box-shadow","box-sizing","break-after","break-before","break-inside","caption-side","clear","clip","clip-path","color","column-count","column-fill","column-gap","column-rule","column-rule-color","column-rule-style","column-rule-width","column-span","column-width","columns","content","counter-increment","counter-reset","cursor","direction","display","empty-cells","filter","flex","flex-basis","flex-direction","flex-flow","flex-grow","flex-shrink","flex-wrap","float","font","font-display","font-family","font-feature-settings","font-kerning","font-language-override","font-size","font-size-adjust","font-smoothing","font-stretch","font-style","font-variant","font-variant-ligatures","font-variation-settings","font-weight","height","hyphens","icon","image-orientation","image-rendering","image-resolution","ime-mode","inherit","initial","justify-content","left","letter-spacing","line-height","list-style","list-style-image","list-style-position","list-style-type","margin","margin-bottom","margin-left","margin-right","margin-top","marks","mask","max-height","max-width","min-height","min-width","nav-down","nav-index","nav-left","nav-right","nav-up","none","normal","object-fit","object-position","opacity","order","orphans","outline","outline-color","outline-offset","outline-style","outline-width","overflow","overflow-wrap","overflow-x","overflow-y","padding","padding-bottom","padding-left","padding-right","padding-top","page-break-after","page-break-before","page-break-inside","perspective","perspective-origin","pointer-events","position","quotes","resize","right","src","tab-size","table-layout","text-align","text-align-last","text-decoration","text-decoration-color","text-decoration-line","text-decoration-style","text-indent","text-overflow","text-rendering","text-shadow","text-transform","text-underline-position","top","transform","transform-origin","transform-style","transition","transition-delay","transition-duration","transition-property","transition-timing-function","unicode-bidi","vertical-align","visibility","white-space","widows","width","word-break","word-spacing","word-wrap","z-index"].reverse() +;return n=>{const a=(e=>({IMPORTANT:{className:"meta",begin:"!important"}, +HEXCOLOR:{className:"number",begin:"#([a-fA-F0-9]{6}|[a-fA-F0-9]{3})"}, +ATTRIBUTE_SELECTOR_MODE:{className:"selector-attr",begin:/\[/,end:/\]/, +illegal:"$",contains:[e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]} +}))(n),l=[n.APOS_STRING_MODE,n.QUOTE_STRING_MODE];return{name:"CSS", +case_insensitive:!0,illegal:/[=|'\$]/,keywords:{keyframePosition:"from to"}, +classNameAliases:{keyframePosition:"selector-tag"}, +contains:[n.C_BLOCK_COMMENT_MODE,{begin:/-(webkit|moz|ms|o)-(?=[a-z])/ +},n.CSS_NUMBER_MODE,{className:"selector-id",begin:/#[A-Za-z0-9_-]+/,relevance:0 +},{className:"selector-class",begin:"\\.[a-zA-Z-][a-zA-Z0-9_-]*",relevance:0 +},a.ATTRIBUTE_SELECTOR_MODE,{className:"selector-pseudo",variants:[{ +begin:":("+i.join("|")+")"},{begin:"::("+o.join("|")+")"}]},{ +className:"attribute",begin:"\\b("+r.join("|")+")\\b"},{begin:":",end:"[;}]", +contains:[a.HEXCOLOR,a.IMPORTANT,n.CSS_NUMBER_MODE,...l,{ +begin:/(url|data-uri)\(/,end:/\)/,relevance:0,keywords:{built_in:"url data-uri" +},contains:[{className:"string",begin:/[^)]/,endsWithParent:!0,excludeEnd:!0}] +},{className:"built_in",begin:/[\w-]+(?=\()/}]},{ +begin:(s=/@/,((...e)=>e.map((e=>(e=>e?"string"==typeof e?e:e.source:null)(e))).join(""))("(?=",s,")")), +end:"[{;]",relevance:0,illegal:/:/,contains:[{className:"keyword", +begin:/@-?\w[\w]*(-\w+)*/},{begin:/\s/,endsWithParent:!0,excludeEnd:!0, +relevance:0,keywords:{$pattern:/[a-z-]+/,keyword:"and or not only", +attribute:t.join(" ")},contains:[{begin:/[a-z-]+(?=:)/,className:"attribute" +},...l,n.CSS_NUMBER_MODE]}]},{className:"selector-tag", +begin:"\\b("+e.join("|")+")\\b"}]};var s}})()); +hljs.registerLanguage("diff",(()=>{"use strict";return e=>({name:"Diff", +aliases:["patch"],contains:[{className:"meta",relevance:10,variants:[{ +begin:/^@@ +-\d+,\d+ +\+\d+,\d+ +@@/},{begin:/^\*\*\* +\d+,\d+ +\*\*\*\*$/},{ +begin:/^--- +\d+,\d+ +----$/}]},{className:"comment",variants:[{begin:/Index: /, +end:/$/},{begin:/^index/,end:/$/},{begin:/={3,}/,end:/$/},{begin:/^-{3}/,end:/$/ +},{begin:/^\*{3} /,end:/$/},{begin:/^\+{3}/,end:/$/},{begin:/^\*{15}$/},{ +begin:/^diff --git/,end:/$/}]},{className:"addition",begin:/^\+/,end:/$/},{ +className:"deletion",begin:/^-/,end:/$/},{className:"addition",begin:/^!/, +end:/$/}]})})()); +hljs.registerLanguage("go",(()=>{"use strict";return e=>{const n={ +keyword:"break default func interface select case map struct chan else goto package switch const fallthrough if range type continue for import return var go defer bool byte complex64 complex128 float32 float64 int8 int16 int32 int64 string uint8 uint16 uint32 uint64 int uint uintptr rune", +literal:"true false iota nil", +built_in:"append cap close complex copy imag len make new panic print println real recover delete" +};return{name:"Go",aliases:["golang"],keywords:n,illegal:"{"use strict";function e(...e){ +return e.map((e=>{return(n=e)?"string"==typeof n?n:n.source:null;var n +})).join("")}return n=>{const a="HTTP/(2|1\\.[01])",s={className:"attribute", +begin:e("^",/[A-Za-z][A-Za-z0-9-]*/,"(?=\\:\\s)"),starts:{contains:[{ +className:"punctuation",begin:/: /,relevance:0,starts:{end:"$",relevance:0}}]} +},t=[s,{begin:"\\n\\n",starts:{subLanguage:[],endsWithParent:!0}}];return{ +name:"HTTP",aliases:["https"],illegal:/\S/,contains:[{begin:"^(?="+a+" \\d{3})", +end:/$/,contains:[{className:"meta",begin:a},{className:"number", +begin:"\\b\\d{3}\\b"}],starts:{end:/\b\B/,illegal:/\S/,contains:t}},{ +begin:"(?=^[A-Z]+ (.*?) "+a+"$)",end:/$/,contains:[{className:"string", +begin:" ",end:" ",excludeBegin:!0,excludeEnd:!0},{className:"meta",begin:a},{ +className:"keyword",begin:"[A-Z]+"}],starts:{end:/\b\B/,illegal:/\S/,contains:t} +},n.inherit(s,{relevance:0})]}}})()); +hljs.registerLanguage("ini",(()=>{"use strict";function e(e){ +return e?"string"==typeof e?e:e.source:null}function n(...n){ +return n.map((n=>e(n))).join("")}return s=>{const a={className:"number", +relevance:0,variants:[{begin:/([+-]+)?[\d]+_[\d_]+/},{begin:s.NUMBER_RE}] +},i=s.COMMENT();i.variants=[{begin:/;/,end:/$/},{begin:/#/,end:/$/}];const t={ +className:"variable",variants:[{begin:/\$[\w\d"][\w\d_]*/},{begin:/\$\{(.*?)\}/ +}]},r={className:"literal",begin:/\bon|off|true|false|yes|no\b/},l={ +className:"string",contains:[s.BACKSLASH_ESCAPE],variants:[{begin:"'''", +end:"'''",relevance:10},{begin:'"""',end:'"""',relevance:10},{begin:'"',end:'"' +},{begin:"'",end:"'"}]},c={begin:/\[/,end:/\]/,contains:[i,r,t,l,a,"self"], +relevance:0 +},g="("+[/[A-Za-z0-9_-]+/,/"(\\"|[^"])*"/,/'[^']*'/].map((n=>e(n))).join("|")+")" +;return{name:"TOML, also INI",aliases:["toml"],case_insensitive:!0,illegal:/\S/, +contains:[i,{className:"section",begin:/\[+/,end:/\]+/},{ +begin:n(g,"(\\s*\\.\\s*",g,")*",n("(?=",/\s*=\s*[^#\s]/,")")),className:"attr", +starts:{end:/$/,contains:[i,c,r,t,l,a]}}]}}})()); +hljs.registerLanguage("java",(()=>{"use strict" +;var e="\\.([0-9](_*[0-9])*)",n="[0-9a-fA-F](_*[0-9a-fA-F])*",a={ +className:"number",variants:[{ +begin:`(\\b([0-9](_*[0-9])*)((${e})|\\.)?|(${e}))[eE][+-]?([0-9](_*[0-9])*)[fFdD]?\\b` +},{begin:`\\b([0-9](_*[0-9])*)((${e})[fFdD]?\\b|\\.([fFdD]\\b)?)`},{ +begin:`(${e})[fFdD]?\\b`},{begin:"\\b([0-9](_*[0-9])*)[fFdD]\\b"},{ +begin:`\\b0[xX]((${n})\\.?|(${n})?\\.(${n}))[pP][+-]?([0-9](_*[0-9])*)[fFdD]?\\b` +},{begin:"\\b(0|[1-9](_*[0-9])*)[lL]?\\b"},{begin:`\\b0[xX](${n})[lL]?\\b`},{ +begin:"\\b0(_*[0-7])*[lL]?\\b"},{begin:"\\b0[bB][01](_*[01])*[lL]?\\b"}], +relevance:0};return e=>{ +var n="false synchronized int abstract float private char boolean var static null if const for true while long strictfp finally protected import native final void enum else break transient catch instanceof byte super volatile case assert short package default double public try this switch continue throws protected public private module requires exports do",s={ +className:"meta",begin:"@[\xc0-\u02b8a-zA-Z_$][\xc0-\u02b8a-zA-Z_$0-9]*", +contains:[{begin:/\(/,end:/\)/,contains:["self"]}]};const r=a;return{ +name:"Java",aliases:["jsp"],keywords:n,illegal:/<\/|#/, +contains:[e.COMMENT("/\\*\\*","\\*/",{relevance:0,contains:[{begin:/\w+@/, +relevance:0},{className:"doctag",begin:"@[A-Za-z]+"}]}),{ +begin:/import java\.[a-z]+\./,keywords:"import",relevance:2 +},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,{ +className:"class",beginKeywords:"class interface enum",end:/[{;=]/, +excludeEnd:!0,relevance:1,keywords:"class interface enum",illegal:/[:"\[\]]/, +contains:[{beginKeywords:"extends implements"},e.UNDERSCORE_TITLE_MODE]},{ +beginKeywords:"new throw return else",relevance:0},{className:"class", +begin:"record\\s+"+e.UNDERSCORE_IDENT_RE+"\\s*\\(",returnBegin:!0,excludeEnd:!0, +end:/[{;=]/,keywords:n,contains:[{beginKeywords:"record"},{ +begin:e.UNDERSCORE_IDENT_RE+"\\s*\\(",returnBegin:!0,relevance:0, +contains:[e.UNDERSCORE_TITLE_MODE]},{className:"params",begin:/\(/,end:/\)/, +keywords:n,relevance:0,contains:[e.C_BLOCK_COMMENT_MODE] +},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},{className:"function", +begin:"([\xc0-\u02b8a-zA-Z_$][\xc0-\u02b8a-zA-Z_$0-9]*(<[\xc0-\u02b8a-zA-Z_$][\xc0-\u02b8a-zA-Z_$0-9]*(\\s*,\\s*[\xc0-\u02b8a-zA-Z_$][\xc0-\u02b8a-zA-Z_$0-9]*)*>)?\\s+)+"+e.UNDERSCORE_IDENT_RE+"\\s*\\(", +returnBegin:!0,end:/[{;=]/,excludeEnd:!0,keywords:n,contains:[{ +begin:e.UNDERSCORE_IDENT_RE+"\\s*\\(",returnBegin:!0,relevance:0, +contains:[e.UNDERSCORE_TITLE_MODE]},{className:"params",begin:/\(/,end:/\)/, +keywords:n,relevance:0, +contains:[s,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,r,e.C_BLOCK_COMMENT_MODE] +},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},r,s]}}})()); +hljs.registerLanguage("javascript",(()=>{"use strict" +;const e="[A-Za-z$_][0-9A-Za-z$_]*",n=["as","in","of","if","for","while","finally","var","new","function","do","return","void","else","break","catch","instanceof","with","throw","case","default","try","switch","continue","typeof","delete","let","yield","const","class","debugger","async","await","static","import","from","export","extends"],a=["true","false","null","undefined","NaN","Infinity"],s=[].concat(["setInterval","setTimeout","clearInterval","clearTimeout","require","exports","eval","isFinite","isNaN","parseFloat","parseInt","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape"],["arguments","this","super","console","window","document","localStorage","module","global"],["Intl","DataView","Number","Math","Date","String","RegExp","Object","Function","Boolean","Error","Symbol","Set","Map","WeakSet","WeakMap","Proxy","Reflect","JSON","Promise","Float64Array","Int16Array","Int32Array","Int8Array","Uint16Array","Uint32Array","Float32Array","Array","Uint8Array","Uint8ClampedArray","ArrayBuffer","BigInt64Array","BigUint64Array","BigInt"],["EvalError","InternalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError"]) +;function r(e){return t("(?=",e,")")}function t(...e){return e.map((e=>{ +return(n=e)?"string"==typeof n?n:n.source:null;var n})).join("")}return i=>{ +const c=e,o={begin:/<[A-Za-z0-9\\._:-]+/,end:/\/[A-Za-z0-9\\._:-]+>|\/>/, +isTrulyOpeningTag:(e,n)=>{const a=e[0].length+e.index,s=e.input[a] +;"<"!==s?">"===s&&(((e,{after:n})=>{const a="", +returnBegin:!0,end:"\\s*=>",contains:[{className:"params",variants:[{ +begin:i.UNDERSCORE_IDENT_RE,relevance:0},{className:null,begin:/\(\s*\)/,skip:!0 +},{begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0,keywords:l,contains:f}]}] +},{begin:/,/,relevance:0},{className:"",begin:/\s/,end:/\s*/,skip:!0},{ +variants:[{begin:"<>",end:""},{begin:o.begin,"on:begin":o.isTrulyOpeningTag, +end:o.end}],subLanguage:"xml",contains:[{begin:o.begin,end:o.end,skip:!0, +contains:["self"]}]}],relevance:0},{className:"function", +beginKeywords:"function",end:/[{;]/,excludeEnd:!0,keywords:l, +contains:["self",i.inherit(i.TITLE_MODE,{begin:c}),p],illegal:/%/},{ +beginKeywords:"while if switch catch for"},{className:"function", +begin:i.UNDERSCORE_IDENT_RE+"\\([^()]*(\\([^()]*(\\([^()]*\\)[^()]*)*\\)[^()]*)*\\)\\s*\\{", +returnBegin:!0,contains:[p,i.inherit(i.TITLE_MODE,{begin:c})]},{variants:[{ +begin:"\\."+c},{begin:"\\$"+c}],relevance:0},{className:"class", +beginKeywords:"class",end:/[{;=]/,excludeEnd:!0,illegal:/[:"[\]]/,contains:[{ +beginKeywords:"extends"},i.UNDERSCORE_TITLE_MODE]},{begin:/\b(?=constructor)/, +end:/[{;]/,excludeEnd:!0,contains:[i.inherit(i.TITLE_MODE,{begin:c}),"self",p] +},{begin:"(get|set)\\s+(?="+c+"\\()",end:/\{/,keywords:"get set", +contains:[i.inherit(i.TITLE_MODE,{begin:c}),{begin:/\(\)/},p]},{begin:/\$[(.]/}] +}}})()); +hljs.registerLanguage("json",(()=>{"use strict";return n=>{const e={ +literal:"true false null" +},i=[n.C_LINE_COMMENT_MODE,n.C_BLOCK_COMMENT_MODE],a=[n.QUOTE_STRING_MODE,n.C_NUMBER_MODE],l={ +end:",",endsWithParent:!0,excludeEnd:!0,contains:a,keywords:e},t={begin:/\{/, +end:/\}/,contains:[{className:"attr",begin:/"/,end:/"/, +contains:[n.BACKSLASH_ESCAPE],illegal:"\\n"},n.inherit(l,{begin:/:/ +})].concat(i),illegal:"\\S"},s={begin:"\\[",end:"\\]",contains:[n.inherit(l)], +illegal:"\\S"};return a.push(t,s),i.forEach((n=>{a.push(n)})),{name:"JSON", +contains:a,keywords:e,illegal:"\\S"}}})()); +hljs.registerLanguage("kotlin",(()=>{"use strict" +;var e="\\.([0-9](_*[0-9])*)",n="[0-9a-fA-F](_*[0-9a-fA-F])*",a={ +className:"number",variants:[{ +begin:`(\\b([0-9](_*[0-9])*)((${e})|\\.)?|(${e}))[eE][+-]?([0-9](_*[0-9])*)[fFdD]?\\b` +},{begin:`\\b([0-9](_*[0-9])*)((${e})[fFdD]?\\b|\\.([fFdD]\\b)?)`},{ +begin:`(${e})[fFdD]?\\b`},{begin:"\\b([0-9](_*[0-9])*)[fFdD]\\b"},{ +begin:`\\b0[xX]((${n})\\.?|(${n})?\\.(${n}))[pP][+-]?([0-9](_*[0-9])*)[fFdD]?\\b` +},{begin:"\\b(0|[1-9](_*[0-9])*)[lL]?\\b"},{begin:`\\b0[xX](${n})[lL]?\\b`},{ +begin:"\\b0(_*[0-7])*[lL]?\\b"},{begin:"\\b0[bB][01](_*[01])*[lL]?\\b"}], +relevance:0};return e=>{const n={ +keyword:"abstract as val var vararg get set class object open private protected public noinline crossinline dynamic final enum if else do while for when throw try catch finally import package is in fun override companion reified inline lateinit init interface annotation data sealed internal infix operator out by constructor super tailrec where const inner suspend typealias external expect actual", +built_in:"Byte Short Char Int Long Boolean Float Double Void Unit Nothing", +literal:"true false null"},i={className:"symbol",begin:e.UNDERSCORE_IDENT_RE+"@" +},s={className:"subst",begin:/\$\{/,end:/\}/,contains:[e.C_NUMBER_MODE]},t={ +className:"variable",begin:"\\$"+e.UNDERSCORE_IDENT_RE},r={className:"string", +variants:[{begin:'"""',end:'"""(?=[^"])',contains:[t,s]},{begin:"'",end:"'", +illegal:/\n/,contains:[e.BACKSLASH_ESCAPE]},{begin:'"',end:'"',illegal:/\n/, +contains:[e.BACKSLASH_ESCAPE,t,s]}]};s.contains.push(r);const l={ +className:"meta", +begin:"@(?:file|property|field|get|set|receiver|param|setparam|delegate)\\s*:(?:\\s*"+e.UNDERSCORE_IDENT_RE+")?" +},c={className:"meta",begin:"@"+e.UNDERSCORE_IDENT_RE,contains:[{begin:/\(/, +end:/\)/,contains:[e.inherit(r,{className:"meta-string"})]}] +},o=a,b=e.COMMENT("/\\*","\\*/",{contains:[e.C_BLOCK_COMMENT_MODE]}),E={ +variants:[{className:"type",begin:e.UNDERSCORE_IDENT_RE},{begin:/\(/,end:/\)/, +contains:[]}]},d=E;return d.variants[1].contains=[E],E.variants[1].contains=[d], +{name:"Kotlin",aliases:["kt","kts"],keywords:n, +contains:[e.COMMENT("/\\*\\*","\\*/",{relevance:0,contains:[{className:"doctag", +begin:"@[A-Za-z]+"}]}),e.C_LINE_COMMENT_MODE,b,{className:"keyword", +begin:/\b(break|continue|return|this)\b/,starts:{contains:[{className:"symbol", +begin:/@\w+/}]}},i,l,c,{className:"function",beginKeywords:"fun",end:"[(]|$", +returnBegin:!0,excludeEnd:!0,keywords:n,relevance:5,contains:[{ +begin:e.UNDERSCORE_IDENT_RE+"\\s*\\(",returnBegin:!0,relevance:0, +contains:[e.UNDERSCORE_TITLE_MODE]},{className:"type",begin://, +keywords:"reified",relevance:0},{className:"params",begin:/\(/,end:/\)/, +endsParent:!0,keywords:n,relevance:0,contains:[{begin:/:/,end:/[=,\/]/, +endsWithParent:!0,contains:[E,e.C_LINE_COMMENT_MODE,b],relevance:0 +},e.C_LINE_COMMENT_MODE,b,l,c,r,e.C_NUMBER_MODE]},b]},{className:"class", +beginKeywords:"class interface trait",end:/[:\{(]|$/,excludeEnd:!0, +illegal:"extends implements",contains:[{ +beginKeywords:"public protected internal private constructor" +},e.UNDERSCORE_TITLE_MODE,{className:"type",begin://,excludeBegin:!0, +excludeEnd:!0,relevance:0},{className:"type",begin:/[,:]\s*/,end:/[<\(,]|$/, +excludeBegin:!0,returnEnd:!0},l,c]},r,{className:"meta",begin:"^#!/usr/bin/env", +end:"$",illegal:"\n"},o]}}})()); +hljs.registerLanguage("less",(()=>{"use strict" +;const e=["a","abbr","address","article","aside","audio","b","blockquote","body","button","canvas","caption","cite","code","dd","del","details","dfn","div","dl","dt","em","fieldset","figcaption","figure","footer","form","h1","h2","h3","h4","h5","h6","header","hgroup","html","i","iframe","img","input","ins","kbd","label","legend","li","main","mark","menu","nav","object","ol","p","q","quote","samp","section","span","strong","summary","sup","table","tbody","td","textarea","tfoot","th","thead","time","tr","ul","var","video"],t=["any-hover","any-pointer","aspect-ratio","color","color-gamut","color-index","device-aspect-ratio","device-height","device-width","display-mode","forced-colors","grid","height","hover","inverted-colors","monochrome","orientation","overflow-block","overflow-inline","pointer","prefers-color-scheme","prefers-contrast","prefers-reduced-motion","prefers-reduced-transparency","resolution","scan","scripting","update","width","min-width","max-width","min-height","max-height"],i=["active","any-link","blank","checked","current","default","defined","dir","disabled","drop","empty","enabled","first","first-child","first-of-type","fullscreen","future","focus","focus-visible","focus-within","has","host","host-context","hover","indeterminate","in-range","invalid","is","lang","last-child","last-of-type","left","link","local-link","not","nth-child","nth-col","nth-last-child","nth-last-col","nth-last-of-type","nth-of-type","only-child","only-of-type","optional","out-of-range","past","placeholder-shown","read-only","read-write","required","right","root","scope","target","target-within","user-invalid","valid","visited","where"],o=["after","backdrop","before","cue","cue-region","first-letter","first-line","grammar-error","marker","part","placeholder","selection","slotted","spelling-error"],n=["align-content","align-items","align-self","animation","animation-delay","animation-direction","animation-duration","animation-fill-mode","animation-iteration-count","animation-name","animation-play-state","animation-timing-function","auto","backface-visibility","background","background-attachment","background-clip","background-color","background-image","background-origin","background-position","background-repeat","background-size","border","border-bottom","border-bottom-color","border-bottom-left-radius","border-bottom-right-radius","border-bottom-style","border-bottom-width","border-collapse","border-color","border-image","border-image-outset","border-image-repeat","border-image-slice","border-image-source","border-image-width","border-left","border-left-color","border-left-style","border-left-width","border-radius","border-right","border-right-color","border-right-style","border-right-width","border-spacing","border-style","border-top","border-top-color","border-top-left-radius","border-top-right-radius","border-top-style","border-top-width","border-width","bottom","box-decoration-break","box-shadow","box-sizing","break-after","break-before","break-inside","caption-side","clear","clip","clip-path","color","column-count","column-fill","column-gap","column-rule","column-rule-color","column-rule-style","column-rule-width","column-span","column-width","columns","content","counter-increment","counter-reset","cursor","direction","display","empty-cells","filter","flex","flex-basis","flex-direction","flex-flow","flex-grow","flex-shrink","flex-wrap","float","font","font-display","font-family","font-feature-settings","font-kerning","font-language-override","font-size","font-size-adjust","font-smoothing","font-stretch","font-style","font-variant","font-variant-ligatures","font-variation-settings","font-weight","height","hyphens","icon","image-orientation","image-rendering","image-resolution","ime-mode","inherit","initial","justify-content","left","letter-spacing","line-height","list-style","list-style-image","list-style-position","list-style-type","margin","margin-bottom","margin-left","margin-right","margin-top","marks","mask","max-height","max-width","min-height","min-width","nav-down","nav-index","nav-left","nav-right","nav-up","none","normal","object-fit","object-position","opacity","order","orphans","outline","outline-color","outline-offset","outline-style","outline-width","overflow","overflow-wrap","overflow-x","overflow-y","padding","padding-bottom","padding-left","padding-right","padding-top","page-break-after","page-break-before","page-break-inside","perspective","perspective-origin","pointer-events","position","quotes","resize","right","src","tab-size","table-layout","text-align","text-align-last","text-decoration","text-decoration-color","text-decoration-line","text-decoration-style","text-indent","text-overflow","text-rendering","text-shadow","text-transform","text-underline-position","top","transform","transform-origin","transform-style","transition","transition-delay","transition-duration","transition-property","transition-timing-function","unicode-bidi","vertical-align","visibility","white-space","widows","width","word-break","word-spacing","word-wrap","z-index"].reverse(),r=i.concat(o) +;return a=>{const s=(e=>({IMPORTANT:{className:"meta",begin:"!important"}, +HEXCOLOR:{className:"number",begin:"#([a-fA-F0-9]{6}|[a-fA-F0-9]{3})"}, +ATTRIBUTE_SELECTOR_MODE:{className:"selector-attr",begin:/\[/,end:/\]/, +illegal:"$",contains:[e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]} +}))(a),l=r,d="([\\w-]+|@\\{[\\w-]+\\})",c=[],g=[],b=e=>({className:"string", +begin:"~?"+e+".*?"+e}),m=(e,t,i)=>({className:e,begin:t,relevance:i}),u={ +$pattern:/[a-z-]+/,keyword:"and or not only",attribute:t.join(" ")},p={ +begin:"\\(",end:"\\)",contains:g,keywords:u,relevance:0} +;g.push(a.C_LINE_COMMENT_MODE,a.C_BLOCK_COMMENT_MODE,b("'"),b('"'),a.CSS_NUMBER_MODE,{ +begin:"(url|data-uri)\\(",starts:{className:"string",end:"[\\)\\n]", +excludeEnd:!0} +},s.HEXCOLOR,p,m("variable","@@?[\\w-]+",10),m("variable","@\\{[\\w-]+\\}"),m("built_in","~?`[^`]*?`"),{ +className:"attribute",begin:"[\\w-]+\\s*:",end:":",returnBegin:!0,excludeEnd:!0 +},s.IMPORTANT);const f=g.concat({begin:/\{/,end:/\}/,contains:c}),h={ +beginKeywords:"when",endsWithParent:!0,contains:[{beginKeywords:"and not" +}].concat(g)},w={begin:d+"\\s*:",returnBegin:!0,end:/[;}]/,relevance:0, +contains:[{begin:/-(webkit|moz|ms|o)-/},{className:"attribute", +begin:"\\b("+n.join("|")+")\\b",end:/(?=:)/,starts:{endsWithParent:!0, +illegal:"[<=$]",relevance:0,contains:g}}]},v={className:"keyword", +begin:"@(import|media|charset|font-face|(-[a-z]+-)?keyframes|supports|document|namespace|page|viewport|host)\\b", +starts:{end:"[;{}]",keywords:u,returnEnd:!0,contains:g,relevance:0}},y={ +className:"variable",variants:[{begin:"@[\\w-]+\\s*:",relevance:15},{ +begin:"@[\\w-]+"}],starts:{end:"[;}]",returnEnd:!0,contains:f}},k={variants:[{ +begin:"[\\.#:&\\[>]",end:"[;{}]"},{begin:d,end:/\{/}],returnBegin:!0, +returnEnd:!0,illegal:"[<='$\"]",relevance:0, +contains:[a.C_LINE_COMMENT_MODE,a.C_BLOCK_COMMENT_MODE,h,m("keyword","all\\b"),m("variable","@\\{[\\w-]+\\}"),{ +begin:"\\b("+e.join("|")+")\\b",className:"selector-tag" +},m("selector-tag",d+"%?",0),m("selector-id","#"+d),m("selector-class","\\."+d,0),m("selector-tag","&",0),s.ATTRIBUTE_SELECTOR_MODE,{ +className:"selector-pseudo",begin:":("+i.join("|")+")"},{ +className:"selector-pseudo",begin:"::("+o.join("|")+")"},{begin:"\\(",end:"\\)", +contains:f},{begin:"!important"}]},E={begin:`[\\w-]+:(:)?(${l.join("|")})`, +returnBegin:!0,contains:[k]} +;return c.push(a.C_LINE_COMMENT_MODE,a.C_BLOCK_COMMENT_MODE,v,y,E,w,k),{ +name:"Less",case_insensitive:!0,illegal:"[=>'/<($\"]",contains:c}}})()); +hljs.registerLanguage("lua",(()=>{"use strict";return e=>{ +const t="\\[=*\\[",a="\\]=*\\]",n={begin:t,end:a,contains:["self"] +},o=[e.COMMENT("--(?!\\[=*\\[)","$"),e.COMMENT("--\\[=*\\[",a,{contains:[n], +relevance:10})];return{name:"Lua",keywords:{$pattern:e.UNDERSCORE_IDENT_RE, +literal:"true false nil", +keyword:"and break do else elseif end for goto if in local not or repeat return then until while", +built_in:"_G _ENV _VERSION __index __newindex __mode __call __metatable __tostring __len __gc __add __sub __mul __div __mod __pow __concat __unm __eq __lt __le assert collectgarbage dofile error getfenv getmetatable ipairs load loadfile loadstring module next pairs pcall print rawequal rawget rawset require select setfenv setmetatable tonumber tostring type unpack xpcall arg self coroutine resume yield status wrap create running debug getupvalue debug sethook getmetatable gethook setmetatable setlocal traceback setfenv getinfo setupvalue getlocal getregistry getfenv io lines write close flush open output type read stderr stdin input stdout popen tmpfile math log max acos huge ldexp pi cos tanh pow deg tan cosh sinh random randomseed frexp ceil floor rad abs sqrt modf asin min mod fmod log10 atan2 exp sin atan os exit setlocale date getenv difftime remove time clock tmpname rename execute package preload loadlib loaded loaders cpath config path seeall string sub upper len gfind rep find match char dump gmatch reverse byte format gsub lower table setn insert getn foreachi maxn foreach concat sort remove" +},contains:o.concat([{className:"function",beginKeywords:"function",end:"\\)", +contains:[e.inherit(e.TITLE_MODE,{ +begin:"([_a-zA-Z]\\w*\\.)*([_a-zA-Z]\\w*:)?[_a-zA-Z]\\w*"}),{className:"params", +begin:"\\(",endsWithParent:!0,contains:o}].concat(o) +},e.C_NUMBER_MODE,e.APOS_STRING_MODE,e.QUOTE_STRING_MODE,{className:"string", +begin:t,end:a,contains:[n],relevance:5}])}}})()); +hljs.registerLanguage("makefile",(()=>{"use strict";return e=>{const i={ +className:"variable",variants:[{begin:"\\$\\("+e.UNDERSCORE_IDENT_RE+"\\)", +contains:[e.BACKSLASH_ESCAPE]},{begin:/\$[@%{"use strict";function e(e){ +return e?"string"==typeof e?e:e.source:null}function n(e){return a("(?=",e,")")} +function a(...n){return n.map((n=>e(n))).join("")}function s(...n){ +return"("+n.map((n=>e(n))).join("|")+")"}return e=>{ +const t=a(/[A-Z_]/,a("(",/[A-Z0-9_.-]*:/,")?"),/[A-Z0-9_.-]*/),i={ +className:"symbol",begin:/&[a-z]+;|&#[0-9]+;|&#x[a-f0-9]+;/},r={begin:/\s/, +contains:[{className:"meta-keyword",begin:/#?[a-z_][a-z1-9_-]+/,illegal:/\n/}] +},c=e.inherit(r,{begin:/\(/,end:/\)/}),l=e.inherit(e.APOS_STRING_MODE,{ +className:"meta-string"}),g=e.inherit(e.QUOTE_STRING_MODE,{ +className:"meta-string"}),m={endsWithParent:!0,illegal:/`]+/}]}] +}]};return{name:"HTML, XML", +aliases:["html","xhtml","rss","atom","xjb","xsd","xsl","plist","wsf","svg"], +case_insensitive:!0,contains:[{className:"meta",begin://, +relevance:10,contains:[r,g,l,c,{begin:/\[/,end:/\]/,contains:[{className:"meta", +begin://,contains:[r,c,g,l]}]}]},e.COMMENT(//,{ +relevance:10}),{begin://,relevance:10},i,{ +className:"meta",begin:/<\?xml/,end:/\?>/,relevance:10},{className:"tag", +begin:/)/,end:/>/,keywords:{name:"style"},contains:[m],starts:{ +end:/<\/style>/,returnEnd:!0,subLanguage:["css","xml"]}},{className:"tag", +begin:/)/,end:/>/,keywords:{name:"script"},contains:[m],starts:{ +end:/<\/script>/,returnEnd:!0,subLanguage:["javascript","handlebars","xml"]}},{ +className:"tag",begin:/<>|<\/>/},{className:"tag", +begin:a(//,/>/,/\s/)))),end:/\/?>/,contains:[{className:"name", +begin:t,relevance:0,starts:m}]},{className:"tag",begin:a(/<\//,n(a(t,/>/))), +contains:[{className:"name",begin:t,relevance:0},{begin:/>/,relevance:0, +endsParent:!0}]}]}}})()); +hljs.registerLanguage("markdown",(()=>{"use strict";function n(...n){ +return n.map((n=>{return(e=n)?"string"==typeof e?e:e.source:null;var e +})).join("")}return e=>{const a={begin:/<\/?[A-Za-z_]/,end:">", +subLanguage:"xml",relevance:0},i={variants:[{begin:/\[.+?\]\[.*?\]/,relevance:0 +},{begin:/\[.+?\]\(((data|javascript|mailto):|(?:http|ftp)s?:\/\/).*?\)/, +relevance:2},{begin:n(/\[.+?\]\(/,/[A-Za-z][A-Za-z0-9+.-]*/,/:\/\/.*?\)/), +relevance:2},{begin:/\[.+?\]\([./?&#].*?\)/,relevance:1},{ +begin:/\[.+?\]\(.*?\)/,relevance:0}],returnBegin:!0,contains:[{ +className:"string",relevance:0,begin:"\\[",end:"\\]",excludeBegin:!0, +returnEnd:!0},{className:"link",relevance:0,begin:"\\]\\(",end:"\\)", +excludeBegin:!0,excludeEnd:!0},{className:"symbol",relevance:0,begin:"\\]\\[", +end:"\\]",excludeBegin:!0,excludeEnd:!0}]},s={className:"strong",contains:[], +variants:[{begin:/_{2}/,end:/_{2}/},{begin:/\*{2}/,end:/\*{2}/}]},c={ +className:"emphasis",contains:[],variants:[{begin:/\*(?!\*)/,end:/\*/},{ +begin:/_(?!_)/,end:/_/,relevance:0}]};s.contains.push(c),c.contains.push(s) +;let t=[a,i] +;return s.contains=s.contains.concat(t),c.contains=c.contains.concat(t), +t=t.concat(s,c),{name:"Markdown",aliases:["md","mkdown","mkd"],contains:[{ +className:"section",variants:[{begin:"^#{1,6}",end:"$",contains:t},{ +begin:"(?=^.+?\\n[=-]{2,}$)",contains:[{begin:"^[=-]*$"},{begin:"^",end:"\\n", +contains:t}]}]},a,{className:"bullet",begin:"^[ \t]*([*+-]|(\\d+\\.))(?=\\s+)", +end:"\\s+",excludeEnd:!0},s,c,{className:"quote",begin:"^>\\s+",contains:t, +end:"$"},{className:"code",variants:[{begin:"(`{3,})[^`](.|\\n)*?\\1`*[ ]*"},{ +begin:"(~{3,})[^~](.|\\n)*?\\1~*[ ]*"},{begin:"```",end:"```+[ ]*$"},{ +begin:"~~~",end:"~~~+[ ]*$"},{begin:"`.+?`"},{begin:"(?=^( {4}|\\t))", +contains:[{begin:"^( {4}|\\t)",end:"(\\n)$"}],relevance:0}]},{ +begin:"^[-\\*]{3,}",end:"$"},i,{begin:/^\[[^\n]+\]:/,returnBegin:!0,contains:[{ +className:"symbol",begin:/\[/,end:/\]/,excludeBegin:!0,excludeEnd:!0},{ +className:"link",begin:/:\s*/,end:/$/,excludeBegin:!0}]}]}}})()); +hljs.registerLanguage("nginx",(()=>{"use strict";return e=>{const n={ +className:"variable",variants:[{begin:/\$\d+/},{begin:/\$\{/,end:/\}/},{ +begin:/[$@]/+e.UNDERSCORE_IDENT_RE}]},a={endsWithParent:!0,keywords:{ +$pattern:"[a-z/_]+", +literal:"on off yes no true false none blocked debug info notice warn error crit select break last permanent redirect kqueue rtsig epoll poll /dev/poll" +},relevance:0,illegal:"=>",contains:[e.HASH_COMMENT_MODE,{className:"string", +contains:[e.BACKSLASH_ESCAPE,n],variants:[{begin:/"/,end:/"/},{begin:/'/,end:/'/ +}]},{begin:"([a-z]+):/",end:"\\s",endsWithParent:!0,excludeEnd:!0,contains:[n] +},{className:"regexp",contains:[e.BACKSLASH_ESCAPE,n],variants:[{begin:"\\s\\^", +end:"\\s|\\{|;",returnEnd:!0},{begin:"~\\*?\\s+",end:"\\s|\\{|;",returnEnd:!0},{ +begin:"\\*(\\.[a-z\\-]+)+"},{begin:"([a-z\\-]+\\.)+\\*"}]},{className:"number", +begin:"\\b\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}(:\\d{1,5})?\\b"},{ +className:"number",begin:"\\b\\d+[kKmMgGdshdwy]*\\b",relevance:0},n]};return{ +name:"Nginx config",aliases:["nginxconf"],contains:[e.HASH_COMMENT_MODE,{ +begin:e.UNDERSCORE_IDENT_RE+"\\s+\\{",returnBegin:!0,end:/\{/,contains:[{ +className:"section",begin:e.UNDERSCORE_IDENT_RE}],relevance:0},{ +begin:e.UNDERSCORE_IDENT_RE+"\\s",end:";|\\{",returnBegin:!0,contains:[{ +className:"attribute",begin:e.UNDERSCORE_IDENT_RE,starts:a}],relevance:0}], +illegal:"[^\\s\\}]"}}})()); +hljs.registerLanguage("objectivec",(()=>{"use strict";return e=>{ +const n=/[a-zA-Z@][a-zA-Z0-9_]*/,_={$pattern:n, +keyword:"@interface @class @protocol @implementation"};return{ +name:"Objective-C",aliases:["mm","objc","obj-c","obj-c++","objective-c++"], +keywords:{$pattern:n, +keyword:"int float while char export sizeof typedef const struct for union unsigned long volatile static bool mutable if do return goto void enum else break extern asm case short default double register explicit signed typename this switch continue wchar_t inline readonly assign readwrite self @synchronized id typeof nonatomic super unichar IBOutlet IBAction strong weak copy in out inout bycopy byref oneway __strong __weak __block __autoreleasing @private @protected @public @try @property @end @throw @catch @finally @autoreleasepool @synthesize @dynamic @selector @optional @required @encode @package @import @defs @compatibility_alias __bridge __bridge_transfer __bridge_retained __bridge_retain __covariant __contravariant __kindof _Nonnull _Nullable _Null_unspecified __FUNCTION__ __PRETTY_FUNCTION__ __attribute__ getter setter retain unsafe_unretained nonnull nullable null_unspecified null_resettable class instancetype NS_DESIGNATED_INITIALIZER NS_UNAVAILABLE NS_REQUIRES_SUPER NS_RETURNS_INNER_POINTER NS_INLINE NS_AVAILABLE NS_DEPRECATED NS_ENUM NS_OPTIONS NS_SWIFT_UNAVAILABLE NS_ASSUME_NONNULL_BEGIN NS_ASSUME_NONNULL_END NS_REFINED_FOR_SWIFT NS_SWIFT_NAME NS_SWIFT_NOTHROW NS_DURING NS_HANDLER NS_ENDHANDLER NS_VALUERETURN NS_VOIDRETURN", +literal:"false true FALSE TRUE nil YES NO NULL", +built_in:"BOOL dispatch_once_t dispatch_queue_t dispatch_sync dispatch_async dispatch_once" +},illegal:"/,end:/$/, +illegal:"\\n"},e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE]},{ +className:"class",begin:"("+_.keyword.split(" ").join("|")+")\\b",end:/(\{|$)/, +excludeEnd:!0,keywords:_,contains:[e.UNDERSCORE_TITLE_MODE]},{ +begin:"\\."+e.UNDERSCORE_IDENT_RE,relevance:0}]}}})()); +hljs.registerLanguage("perl",(()=>{"use strict";function e(e){ +return e?"string"==typeof e?e:e.source:null}function n(...n){ +return n.map((n=>e(n))).join("")}function t(...n){ +return"("+n.map((n=>e(n))).join("|")+")"}return e=>{ +const r=/[dualxmsipngr]{0,12}/,s={$pattern:/[\w.]+/, +keyword:"abs accept alarm and atan2 bind binmode bless break caller chdir chmod chomp chop chown chr chroot close closedir connect continue cos crypt dbmclose dbmopen defined delete die do dump each else elsif endgrent endhostent endnetent endprotoent endpwent endservent eof eval exec exists exit exp fcntl fileno flock for foreach fork format formline getc getgrent getgrgid getgrnam gethostbyaddr gethostbyname gethostent getlogin getnetbyaddr getnetbyname getnetent getpeername getpgrp getpriority getprotobyname getprotobynumber getprotoent getpwent getpwnam getpwuid getservbyname getservbyport getservent getsockname getsockopt given glob gmtime goto grep gt hex if index int ioctl join keys kill last lc lcfirst length link listen local localtime log lstat lt ma map mkdir msgctl msgget msgrcv msgsnd my ne next no not oct open opendir or ord our pack package pipe pop pos print printf prototype push q|0 qq quotemeta qw qx rand read readdir readline readlink readpipe recv redo ref rename require reset return reverse rewinddir rindex rmdir say scalar seek seekdir select semctl semget semop send setgrent sethostent setnetent setpgrp setpriority setprotoent setpwent setservent setsockopt shift shmctl shmget shmread shmwrite shutdown sin sleep socket socketpair sort splice split sprintf sqrt srand stat state study sub substr symlink syscall sysopen sysread sysseek system syswrite tell telldir tie tied time times tr truncate uc ucfirst umask undef unless unlink unpack unshift untie until use utime values vec wait waitpid wantarray warn when while write x|0 xor y|0" +},i={className:"subst",begin:"[$@]\\{",end:"\\}",keywords:s},a={begin:/->\{/, +end:/\}/},o={variants:[{begin:/\$\d/},{ +begin:n(/[$%@](\^\w\b|#\w+(::\w+)*|\{\w+\}|\w+(::\w*)*)/,"(?![A-Za-z])(?![@$%])") +},{begin:/[$%@][^\s\w{]/,relevance:0}] +},c=[e.BACKSLASH_ESCAPE,i,o],g=[/!/,/\//,/\|/,/\?/,/'/,/"/,/#/],l=(e,t,s="\\1")=>{ +const i="\\1"===s?s:n(s,t) +;return n(n("(?:",e,")"),t,/(?:\\.|[^\\\/])*?/,i,/(?:\\.|[^\\\/])*?/,s,r) +},d=(e,t,s)=>n(n("(?:",e,")"),t,/(?:\\.|[^\\\/])*?/,s,r),p=[o,e.HASH_COMMENT_MODE,e.COMMENT(/^=\w/,/=cut/,{ +endsWithParent:!0}),a,{className:"string",contains:c,variants:[{ +begin:"q[qwxr]?\\s*\\(",end:"\\)",relevance:5},{begin:"q[qwxr]?\\s*\\[", +end:"\\]",relevance:5},{begin:"q[qwxr]?\\s*\\{",end:"\\}",relevance:5},{ +begin:"q[qwxr]?\\s*\\|",end:"\\|",relevance:5},{begin:"q[qwxr]?\\s*<",end:">", +relevance:5},{begin:"qw\\s+q",end:"q",relevance:5},{begin:"'",end:"'", +contains:[e.BACKSLASH_ESCAPE]},{begin:'"',end:'"'},{begin:"`",end:"`", +contains:[e.BACKSLASH_ESCAPE]},{begin:/\{\w+\}/,relevance:0},{ +begin:"-?\\w+\\s*=>",relevance:0}]},{className:"number", +begin:"(\\b0[0-7_]+)|(\\b0x[0-9a-fA-F_]+)|(\\b[1-9][0-9_]*(\\.[0-9_]+)?)|[0_]\\b", +relevance:0},{ +begin:"(\\/\\/|"+e.RE_STARTERS_RE+"|\\b(split|return|print|reverse|grep)\\b)\\s*", +keywords:"split return print reverse grep",relevance:0, +contains:[e.HASH_COMMENT_MODE,{className:"regexp",variants:[{ +begin:l("s|tr|y",t(...g))},{begin:l("s|tr|y","\\(","\\)")},{ +begin:l("s|tr|y","\\[","\\]")},{begin:l("s|tr|y","\\{","\\}")}],relevance:2},{ +className:"regexp",variants:[{begin:/(m|qr)\/\//,relevance:0},{ +begin:d("(?:m|qr)?",/\//,/\//)},{begin:d("m|qr",t(...g),/\1/)},{ +begin:d("m|qr",/\(/,/\)/)},{begin:d("m|qr",/\[/,/\]/)},{ +begin:d("m|qr",/\{/,/\}/)}]}]},{className:"function",beginKeywords:"sub", +end:"(\\s*\\(.*?\\))?[;{]",excludeEnd:!0,relevance:5,contains:[e.TITLE_MODE]},{ +begin:"-\\w\\b",relevance:0},{begin:"^__DATA__$",end:"^__END__$", +subLanguage:"mojolicious",contains:[{begin:"^@@.*",end:"$",className:"comment"}] +}];return i.contains=p,a.contains=p,{name:"Perl",aliases:["pl","pm"],keywords:s, +contains:p}}})()); +hljs.registerLanguage("php",(()=>{"use strict";return e=>{const r={ +className:"variable", +begin:"\\$+[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*(?![A-Za-z0-9])(?![$])"},t={ +className:"meta",variants:[{begin:/<\?php/,relevance:10},{begin:/<\?[=]?/},{ +begin:/\?>/}]},a={className:"subst",variants:[{begin:/\$\w+/},{begin:/\{\$/, +end:/\}/}]},n=e.inherit(e.APOS_STRING_MODE,{illegal:null +}),i=e.inherit(e.QUOTE_STRING_MODE,{illegal:null, +contains:e.QUOTE_STRING_MODE.contains.concat(a)}),o=e.END_SAME_AS_BEGIN({ +begin:/<<<[ \t]*(\w+)\n/,end:/[ \t]*(\w+)\b/, +contains:e.QUOTE_STRING_MODE.contains.concat(a)}),l={className:"string", +contains:[e.BACKSLASH_ESCAPE,t],variants:[e.inherit(n,{begin:"b'",end:"'" +}),e.inherit(i,{begin:'b"',end:'"'}),i,n,o]},s={className:"number",variants:[{ +begin:"\\b0b[01]+(?:_[01]+)*\\b"},{begin:"\\b0o[0-7]+(?:_[0-7]+)*\\b"},{ +begin:"\\b0x[\\da-f]+(?:_[\\da-f]+)*\\b"},{ +begin:"(?:\\b\\d+(?:_\\d+)*(\\.(?:\\d+(?:_\\d+)*))?|\\B\\.\\d+)(?:e[+-]?\\d+)?" +}],relevance:0},c={ +keyword:"__CLASS__ __DIR__ __FILE__ __FUNCTION__ __LINE__ __METHOD__ __NAMESPACE__ __TRAIT__ die echo exit include include_once print require require_once array abstract and as binary bool boolean break callable case catch class clone const continue declare default do double else elseif empty enddeclare endfor endforeach endif endswitch endwhile enum eval extends final finally float for foreach from global goto if implements instanceof insteadof int integer interface isset iterable list match|0 mixed new object or private protected public real return string switch throw trait try unset use var void while xor yield", +literal:"false null true", +built_in:"Error|0 AppendIterator ArgumentCountError ArithmeticError ArrayIterator ArrayObject AssertionError BadFunctionCallException BadMethodCallException CachingIterator CallbackFilterIterator CompileError Countable DirectoryIterator DivisionByZeroError DomainException EmptyIterator ErrorException Exception FilesystemIterator FilterIterator GlobIterator InfiniteIterator InvalidArgumentException IteratorIterator LengthException LimitIterator LogicException MultipleIterator NoRewindIterator OutOfBoundsException OutOfRangeException OuterIterator OverflowException ParentIterator ParseError RangeException RecursiveArrayIterator RecursiveCachingIterator RecursiveCallbackFilterIterator RecursiveDirectoryIterator RecursiveFilterIterator RecursiveIterator RecursiveIteratorIterator RecursiveRegexIterator RecursiveTreeIterator RegexIterator RuntimeException SeekableIterator SplDoublyLinkedList SplFileInfo SplFileObject SplFixedArray SplHeap SplMaxHeap SplMinHeap SplObjectStorage SplObserver SplObserver SplPriorityQueue SplQueue SplStack SplSubject SplSubject SplTempFileObject TypeError UnderflowException UnexpectedValueException UnhandledMatchError ArrayAccess Closure Generator Iterator IteratorAggregate Serializable Stringable Throwable Traversable WeakReference WeakMap Directory __PHP_Incomplete_Class parent php_user_filter self static stdClass" +};return{aliases:["php3","php4","php5","php6","php7","php8"], +case_insensitive:!0,keywords:c, +contains:[e.HASH_COMMENT_MODE,e.COMMENT("//","$",{contains:[t] +}),e.COMMENT("/\\*","\\*/",{contains:[{className:"doctag",begin:"@[A-Za-z]+"}] +}),e.COMMENT("__halt_compiler.+?;",!1,{endsWithParent:!0, +keywords:"__halt_compiler"}),t,{className:"keyword",begin:/\$this\b/},r,{ +begin:/(::|->)+[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*/},{className:"function", +relevance:0,beginKeywords:"fn function",end:/[;{]/,excludeEnd:!0, +illegal:"[$%\\[]",contains:[{beginKeywords:"use"},e.UNDERSCORE_TITLE_MODE,{ +begin:"=>",endsParent:!0},{className:"params",begin:"\\(",end:"\\)", +excludeBegin:!0,excludeEnd:!0,keywords:c, +contains:["self",r,e.C_BLOCK_COMMENT_MODE,l,s]}]},{className:"class",variants:[{ +beginKeywords:"enum",illegal:/[($"]/},{beginKeywords:"class interface trait", +illegal:/[:($"]/}],relevance:0,end:/\{/,excludeEnd:!0,contains:[{ +beginKeywords:"extends implements"},e.UNDERSCORE_TITLE_MODE]},{ +beginKeywords:"namespace",relevance:0,end:";",illegal:/[.']/, +contains:[e.UNDERSCORE_TITLE_MODE]},{beginKeywords:"use",relevance:0,end:";", +contains:[e.UNDERSCORE_TITLE_MODE]},l,s]}}})()); +hljs.registerLanguage("php-template",(()=>{"use strict";return n=>({ +name:"PHP template",subLanguage:"xml",contains:[{begin:/<\?(php|=)?/,end:/\?>/, +subLanguage:"php",contains:[{begin:"/\\*",end:"\\*/",skip:!0},{begin:'b"', +end:'"',skip:!0},{begin:"b'",end:"'",skip:!0},n.inherit(n.APOS_STRING_MODE,{ +illegal:null,className:null,contains:null,skip:!0 +}),n.inherit(n.QUOTE_STRING_MODE,{illegal:null,className:null,contains:null, +skip:!0})]}]})})()); +hljs.registerLanguage("plaintext",(()=>{"use strict";return t=>({ +name:"Plain text",aliases:["text","txt"],disableAutodetect:!0})})()); +hljs.registerLanguage("properties",(()=>{"use strict";return e=>{ +var n="[ \\t\\f]*",a=n+"[:=]"+n,t="("+a+"|[ \\t\\f]+)",r="([^\\\\\\W:= \\t\\f\\n]|\\\\.)+",s="([^\\\\:= \\t\\f\\n]|\\\\.)+",i={ +end:t,relevance:0,starts:{className:"string",end:/$/,relevance:0,contains:[{ +begin:"\\\\\\\\"},{begin:"\\\\\\n"}]}};return{name:".properties", +case_insensitive:!0,illegal:/\S/,contains:[e.COMMENT("^\\s*[!#]","$"),{ +returnBegin:!0,variants:[{begin:r+a,relevance:1},{begin:r+"[ \\t\\f]+", +relevance:0}],contains:[{className:"attr",begin:r,endsParent:!0,relevance:0}], +starts:i},{begin:s+t,returnBegin:!0,relevance:0,contains:[{className:"meta", +begin:s,endsParent:!0,relevance:0}],starts:i},{className:"attr",relevance:0, +begin:s+n+"$"}]}}})()); +hljs.registerLanguage("python",(()=>{"use strict";return e=>{const n={ +$pattern:/[A-Za-z]\w+|__\w+__/, +keyword:["and","as","assert","async","await","break","class","continue","def","del","elif","else","except","finally","for","from","global","if","import","in","is","lambda","nonlocal|10","not","or","pass","raise","return","try","while","with","yield"], +built_in:["__import__","abs","all","any","ascii","bin","bool","breakpoint","bytearray","bytes","callable","chr","classmethod","compile","complex","delattr","dict","dir","divmod","enumerate","eval","exec","filter","float","format","frozenset","getattr","globals","hasattr","hash","help","hex","id","input","int","isinstance","issubclass","iter","len","list","locals","map","max","memoryview","min","next","object","oct","open","ord","pow","print","property","range","repr","reversed","round","set","setattr","slice","sorted","staticmethod","str","sum","super","tuple","type","vars","zip"], +literal:["__debug__","Ellipsis","False","None","NotImplemented","True"], +type:["Any","Callable","Coroutine","Dict","List","Literal","Generic","Optional","Sequence","Set","Tuple","Type","Union"] +},a={className:"meta",begin:/^(>>>|\.\.\.) /},i={className:"subst",begin:/\{/, +end:/\}/,keywords:n,illegal:/#/},s={begin:/\{\{/,relevance:0},t={ +className:"string",contains:[e.BACKSLASH_ESCAPE],variants:[{ +begin:/([uU]|[bB]|[rR]|[bB][rR]|[rR][bB])?'''/,end:/'''/, +contains:[e.BACKSLASH_ESCAPE,a],relevance:10},{ +begin:/([uU]|[bB]|[rR]|[bB][rR]|[rR][bB])?"""/,end:/"""/, +contains:[e.BACKSLASH_ESCAPE,a],relevance:10},{ +begin:/([fF][rR]|[rR][fF]|[fF])'''/,end:/'''/, +contains:[e.BACKSLASH_ESCAPE,a,s,i]},{begin:/([fF][rR]|[rR][fF]|[fF])"""/, +end:/"""/,contains:[e.BACKSLASH_ESCAPE,a,s,i]},{begin:/([uU]|[rR])'/,end:/'/, +relevance:10},{begin:/([uU]|[rR])"/,end:/"/,relevance:10},{ +begin:/([bB]|[bB][rR]|[rR][bB])'/,end:/'/},{begin:/([bB]|[bB][rR]|[rR][bB])"/, +end:/"/},{begin:/([fF][rR]|[rR][fF]|[fF])'/,end:/'/, +contains:[e.BACKSLASH_ESCAPE,s,i]},{begin:/([fF][rR]|[rR][fF]|[fF])"/,end:/"/, +contains:[e.BACKSLASH_ESCAPE,s,i]},e.APOS_STRING_MODE,e.QUOTE_STRING_MODE] +},r="[0-9](_?[0-9])*",l=`(\\b(${r}))?\\.(${r})|\\b(${r})\\.`,b={ +className:"number",relevance:0,variants:[{ +begin:`(\\b(${r})|(${l}))[eE][+-]?(${r})[jJ]?\\b`},{begin:`(${l})[jJ]?`},{ +begin:"\\b([1-9](_?[0-9])*|0+(_?0)*)[lLjJ]?\\b"},{ +begin:"\\b0[bB](_?[01])+[lL]?\\b"},{begin:"\\b0[oO](_?[0-7])+[lL]?\\b"},{ +begin:"\\b0[xX](_?[0-9a-fA-F])+[lL]?\\b"},{begin:`\\b(${r})[jJ]\\b`}]},o={ +className:"comment", +begin:(d=/# type:/,((...e)=>e.map((e=>(e=>e?"string"==typeof e?e:e.source:null)(e))).join(""))("(?=",d,")")), +end:/$/,keywords:n,contains:[{begin:/# type:/},{begin:/#/,end:/\b\B/, +endsWithParent:!0}]},c={className:"params",variants:[{className:"", +begin:/\(\s*\)/,skip:!0},{begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0, +keywords:n,contains:["self",a,b,t,e.HASH_COMMENT_MODE]}]};var d +;return i.contains=[t,b,a],{name:"Python",aliases:["py","gyp","ipython"], +keywords:n,illegal:/(<\/|->|\?)|=>/,contains:[a,b,{begin:/\bself\b/},{ +beginKeywords:"if",relevance:0},t,o,e.HASH_COMMENT_MODE,{variants:[{ +className:"function",beginKeywords:"def"},{className:"class", +beginKeywords:"class"}],end:/:/,illegal:/[${=;\n,]/, +contains:[e.UNDERSCORE_TITLE_MODE,c,{begin:/->/,endsWithParent:!0,keywords:n}] +},{className:"meta",begin:/^[\t ]*@/,end:/(?=#)|$/,contains:[b,c,t]}]}}})()); +hljs.registerLanguage("python-repl",(()=>{"use strict";return s=>({ +aliases:["pycon"],contains:[{className:"meta",starts:{end:/ |$/,starts:{end:"$", +subLanguage:"python"}},variants:[{begin:/^>>>(?=[ ]|$)/},{ +begin:/^\.\.\.(?=[ ]|$)/}]}]})})()); +hljs.registerLanguage("r",(()=>{"use strict";function e(...e){return e.map((e=>{ +return(a=e)?"string"==typeof a?a:a.source:null;var a})).join("")}return a=>{ +const n=/(?:(?:[a-zA-Z]|\.[._a-zA-Z])[._a-zA-Z0-9]*)|\.(?!\d)/;return{name:"R", +illegal:/->/,keywords:{$pattern:n, +keyword:"function if in break next repeat else for while", +literal:"NULL NA TRUE FALSE Inf NaN NA_integer_|10 NA_real_|10 NA_character_|10 NA_complex_|10", +built_in:"LETTERS letters month.abb month.name pi T F abs acos acosh all any anyNA Arg as.call as.character as.complex as.double as.environment as.integer as.logical as.null.default as.numeric as.raw asin asinh atan atanh attr attributes baseenv browser c call ceiling class Conj cos cosh cospi cummax cummin cumprod cumsum digamma dim dimnames emptyenv exp expression floor forceAndCall gamma gc.time globalenv Im interactive invisible is.array is.atomic is.call is.character is.complex is.double is.environment is.expression is.finite is.function is.infinite is.integer is.language is.list is.logical is.matrix is.na is.name is.nan is.null is.numeric is.object is.pairlist is.raw is.recursive is.single is.symbol lazyLoadDBfetch length lgamma list log max min missing Mod names nargs nzchar oldClass on.exit pos.to.env proc.time prod quote range Re rep retracemem return round seq_along seq_len seq.int sign signif sin sinh sinpi sqrt standardGeneric substitute sum switch tan tanh tanpi tracemem trigamma trunc unclass untracemem UseMethod xtfrm" +},compilerExtensions:[(a,n)=>{if(!a.beforeMatch)return +;if(a.starts)throw Error("beforeMatch cannot be used with starts") +;const i=Object.assign({},a);Object.keys(a).forEach((e=>{delete a[e] +})),a.begin=e(i.beforeMatch,e("(?=",i.begin,")")),a.starts={relevance:0, +contains:[Object.assign(i,{endsParent:!0})]},a.relevance=0,delete i.beforeMatch +}],contains:[a.COMMENT(/#'/,/$/,{contains:[{className:"doctag", +begin:"@examples",starts:{contains:[{begin:/\n/},{begin:/#'\s*(?=@[a-zA-Z]+)/, +endsParent:!0},{begin:/#'/,end:/$/,excludeBegin:!0}]}},{className:"doctag", +begin:"@param",end:/$/,contains:[{className:"variable",variants:[{begin:n},{ +begin:/`(?:\\.|[^`\\])+`/}],endsParent:!0}]},{className:"doctag", +begin:/@[a-zA-Z]+/},{className:"meta-keyword",begin:/\\[a-zA-Z]+/}] +}),a.HASH_COMMENT_MODE,{className:"string",contains:[a.BACKSLASH_ESCAPE], +variants:[a.END_SAME_AS_BEGIN({begin:/[rR]"(-*)\(/,end:/\)(-*)"/ +}),a.END_SAME_AS_BEGIN({begin:/[rR]"(-*)\{/,end:/\}(-*)"/ +}),a.END_SAME_AS_BEGIN({begin:/[rR]"(-*)\[/,end:/\](-*)"/ +}),a.END_SAME_AS_BEGIN({begin:/[rR]'(-*)\(/,end:/\)(-*)'/ +}),a.END_SAME_AS_BEGIN({begin:/[rR]'(-*)\{/,end:/\}(-*)'/ +}),a.END_SAME_AS_BEGIN({begin:/[rR]'(-*)\[/,end:/\](-*)'/}),{begin:'"',end:'"', +relevance:0},{begin:"'",end:"'",relevance:0}]},{className:"number",relevance:0, +beforeMatch:/([^a-zA-Z0-9._])/,variants:[{ +match:/0[xX][0-9a-fA-F]+\.[0-9a-fA-F]*[pP][+-]?\d+i?/},{ +match:/0[xX][0-9a-fA-F]+([pP][+-]?\d+)?[Li]?/},{ +match:/(\d+(\.\d*)?|\.\d+)([eE][+-]?\d+)?[Li]?/}]},{begin:"%",end:"%"},{ +begin:e(/[a-zA-Z][a-zA-Z_0-9]*/,"\\s+<-\\s+")},{begin:"`",end:"`",contains:[{ +begin:/\\./}]}]}}})()); +hljs.registerLanguage("ruby",(()=>{"use strict";function e(...e){ +return e.map((e=>{return(n=e)?"string"==typeof n?n:n.source:null;var n +})).join("")}return n=>{ +const a="([a-zA-Z_]\\w*[!?=]?|[-+~]@|<<|>>|=~|===?|<=>|[<>]=?|\\*\\*|[-/+%^&*~`|]|\\[\\]=?)",i={ +keyword:"and then defined module in return redo if BEGIN retry end for self when next until do begin unless END rescue else break undef not super class case require yield alias while ensure elsif or include attr_reader attr_writer attr_accessor __FILE__", +built_in:"proc lambda",literal:"true false nil"},s={className:"doctag", +begin:"@[A-Za-z]+"},r={begin:"#<",end:">"},b=[n.COMMENT("#","$",{contains:[s] +}),n.COMMENT("^=begin","^=end",{contains:[s],relevance:10 +}),n.COMMENT("^__END__","\\n$")],c={className:"subst",begin:/#\{/,end:/\}/, +keywords:i},t={className:"string",contains:[n.BACKSLASH_ESCAPE,c],variants:[{ +begin:/'/,end:/'/},{begin:/"/,end:/"/},{begin:/`/,end:/`/},{begin:/%[qQwWx]?\(/, +end:/\)/},{begin:/%[qQwWx]?\[/,end:/\]/},{begin:/%[qQwWx]?\{/,end:/\}/},{ +begin:/%[qQwWx]?/},{begin:/%[qQwWx]?\//,end:/\//},{begin:/%[qQwWx]?%/, +end:/%/},{begin:/%[qQwWx]?-/,end:/-/},{begin:/%[qQwWx]?\|/,end:/\|/},{ +begin:/\B\?(\\\d{1,3})/},{begin:/\B\?(\\x[A-Fa-f0-9]{1,2})/},{ +begin:/\B\?(\\u\{?[A-Fa-f0-9]{1,6}\}?)/},{ +begin:/\B\?(\\M-\\C-|\\M-\\c|\\c\\M-|\\M-|\\C-\\M-)[\x20-\x7e]/},{ +begin:/\B\?\\(c|C-)[\x20-\x7e]/},{begin:/\B\?\\?\S/},{ +begin:/<<[-~]?'?(\w+)\n(?:[^\n]*\n)*?\s*\1\b/,returnBegin:!0,contains:[{ +begin:/<<[-~]?'?/},n.END_SAME_AS_BEGIN({begin:/(\w+)/,end:/(\w+)/, +contains:[n.BACKSLASH_ESCAPE,c]})]}]},g="[0-9](_?[0-9])*",d={className:"number", +relevance:0,variants:[{ +begin:`\\b([1-9](_?[0-9])*|0)(\\.(${g}))?([eE][+-]?(${g})|r)?i?\\b`},{ +begin:"\\b0[dD][0-9](_?[0-9])*r?i?\\b"},{begin:"\\b0[bB][0-1](_?[0-1])*r?i?\\b" +},{begin:"\\b0[oO][0-7](_?[0-7])*r?i?\\b"},{ +begin:"\\b0[xX][0-9a-fA-F](_?[0-9a-fA-F])*r?i?\\b"},{ +begin:"\\b0(_?[0-7])+r?i?\\b"}]},l={className:"params",begin:"\\(",end:"\\)", +endsParent:!0,keywords:i},o=[t,{className:"class",beginKeywords:"class module", +end:"$|;",illegal:/=/,contains:[n.inherit(n.TITLE_MODE,{ +begin:"[A-Za-z_]\\w*(::\\w+)*(\\?|!)?"}),{begin:"<\\s*",contains:[{ +begin:"("+n.IDENT_RE+"::)?"+n.IDENT_RE,relevance:0}]}].concat(b)},{ +className:"function",begin:e(/def\s+/,(_=a+"\\s*(\\(|;|$)",e("(?=",_,")"))), +relevance:0,keywords:"def",end:"$|;",contains:[n.inherit(n.TITLE_MODE,{begin:a +}),l].concat(b)},{begin:n.IDENT_RE+"::"},{className:"symbol", +begin:n.UNDERSCORE_IDENT_RE+"(!|\\?)?:",relevance:0},{className:"symbol", +begin:":(?!\\s)",contains:[t,{begin:a}],relevance:0},d,{className:"variable", +begin:"(\\$\\W)|((\\$|@@?)(\\w+))(?=[^@$?])(?![A-Za-z])(?![@$?'])"},{ +className:"params",begin:/\|/,end:/\|/,relevance:0,keywords:i},{ +begin:"("+n.RE_STARTERS_RE+"|unless)\\s*",keywords:"unless",contains:[{ +className:"regexp",contains:[n.BACKSLASH_ESCAPE,c],illegal:/\n/,variants:[{ +begin:"/",end:"/[a-z]*"},{begin:/%r\{/,end:/\}[a-z]*/},{begin:"%r\\(", +end:"\\)[a-z]*"},{begin:"%r!",end:"![a-z]*"},{begin:"%r\\[",end:"\\][a-z]*"}] +}].concat(r,b),relevance:0}].concat(r,b);var _;c.contains=o,l.contains=o +;const E=[{begin:/^\s*=>/,starts:{end:"$",contains:o}},{className:"meta", +begin:"^([>?]>|[\\w#]+\\(\\w+\\):\\d+:\\d+>|(\\w+-)?\\d+\\.\\d+\\.\\d+(p\\d+)?[^\\d][^>]+>)(?=[ ])", +starts:{end:"$",contains:o}}];return b.unshift(r),{name:"Ruby", +aliases:["rb","gemspec","podspec","thor","irb"],keywords:i,illegal:/\/\*/, +contains:[n.SHEBANG({binary:"ruby"})].concat(E).concat(b).concat(o)}}})()); +hljs.registerLanguage("rust",(()=>{"use strict";return e=>{ +const n="([ui](8|16|32|64|128|size)|f(32|64))?",t="drop i8 i16 i32 i64 i128 isize u8 u16 u32 u64 u128 usize f32 f64 str char bool Box Option Result String Vec Copy Send Sized Sync Drop Fn FnMut FnOnce ToOwned Clone Debug PartialEq PartialOrd Eq Ord AsRef AsMut Into From Default Iterator Extend IntoIterator DoubleEndedIterator ExactSizeIterator SliceConcatExt ToString assert! assert_eq! bitflags! bytes! cfg! col! concat! concat_idents! debug_assert! debug_assert_eq! env! panic! file! format! format_args! include_bin! include_str! line! local_data_key! module_path! option_env! print! println! select! stringify! try! unimplemented! unreachable! vec! write! writeln! macro_rules! assert_ne! debug_assert_ne!" +;return{name:"Rust",aliases:["rs"],keywords:{$pattern:e.IDENT_RE+"!?", +keyword:"abstract as async await become box break const continue crate do dyn else enum extern false final fn for if impl in let loop macro match mod move mut override priv pub ref return self Self static struct super trait true try type typeof unsafe unsized use virtual where while yield", +literal:"true false Some None Ok Err",built_in:t},illegal:""}]}}})()); +hljs.registerLanguage("scss",(()=>{"use strict" +;const e=["a","abbr","address","article","aside","audio","b","blockquote","body","button","canvas","caption","cite","code","dd","del","details","dfn","div","dl","dt","em","fieldset","figcaption","figure","footer","form","h1","h2","h3","h4","h5","h6","header","hgroup","html","i","iframe","img","input","ins","kbd","label","legend","li","main","mark","menu","nav","object","ol","p","q","quote","samp","section","span","strong","summary","sup","table","tbody","td","textarea","tfoot","th","thead","time","tr","ul","var","video"],t=["any-hover","any-pointer","aspect-ratio","color","color-gamut","color-index","device-aspect-ratio","device-height","device-width","display-mode","forced-colors","grid","height","hover","inverted-colors","monochrome","orientation","overflow-block","overflow-inline","pointer","prefers-color-scheme","prefers-contrast","prefers-reduced-motion","prefers-reduced-transparency","resolution","scan","scripting","update","width","min-width","max-width","min-height","max-height"],i=["active","any-link","blank","checked","current","default","defined","dir","disabled","drop","empty","enabled","first","first-child","first-of-type","fullscreen","future","focus","focus-visible","focus-within","has","host","host-context","hover","indeterminate","in-range","invalid","is","lang","last-child","last-of-type","left","link","local-link","not","nth-child","nth-col","nth-last-child","nth-last-col","nth-last-of-type","nth-of-type","only-child","only-of-type","optional","out-of-range","past","placeholder-shown","read-only","read-write","required","right","root","scope","target","target-within","user-invalid","valid","visited","where"],o=["after","backdrop","before","cue","cue-region","first-letter","first-line","grammar-error","marker","part","placeholder","selection","slotted","spelling-error"],r=["align-content","align-items","align-self","animation","animation-delay","animation-direction","animation-duration","animation-fill-mode","animation-iteration-count","animation-name","animation-play-state","animation-timing-function","auto","backface-visibility","background","background-attachment","background-clip","background-color","background-image","background-origin","background-position","background-repeat","background-size","border","border-bottom","border-bottom-color","border-bottom-left-radius","border-bottom-right-radius","border-bottom-style","border-bottom-width","border-collapse","border-color","border-image","border-image-outset","border-image-repeat","border-image-slice","border-image-source","border-image-width","border-left","border-left-color","border-left-style","border-left-width","border-radius","border-right","border-right-color","border-right-style","border-right-width","border-spacing","border-style","border-top","border-top-color","border-top-left-radius","border-top-right-radius","border-top-style","border-top-width","border-width","bottom","box-decoration-break","box-shadow","box-sizing","break-after","break-before","break-inside","caption-side","clear","clip","clip-path","color","column-count","column-fill","column-gap","column-rule","column-rule-color","column-rule-style","column-rule-width","column-span","column-width","columns","content","counter-increment","counter-reset","cursor","direction","display","empty-cells","filter","flex","flex-basis","flex-direction","flex-flow","flex-grow","flex-shrink","flex-wrap","float","font","font-display","font-family","font-feature-settings","font-kerning","font-language-override","font-size","font-size-adjust","font-smoothing","font-stretch","font-style","font-variant","font-variant-ligatures","font-variation-settings","font-weight","height","hyphens","icon","image-orientation","image-rendering","image-resolution","ime-mode","inherit","initial","justify-content","left","letter-spacing","line-height","list-style","list-style-image","list-style-position","list-style-type","margin","margin-bottom","margin-left","margin-right","margin-top","marks","mask","max-height","max-width","min-height","min-width","nav-down","nav-index","nav-left","nav-right","nav-up","none","normal","object-fit","object-position","opacity","order","orphans","outline","outline-color","outline-offset","outline-style","outline-width","overflow","overflow-wrap","overflow-x","overflow-y","padding","padding-bottom","padding-left","padding-right","padding-top","page-break-after","page-break-before","page-break-inside","perspective","perspective-origin","pointer-events","position","quotes","resize","right","src","tab-size","table-layout","text-align","text-align-last","text-decoration","text-decoration-color","text-decoration-line","text-decoration-style","text-indent","text-overflow","text-rendering","text-shadow","text-transform","text-underline-position","top","transform","transform-origin","transform-style","transition","transition-delay","transition-duration","transition-property","transition-timing-function","unicode-bidi","vertical-align","visibility","white-space","widows","width","word-break","word-spacing","word-wrap","z-index"].reverse() +;return a=>{const n=(e=>({IMPORTANT:{className:"meta",begin:"!important"}, +HEXCOLOR:{className:"number",begin:"#([a-fA-F0-9]{6}|[a-fA-F0-9]{3})"}, +ATTRIBUTE_SELECTOR_MODE:{className:"selector-attr",begin:/\[/,end:/\]/, +illegal:"$",contains:[e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]} +}))(a),l=o,s=i,d="@[a-z-]+",c={className:"variable", +begin:"(\\$[a-zA-Z-][a-zA-Z0-9_-]*)\\b"};return{name:"SCSS",case_insensitive:!0, +illegal:"[=/|']",contains:[a.C_LINE_COMMENT_MODE,a.C_BLOCK_COMMENT_MODE,{ +className:"selector-id",begin:"#[A-Za-z0-9_-]+",relevance:0},{ +className:"selector-class",begin:"\\.[A-Za-z0-9_-]+",relevance:0 +},n.ATTRIBUTE_SELECTOR_MODE,{className:"selector-tag", +begin:"\\b("+e.join("|")+")\\b",relevance:0},{className:"selector-pseudo", +begin:":("+s.join("|")+")"},{className:"selector-pseudo", +begin:"::("+l.join("|")+")"},c,{begin:/\(/,end:/\)/,contains:[a.CSS_NUMBER_MODE] +},{className:"attribute",begin:"\\b("+r.join("|")+")\\b"},{ +begin:"\\b(whitespace|wait|w-resize|visible|vertical-text|vertical-ideographic|uppercase|upper-roman|upper-alpha|underline|transparent|top|thin|thick|text|text-top|text-bottom|tb-rl|table-header-group|table-footer-group|sw-resize|super|strict|static|square|solid|small-caps|separate|se-resize|scroll|s-resize|rtl|row-resize|ridge|right|repeat|repeat-y|repeat-x|relative|progress|pointer|overline|outside|outset|oblique|nowrap|not-allowed|normal|none|nw-resize|no-repeat|no-drop|newspaper|ne-resize|n-resize|move|middle|medium|ltr|lr-tb|lowercase|lower-roman|lower-alpha|loose|list-item|line|line-through|line-edge|lighter|left|keep-all|justify|italic|inter-word|inter-ideograph|inside|inset|inline|inline-block|inherit|inactive|ideograph-space|ideograph-parenthesis|ideograph-numeric|ideograph-alpha|horizontal|hidden|help|hand|groove|fixed|ellipsis|e-resize|double|dotted|distribute|distribute-space|distribute-letter|distribute-all-lines|disc|disabled|default|decimal|dashed|crosshair|collapse|col-resize|circle|char|center|capitalize|break-word|break-all|bottom|both|bolder|bold|block|bidi-override|below|baseline|auto|always|all-scroll|absolute|table|table-cell)\\b" +},{begin:":",end:";", +contains:[c,n.HEXCOLOR,a.CSS_NUMBER_MODE,a.QUOTE_STRING_MODE,a.APOS_STRING_MODE,n.IMPORTANT] +},{begin:"@(page|font-face)",lexemes:d,keywords:"@page @font-face"},{begin:"@", +end:"[{;]",returnBegin:!0,keywords:{$pattern:/[a-z-]+/, +keyword:"and or not only",attribute:t.join(" ")},contains:[{begin:d, +className:"keyword"},{begin:/[a-z-]+(?=:)/,className:"attribute" +},c,a.QUOTE_STRING_MODE,a.APOS_STRING_MODE,n.HEXCOLOR,a.CSS_NUMBER_MODE]}]}} +})()); +hljs.registerLanguage("shell",(()=>{"use strict";return s=>({ +name:"Shell Session",aliases:["console"],contains:[{className:"meta", +begin:/^\s{0,3}[/~\w\d[\]()@-]*[>%$#]/,starts:{end:/[^\\](?=\s*$)/, +subLanguage:"bash"}}]})})()); +hljs.registerLanguage("sql",(()=>{"use strict";function e(e){ +return e?"string"==typeof e?e:e.source:null}function r(...r){ +return r.map((r=>e(r))).join("")}function t(...r){ +return"("+r.map((r=>e(r))).join("|")+")"}return e=>{ +const n=e.COMMENT("--","$"),a=["true","false","unknown"],i=["bigint","binary","blob","boolean","char","character","clob","date","dec","decfloat","decimal","float","int","integer","interval","nchar","nclob","national","numeric","real","row","smallint","time","timestamp","varchar","varying","varbinary"],s=["abs","acos","array_agg","asin","atan","avg","cast","ceil","ceiling","coalesce","corr","cos","cosh","count","covar_pop","covar_samp","cume_dist","dense_rank","deref","element","exp","extract","first_value","floor","json_array","json_arrayagg","json_exists","json_object","json_objectagg","json_query","json_table","json_table_primitive","json_value","lag","last_value","lead","listagg","ln","log","log10","lower","max","min","mod","nth_value","ntile","nullif","percent_rank","percentile_cont","percentile_disc","position","position_regex","power","rank","regr_avgx","regr_avgy","regr_count","regr_intercept","regr_r2","regr_slope","regr_sxx","regr_sxy","regr_syy","row_number","sin","sinh","sqrt","stddev_pop","stddev_samp","substring","substring_regex","sum","tan","tanh","translate","translate_regex","treat","trim","trim_array","unnest","upper","value_of","var_pop","var_samp","width_bucket"],o=["create table","insert into","primary key","foreign key","not null","alter table","add constraint","grouping sets","on overflow","character set","respect nulls","ignore nulls","nulls first","nulls last","depth first","breadth first"],c=s,l=["abs","acos","all","allocate","alter","and","any","are","array","array_agg","array_max_cardinality","as","asensitive","asin","asymmetric","at","atan","atomic","authorization","avg","begin","begin_frame","begin_partition","between","bigint","binary","blob","boolean","both","by","call","called","cardinality","cascaded","case","cast","ceil","ceiling","char","char_length","character","character_length","check","classifier","clob","close","coalesce","collate","collect","column","commit","condition","connect","constraint","contains","convert","copy","corr","corresponding","cos","cosh","count","covar_pop","covar_samp","create","cross","cube","cume_dist","current","current_catalog","current_date","current_default_transform_group","current_path","current_role","current_row","current_schema","current_time","current_timestamp","current_path","current_role","current_transform_group_for_type","current_user","cursor","cycle","date","day","deallocate","dec","decimal","decfloat","declare","default","define","delete","dense_rank","deref","describe","deterministic","disconnect","distinct","double","drop","dynamic","each","element","else","empty","end","end_frame","end_partition","end-exec","equals","escape","every","except","exec","execute","exists","exp","external","extract","false","fetch","filter","first_value","float","floor","for","foreign","frame_row","free","from","full","function","fusion","get","global","grant","group","grouping","groups","having","hold","hour","identity","in","indicator","initial","inner","inout","insensitive","insert","int","integer","intersect","intersection","interval","into","is","join","json_array","json_arrayagg","json_exists","json_object","json_objectagg","json_query","json_table","json_table_primitive","json_value","lag","language","large","last_value","lateral","lead","leading","left","like","like_regex","listagg","ln","local","localtime","localtimestamp","log","log10","lower","match","match_number","match_recognize","matches","max","member","merge","method","min","minute","mod","modifies","module","month","multiset","national","natural","nchar","nclob","new","no","none","normalize","not","nth_value","ntile","null","nullif","numeric","octet_length","occurrences_regex","of","offset","old","omit","on","one","only","open","or","order","out","outer","over","overlaps","overlay","parameter","partition","pattern","per","percent","percent_rank","percentile_cont","percentile_disc","period","portion","position","position_regex","power","precedes","precision","prepare","primary","procedure","ptf","range","rank","reads","real","recursive","ref","references","referencing","regr_avgx","regr_avgy","regr_count","regr_intercept","regr_r2","regr_slope","regr_sxx","regr_sxy","regr_syy","release","result","return","returns","revoke","right","rollback","rollup","row","row_number","rows","running","savepoint","scope","scroll","search","second","seek","select","sensitive","session_user","set","show","similar","sin","sinh","skip","smallint","some","specific","specifictype","sql","sqlexception","sqlstate","sqlwarning","sqrt","start","static","stddev_pop","stddev_samp","submultiset","subset","substring","substring_regex","succeeds","sum","symmetric","system","system_time","system_user","table","tablesample","tan","tanh","then","time","timestamp","timezone_hour","timezone_minute","to","trailing","translate","translate_regex","translation","treat","trigger","trim","trim_array","true","truncate","uescape","union","unique","unknown","unnest","update ","upper","user","using","value","values","value_of","var_pop","var_samp","varbinary","varchar","varying","versioning","when","whenever","where","width_bucket","window","with","within","without","year","add","asc","collation","desc","final","first","last","view"].filter((e=>!s.includes(e))),u={ +begin:r(/\b/,t(...c),/\s*\(/),keywords:{built_in:c}};return{name:"SQL", +case_insensitive:!0,illegal:/[{}]|<\//,keywords:{$pattern:/\b[\w\.]+/, +keyword:((e,{exceptions:r,when:t}={})=>{const n=t +;return r=r||[],e.map((e=>e.match(/\|\d+$/)||r.includes(e)?e:n(e)?e+"|0":e)) +})(l,{when:e=>e.length<3}),literal:a,type:i, +built_in:["current_catalog","current_date","current_default_transform_group","current_path","current_role","current_schema","current_transform_group_for_type","current_user","session_user","system_time","system_user","current_time","localtime","current_timestamp","localtimestamp"] +},contains:[{begin:t(...o),keywords:{$pattern:/[\w\.]+/,keyword:l.concat(o), +literal:a,type:i}},{className:"type", +begin:t("double precision","large object","with timezone","without timezone") +},u,{className:"variable",begin:/@[a-z0-9]+/},{className:"string",variants:[{ +begin:/'/,end:/'/,contains:[{begin:/''/}]}]},{begin:/"/,end:/"/,contains:[{ +begin:/""/}]},e.C_NUMBER_MODE,e.C_BLOCK_COMMENT_MODE,n,{className:"operator", +begin:/[-+*/=%^~]|&&?|\|\|?|!=?|<(?:=>?|<|>)?|>[>=]?/,relevance:0}]}}})()); +hljs.registerLanguage("swift",(()=>{"use strict";function e(e){ +return e?"string"==typeof e?e:e.source:null}function n(e){return a("(?=",e,")")} +function a(...n){return n.map((n=>e(n))).join("")}function t(...n){ +return"("+n.map((n=>e(n))).join("|")+")"} +const i=e=>a(/\b/,e,/\w$/.test(e)?/\b/:/\B/),s=["Protocol","Type"].map(i),u=["init","self"].map(i),c=["Any","Self"],r=["associatedtype","async","await",/as\?/,/as!/,"as","break","case","catch","class","continue","convenience","default","defer","deinit","didSet","do","dynamic","else","enum","extension","fallthrough",/fileprivate\(set\)/,"fileprivate","final","for","func","get","guard","if","import","indirect","infix",/init\?/,/init!/,"inout",/internal\(set\)/,"internal","in","is","lazy","let","mutating","nonmutating",/open\(set\)/,"open","operator","optional","override","postfix","precedencegroup","prefix",/private\(set\)/,"private","protocol",/public\(set\)/,"public","repeat","required","rethrows","return","set","some","static","struct","subscript","super","switch","throws","throw",/try\?/,/try!/,"try","typealias",/unowned\(safe\)/,/unowned\(unsafe\)/,"unowned","var","weak","where","while","willSet"],o=["false","nil","true"],l=["assignment","associativity","higherThan","left","lowerThan","none","right"],m=["#colorLiteral","#column","#dsohandle","#else","#elseif","#endif","#error","#file","#fileID","#fileLiteral","#filePath","#function","#if","#imageLiteral","#keyPath","#line","#selector","#sourceLocation","#warn_unqualified_access","#warning"],d=["abs","all","any","assert","assertionFailure","debugPrint","dump","fatalError","getVaList","isKnownUniquelyReferenced","max","min","numericCast","pointwiseMax","pointwiseMin","precondition","preconditionFailure","print","readLine","repeatElement","sequence","stride","swap","swift_unboxFromSwiftValueWithType","transcode","type","unsafeBitCast","unsafeDowncast","withExtendedLifetime","withUnsafeMutablePointer","withUnsafePointer","withVaList","withoutActuallyEscaping","zip"],p=t(/[/=\-+!*%<>&|^~?]/,/[\u00A1-\u00A7]/,/[\u00A9\u00AB]/,/[\u00AC\u00AE]/,/[\u00B0\u00B1]/,/[\u00B6\u00BB\u00BF\u00D7\u00F7]/,/[\u2016-\u2017]/,/[\u2020-\u2027]/,/[\u2030-\u203E]/,/[\u2041-\u2053]/,/[\u2055-\u205E]/,/[\u2190-\u23FF]/,/[\u2500-\u2775]/,/[\u2794-\u2BFF]/,/[\u2E00-\u2E7F]/,/[\u3001-\u3003]/,/[\u3008-\u3020]/,/[\u3030]/),F=t(p,/[\u0300-\u036F]/,/[\u1DC0-\u1DFF]/,/[\u20D0-\u20FF]/,/[\uFE00-\uFE0F]/,/[\uFE20-\uFE2F]/),b=a(p,F,"*"),h=t(/[a-zA-Z_]/,/[\u00A8\u00AA\u00AD\u00AF\u00B2-\u00B5\u00B7-\u00BA]/,/[\u00BC-\u00BE\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u00FF]/,/[\u0100-\u02FF\u0370-\u167F\u1681-\u180D\u180F-\u1DBF]/,/[\u1E00-\u1FFF]/,/[\u200B-\u200D\u202A-\u202E\u203F-\u2040\u2054\u2060-\u206F]/,/[\u2070-\u20CF\u2100-\u218F\u2460-\u24FF\u2776-\u2793]/,/[\u2C00-\u2DFF\u2E80-\u2FFF]/,/[\u3004-\u3007\u3021-\u302F\u3031-\u303F\u3040-\uD7FF]/,/[\uF900-\uFD3D\uFD40-\uFDCF\uFDF0-\uFE1F\uFE30-\uFE44]/,/[\uFE47-\uFEFE\uFF00-\uFFFD]/),f=t(h,/\d/,/[\u0300-\u036F\u1DC0-\u1DFF\u20D0-\u20FF\uFE20-\uFE2F]/),w=a(h,f,"*"),y=a(/[A-Z]/,f,"*"),g=["autoclosure",a(/convention\(/,t("swift","block","c"),/\)/),"discardableResult","dynamicCallable","dynamicMemberLookup","escaping","frozen","GKInspectable","IBAction","IBDesignable","IBInspectable","IBOutlet","IBSegueAction","inlinable","main","nonobjc","NSApplicationMain","NSCopying","NSManaged",a(/objc\(/,w,/\)/),"objc","objcMembers","propertyWrapper","requires_stored_property_inits","testable","UIApplicationMain","unknown","usableFromInline"],E=["iOS","iOSApplicationExtension","macOS","macOSApplicationExtension","macCatalyst","macCatalystApplicationExtension","watchOS","watchOSApplicationExtension","tvOS","tvOSApplicationExtension","swift"] +;return e=>{const p={match:/\s+/,relevance:0},h=e.COMMENT("/\\*","\\*/",{ +contains:["self"]}),v=[e.C_LINE_COMMENT_MODE,h],N={className:"keyword", +begin:a(/\./,n(t(...s,...u))),end:t(...s,...u),excludeBegin:!0},A={ +match:a(/\./,t(...r)),relevance:0 +},C=r.filter((e=>"string"==typeof e)).concat(["_|0"]),_={variants:[{ +className:"keyword", +match:t(...r.filter((e=>"string"!=typeof e)).concat(c).map(i),...u)}]},D={ +$pattern:t(/\b\w+/,/#\w+/),keyword:C.concat(m),literal:o},B=[N,A,_],k=[{ +match:a(/\./,t(...d)),relevance:0},{className:"built_in", +match:a(/\b/,t(...d),/(?=\()/)}],M={match:/->/,relevance:0},S=[M,{ +className:"operator",relevance:0,variants:[{match:b},{match:`\\.(\\.|${F})+`}] +}],x="([0-9a-fA-F]_*)+",I={className:"number",relevance:0,variants:[{ +match:"\\b(([0-9]_*)+)(\\.(([0-9]_*)+))?([eE][+-]?(([0-9]_*)+))?\\b"},{ +match:`\\b0x(${x})(\\.(${x}))?([pP][+-]?(([0-9]_*)+))?\\b`},{ +match:/\b0o([0-7]_*)+\b/},{match:/\b0b([01]_*)+\b/}]},O=(e="")=>({ +className:"subst",variants:[{match:a(/\\/,e,/[0\\tnr"']/)},{ +match:a(/\\/,e,/u\{[0-9a-fA-F]{1,8}\}/)}]}),T=(e="")=>({className:"subst", +match:a(/\\/,e,/[\t ]*(?:[\r\n]|\r\n)/)}),L=(e="")=>({className:"subst", +label:"interpol",begin:a(/\\/,e,/\(/),end:/\)/}),P=(e="")=>({begin:a(e,/"""/), +end:a(/"""/,e),contains:[O(e),T(e),L(e)]}),$=(e="")=>({begin:a(e,/"/), +end:a(/"/,e),contains:[O(e),L(e)]}),K={className:"string", +variants:[P(),P("#"),P("##"),P("###"),$(),$("#"),$("##"),$("###")]},j={ +match:a(/`/,w,/`/)},z=[j,{className:"variable",match:/\$\d+/},{ +className:"variable",match:`\\$${f}+`}],q=[{match:/(@|#)available/, +className:"keyword",starts:{contains:[{begin:/\(/,end:/\)/,keywords:E, +contains:[...S,I,K]}]}},{className:"keyword",match:a(/@/,t(...g))},{ +className:"meta",match:a(/@/,w)}],U={match:n(/\b[A-Z]/),relevance:0,contains:[{ +className:"type", +match:a(/(AV|CA|CF|CG|CI|CL|CM|CN|CT|MK|MP|MTK|MTL|NS|SCN|SK|UI|WK|XC)/,f,"+") +},{className:"type",match:y,relevance:0},{match:/[?!]+/,relevance:0},{ +match:/\.\.\./,relevance:0},{match:a(/\s+&\s+/,n(y)),relevance:0}]},Z={ +begin://,keywords:D,contains:[...v,...B,...q,M,U]};U.contains.push(Z) +;const G={begin:/\(/,end:/\)/,relevance:0,keywords:D,contains:["self",{ +match:a(w,/\s*:/),keywords:"_|0",relevance:0 +},...v,...B,...k,...S,I,K,...z,...q,U]},H={beginKeywords:"func",contains:[{ +className:"title",match:t(j.match,w,b),endsParent:!0,relevance:0},p]},R={ +begin://,contains:[...v,U]},V={begin:/\(/,end:/\)/,keywords:D, +contains:[{begin:t(n(a(w,/\s*:/)),n(a(w,/\s+/,w,/\s*:/))),end:/:/,relevance:0, +contains:[{className:"keyword",match:/\b_\b/},{className:"params",match:w}] +},...v,...B,...S,I,K,...q,U,G],endsParent:!0,illegal:/["']/},W={ +className:"function",match:n(/\bfunc\b/),contains:[H,R,V,p],illegal:[/\[/,/%/] +},X={className:"function",match:/\b(subscript|init[?!]?)\s*(?=[<(])/,keywords:{ +keyword:"subscript init init? init!",$pattern:/\w+[?!]?/},contains:[R,V,p], +illegal:/\[|%/},J={beginKeywords:"operator",end:e.MATCH_NOTHING_RE,contains:[{ +className:"title",match:b,endsParent:!0,relevance:0}]},Q={ +beginKeywords:"precedencegroup",end:e.MATCH_NOTHING_RE,contains:[{ +className:"title",match:y,relevance:0},{begin:/{/,end:/}/,relevance:0, +endsParent:!0,keywords:[...l,...o],contains:[U]}]};for(const e of K.variants){ +const n=e.contains.find((e=>"interpol"===e.label));n.keywords=D +;const a=[...B,...k,...S,I,K,...z];n.contains=[...a,{begin:/\(/,end:/\)/, +contains:["self",...a]}]}return{name:"Swift",keywords:D,contains:[...v,W,X,{ +className:"class",beginKeywords:"struct protocol class extension enum", +end:"\\{",excludeEnd:!0,keywords:D,contains:[e.inherit(e.TITLE_MODE,{ +begin:/[A-Za-z$_][\u00C0-\u02B80-9A-Za-z$_]*/}),...B]},J,Q,{ +beginKeywords:"import",end:/$/,contains:[...v],relevance:0 +},...B,...k,...S,I,K,...z,...q,U,G]}}})()); +hljs.registerLanguage("typescript",(()=>{"use strict" +;const e="[A-Za-z$_][0-9A-Za-z$_]*",n=["as","in","of","if","for","while","finally","var","new","function","do","return","void","else","break","catch","instanceof","with","throw","case","default","try","switch","continue","typeof","delete","let","yield","const","class","debugger","async","await","static","import","from","export","extends"],a=["true","false","null","undefined","NaN","Infinity"],s=[].concat(["setInterval","setTimeout","clearInterval","clearTimeout","require","exports","eval","isFinite","isNaN","parseFloat","parseInt","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape"],["arguments","this","super","console","window","document","localStorage","module","global"],["Intl","DataView","Number","Math","Date","String","RegExp","Object","Function","Boolean","Error","Symbol","Set","Map","WeakSet","WeakMap","Proxy","Reflect","JSON","Promise","Float64Array","Int16Array","Int32Array","Int8Array","Uint16Array","Uint32Array","Float32Array","Array","Uint8Array","Uint8ClampedArray","ArrayBuffer","BigInt64Array","BigUint64Array","BigInt"],["EvalError","InternalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError"]) +;function t(e){return r("(?=",e,")")}function r(...e){return e.map((e=>{ +return(n=e)?"string"==typeof n?n:n.source:null;var n})).join("")}return i=>{ +const c={$pattern:e, +keyword:n.concat(["type","namespace","typedef","interface","public","private","protected","implements","declare","abstract","readonly"]), +literal:a, +built_in:s.concat(["any","void","number","boolean","string","object","never","enum"]) +},o={className:"meta",begin:"@[A-Za-z$_][0-9A-Za-z$_]*"},l=(e,n,a)=>{ +const s=e.contains.findIndex((e=>e.label===n)) +;if(-1===s)throw Error("can not find mode to replace");e.contains.splice(s,1,a) +},b=(i=>{const c=e,o={begin:/<[A-Za-z0-9\\._:-]+/, +end:/\/[A-Za-z0-9\\._:-]+>|\/>/,isTrulyOpeningTag:(e,n)=>{ +const a=e[0].length+e.index,s=e.input[a];"<"!==s?">"===s&&(((e,{after:n})=>{ +const a="", +returnBegin:!0,end:"\\s*=>",contains:[{className:"params",variants:[{ +begin:i.UNDERSCORE_IDENT_RE,relevance:0},{className:null,begin:/\(\s*\)/,skip:!0 +},{begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0,keywords:l,contains:f}]}] +},{begin:/,/,relevance:0},{className:"",begin:/\s/,end:/\s*/,skip:!0},{ +variants:[{begin:"<>",end:""},{begin:o.begin,"on:begin":o.isTrulyOpeningTag, +end:o.end}],subLanguage:"xml",contains:[{begin:o.begin,end:o.end,skip:!0, +contains:["self"]}]}],relevance:0},{className:"function", +beginKeywords:"function",end:/[{;]/,excludeEnd:!0,keywords:l, +contains:["self",i.inherit(i.TITLE_MODE,{begin:c}),A],illegal:/%/},{ +beginKeywords:"while if switch catch for"},{className:"function", +begin:i.UNDERSCORE_IDENT_RE+"\\([^()]*(\\([^()]*(\\([^()]*\\)[^()]*)*\\)[^()]*)*\\)\\s*\\{", +returnBegin:!0,contains:[A,i.inherit(i.TITLE_MODE,{begin:c})]},{variants:[{ +begin:"\\."+c},{begin:"\\$"+c}],relevance:0},{className:"class", +beginKeywords:"class",end:/[{;=]/,excludeEnd:!0,illegal:/[:"[\]]/,contains:[{ +beginKeywords:"extends"},i.UNDERSCORE_TITLE_MODE]},{begin:/\b(?=constructor)/, +end:/[{;]/,excludeEnd:!0,contains:[i.inherit(i.TITLE_MODE,{begin:c}),"self",A] +},{begin:"(get|set)\\s+(?="+c+"\\()",end:/\{/,keywords:"get set", +contains:[i.inherit(i.TITLE_MODE,{begin:c}),{begin:/\(\)/},A]},{begin:/\$[(.]/}] +}})(i) +;return Object.assign(b.keywords,c),b.exports.PARAMS_CONTAINS.push(o),b.contains=b.contains.concat([o,{ +beginKeywords:"namespace",end:/\{/,excludeEnd:!0},{beginKeywords:"interface", +end:/\{/,excludeEnd:!0,keywords:"interface extends" +}]),l(b,"shebang",i.SHEBANG()),l(b,"use_strict",{className:"meta",relevance:10, +begin:/^\s*['"]use strict['"]/ +}),b.contains.find((e=>"function"===e.className)).relevance=0,Object.assign(b,{ +name:"TypeScript",aliases:["ts","tsx"]}),b}})()); +hljs.registerLanguage("vbnet",(()=>{"use strict";function e(e){ +return e?"string"==typeof e?e:e.source:null}function n(...n){ +return n.map((n=>e(n))).join("")}function t(...n){ +return"("+n.map((n=>e(n))).join("|")+")"}return e=>{ +const a=/\d{1,2}\/\d{1,2}\/\d{4}/,i=/\d{4}-\d{1,2}-\d{1,2}/,s=/(\d|1[012])(:\d+){0,2} *(AM|PM)/,r=/\d{1,2}(:\d{1,2}){1,2}/,o={ +className:"literal",variants:[{begin:n(/# */,t(i,a),/ *#/)},{ +begin:n(/# */,r,/ *#/)},{begin:n(/# */,s,/ *#/)},{ +begin:n(/# */,t(i,a),/ +/,t(s,r),/ *#/)}]},l=e.COMMENT(/'''/,/$/,{contains:[{ +className:"doctag",begin:/<\/?/,end:/>/}]}),c=e.COMMENT(null,/$/,{variants:[{ +begin:/'/},{begin:/([\t ]|^)REM(?=\s)/}]});return{name:"Visual Basic .NET", +aliases:["vb"],case_insensitive:!0,classNameAliases:{label:"symbol"},keywords:{ +keyword:"addhandler alias aggregate ansi as async assembly auto binary by byref byval call case catch class compare const continue custom declare default delegate dim distinct do each equals else elseif end enum erase error event exit explicit finally for friend from function get global goto group handles if implements imports in inherits interface into iterator join key let lib loop me mid module mustinherit mustoverride mybase myclass namespace narrowing new next notinheritable notoverridable of off on operator option optional order overloads overridable overrides paramarray partial preserve private property protected public raiseevent readonly redim removehandler resume return select set shadows shared skip static step stop structure strict sub synclock take text then throw to try unicode until using when where while widening with withevents writeonly yield", +built_in:"addressof and andalso await directcast gettype getxmlnamespace is isfalse isnot istrue like mod nameof new not or orelse trycast typeof xor cbool cbyte cchar cdate cdbl cdec cint clng cobj csbyte cshort csng cstr cuint culng cushort", +type:"boolean byte char date decimal double integer long object sbyte short single string uinteger ulong ushort", +literal:"true false nothing"}, +illegal:"//|\\{|\\}|endif|gosub|variant|wend|^\\$ ",contains:[{ +className:"string",begin:/"(""|[^/n])"C\b/},{className:"string",begin:/"/, +end:/"/,illegal:/\n/,contains:[{begin:/""/}]},o,{className:"number",relevance:0, +variants:[{begin:/\b\d[\d_]*((\.[\d_]+(E[+-]?[\d_]+)?)|(E[+-]?[\d_]+))[RFD@!#]?/ +},{begin:/\b\d[\d_]*((U?[SIL])|[%&])?/},{begin:/&H[\dA-F_]+((U?[SIL])|[%&])?/},{ +begin:/&O[0-7_]+((U?[SIL])|[%&])?/},{begin:/&B[01_]+((U?[SIL])|[%&])?/}]},{ +className:"label",begin:/^\w+:/},l,c,{className:"meta", +begin:/[\t ]*#(const|disable|else|elseif|enable|end|externalsource|if|region)\b/, +end:/$/,keywords:{ +"meta-keyword":"const disable else elseif enable end externalsource if region then" +},contains:[c]}]}}})()); +hljs.registerLanguage("yaml",(()=>{"use strict";return e=>{ +var n="true false yes no null",a="[\\w#;/?:@&=+$,.~*'()[\\]]+",s={ +className:"string",relevance:0,variants:[{begin:/'/,end:/'/},{begin:/"/,end:/"/ +},{begin:/\S+/}],contains:[e.BACKSLASH_ESCAPE,{className:"template-variable", +variants:[{begin:/\{\{/,end:/\}\}/},{begin:/%\{/,end:/\}/}]}]},i=e.inherit(s,{ +variants:[{begin:/'/,end:/'/},{begin:/"/,end:/"/},{begin:/[^\s,{}[\]]+/}]}),l={ +end:",",endsWithParent:!0,excludeEnd:!0,keywords:n,relevance:0},t={begin:/\{/, +end:/\}/,contains:[l],illegal:"\\n",relevance:0},g={begin:"\\[",end:"\\]", +contains:[l],illegal:"\\n",relevance:0},b=[{className:"attr",variants:[{ +begin:"\\w[\\w :\\/.-]*:(?=[ \t]|$)"},{begin:'"\\w[\\w :\\/.-]*":(?=[ \t]|$)'},{ +begin:"'\\w[\\w :\\/.-]*':(?=[ \t]|$)"}]},{className:"meta",begin:"^---\\s*$", +relevance:10},{className:"string", +begin:"[\\|>]([1-9]?[+-])?[ ]*\\n( +)[^ ][^\\n]*\\n(\\2[^\\n]+\\n?)*"},{ +begin:"<%[%=-]?",end:"[%-]?%>",subLanguage:"ruby",excludeBegin:!0,excludeEnd:!0, +relevance:0},{className:"type",begin:"!\\w+!"+a},{className:"type", +begin:"!<"+a+">"},{className:"type",begin:"!"+a},{className:"type",begin:"!!"+a +},{className:"meta",begin:"&"+e.UNDERSCORE_IDENT_RE+"$"},{className:"meta", +begin:"\\*"+e.UNDERSCORE_IDENT_RE+"$"},{className:"bullet",begin:"-(?=[ ]|$)", +relevance:0},e.HASH_COMMENT_MODE,{beginKeywords:n,keywords:{literal:n}},{ +className:"number", +begin:"\\b[0-9]{4}(-[0-9][0-9]){0,2}([Tt \\t][0-9][0-9]?(:[0-9][0-9]){2})?(\\.[0-9]*)?([ \\t])*(Z|[-+][0-9][0-9]?(:[0-9][0-9])?)?\\b" +},{className:"number",begin:e.C_NUMBER_RE+"\\b",relevance:0},t,g,s],r=[...b] +;return r.pop(),r.push(i),l.contains=r,{name:"YAML",case_insensitive:!0, +aliases:["yml"],contains:b}}})()); \ No newline at end of file diff --git a/resources/JUnitReport/js/highlightjs-line-numbers.min.js b/resources/JUnitReport/js/highlightjs-line-numbers.min.js new file mode 100644 index 0000000..8548576 --- /dev/null +++ b/resources/JUnitReport/js/highlightjs-line-numbers.min.js @@ -0,0 +1,24 @@ +/* +The MIT License (MIT) + +Copyright (c) 2017 Yauheni Pakala + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + */ +!function(r,o){"use strict";var e,i="hljs-ln",l="hljs-ln-line",h="hljs-ln-code",s="hljs-ln-numbers",c="hljs-ln-n",m="data-line-number",a=/\r\n|\r|\n/g;function u(e){for(var n=e.toString(),t=e.anchorNode;"TD"!==t.nodeName;)t=t.parentNode;for(var r=e.focusNode;"TD"!==r.nodeName;)r=r.parentNode;var o=parseInt(t.dataset.lineNumber),a=parseInt(r.dataset.lineNumber);if(o==a)return n;var i,l=t.textContent,s=r.textContent;for(a
{6}',[l,s,c,m,h,o+n.startFrom,0{1}',[i,r])}return e}(e.innerHTML,o)}function v(e){var n=e.className;if(/hljs-/.test(n)){for(var t=g(e.innerHTML),r=0,o="";r{1}
\n',[n,0 + + + + Coverage Report > com.profile.matcher + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
MatcherApplication + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-1/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-1/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..678ecb4 --- /dev/null +++ b/resources/JUnitReport/ns-1/index_SORT_BY_BLOCK.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
MatcherApplication + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-1/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-1/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..1235494 --- /dev/null +++ b/resources/JUnitReport/ns-1/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
MatcherApplication + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-1/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-1/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..1e7ae92 --- /dev/null +++ b/resources/JUnitReport/ns-1/index_SORT_BY_CLASS.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
MatcherApplication + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-1/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-1/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..314fe34 --- /dev/null +++ b/resources/JUnitReport/ns-1/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
MatcherApplication + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-1/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-1/index_SORT_BY_LINE.html new file mode 100644 index 0000000..2dc1556 --- /dev/null +++ b/resources/JUnitReport/ns-1/index_SORT_BY_LINE.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
MatcherApplication + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-1/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-1/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..da1ccf9 --- /dev/null +++ b/resources/JUnitReport/ns-1/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
MatcherApplication + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-1/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-1/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..51551e2 --- /dev/null +++ b/resources/JUnitReport/ns-1/index_SORT_BY_METHOD.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
MatcherApplication + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-1/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-1/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..53ee67f --- /dev/null +++ b/resources/JUnitReport/ns-1/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
MatcherApplication + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-1/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-1/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..b80ba31 --- /dev/null +++ b/resources/JUnitReport/ns-1/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
MatcherApplication + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-1/sources/source-1.html b/resources/JUnitReport/ns-1/sources/source-1.html new file mode 100644 index 0000000..fbb633d --- /dev/null +++ b/resources/JUnitReport/ns-1/sources/source-1.html @@ -0,0 +1,133 @@ + + + + + + + + Coverage Report > MatcherApplication + + + + + + +
+ + +

Coverage Summary for Class: MatcherApplication (com.profile.matcher)

+ + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
MatcherApplication + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
MatcherApplication$$SpringCGLIB$$0
Total + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + +
+ package com.profile.matcher;
+ 
+ import org.springframework.boot.SpringApplication;
+ import org.springframework.boot.autoconfigure.SpringBootApplication;
+ import org.springframework.boot.context.properties.EnableConfigurationProperties;
+ import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
+ import org.springframework.web.servlet.config.annotation.EnableWebMvc;
+ 
+ @SpringBootApplication
+ @EnableConfigurationProperties
+ @EnableWebMvc
+ @EnableJpaRepositories
+ public class MatcherApplication {
+ 
+ 	public static void main(String[] args) {
+ 		SpringApplication.run(MatcherApplication.class, args);
+ 	}
+ 
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-2/index.html b/resources/JUnitReport/ns-2/index.html new file mode 100644 index 0000000..40391c7 --- /dev/null +++ b/resources/JUnitReport/ns-2/index.html @@ -0,0 +1,278 @@ + + + + + + Coverage Report > com.profile.matcher.arhitecture + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.arhitecture

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-2/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-2/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..3f95375 --- /dev/null +++ b/resources/JUnitReport/ns-2/index_SORT_BY_BLOCK.html @@ -0,0 +1,278 @@ + + + + + + Coverage Report > com.profile.matcher.arhitecture + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.arhitecture

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-2/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-2/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..6656ca1 --- /dev/null +++ b/resources/JUnitReport/ns-2/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,278 @@ + + + + + + Coverage Report > com.profile.matcher.arhitecture + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.arhitecture

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-2/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-2/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..d55c658 --- /dev/null +++ b/resources/JUnitReport/ns-2/index_SORT_BY_CLASS.html @@ -0,0 +1,278 @@ + + + + + + Coverage Report > com.profile.matcher.arhitecture + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.arhitecture

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-2/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-2/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..cd554d3 --- /dev/null +++ b/resources/JUnitReport/ns-2/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,278 @@ + + + + + + Coverage Report > com.profile.matcher.arhitecture + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.arhitecture

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-2/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-2/index_SORT_BY_LINE.html new file mode 100644 index 0000000..a89fcff --- /dev/null +++ b/resources/JUnitReport/ns-2/index_SORT_BY_LINE.html @@ -0,0 +1,278 @@ + + + + + + Coverage Report > com.profile.matcher.arhitecture + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.arhitecture

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-2/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-2/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..e01bf67 --- /dev/null +++ b/resources/JUnitReport/ns-2/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,278 @@ + + + + + + Coverage Report > com.profile.matcher.arhitecture + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.arhitecture

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-2/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-2/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..e91fa3e --- /dev/null +++ b/resources/JUnitReport/ns-2/index_SORT_BY_METHOD.html @@ -0,0 +1,278 @@ + + + + + + Coverage Report > com.profile.matcher.arhitecture + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.arhitecture

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-2/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-2/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..972a682 --- /dev/null +++ b/resources/JUnitReport/ns-2/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,278 @@ + + + + + + Coverage Report > com.profile.matcher.arhitecture + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.arhitecture

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-2/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-2/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..5419a93 --- /dev/null +++ b/resources/JUnitReport/ns-2/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,278 @@ + + + + + + Coverage Report > com.profile.matcher.arhitecture + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.arhitecture

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.arhitecture + + 100% + + + (6/6) + + + + 61.5% + + + (8/13) + + + + 48% + + + (12/25) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-2/sources/source-1.html b/resources/JUnitReport/ns-2/sources/source-1.html new file mode 100644 index 0000000..e2db263 --- /dev/null +++ b/resources/JUnitReport/ns-2/sources/source-1.html @@ -0,0 +1,113 @@ + + + + + + + + Coverage Report > BaseAssembler + + + + + + +
+ + +

Coverage Summary for Class: BaseAssembler (com.profile.matcher.arhitecture)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
BaseAssembler + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
+ +
+
+ + +
+ package com.profile.matcher.arhitecture;
+ 
+ import java.util.List;
+ 
+ public abstract class BaseAssembler<T, D> extends BaseLogging {
+     public abstract D toResource(T t);
+ 
+     public abstract List<D> toCollectionResource(List<T> t);
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-2/sources/source-2.html b/resources/JUnitReport/ns-2/sources/source-2.html new file mode 100644 index 0000000..c79a20f --- /dev/null +++ b/resources/JUnitReport/ns-2/sources/source-2.html @@ -0,0 +1,121 @@ + + + + + + + + Coverage Report > BaseCommand + + + + + + +
+ + +

Coverage Summary for Class: BaseCommand (com.profile.matcher.arhitecture)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
BaseCommand + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 20% + + + (1/5) + +
+ +
+
+ + +
+ package com.profile.matcher.arhitecture;
+ 
+ public abstract class BaseCommand<T> extends BaseLogging {
+     protected boolean canExecute() {
+         return true;
+     }
+ 
+     public T execute() {
+         if (canExecute()) {
+             return doExecute();
+         }
+ 
+         throw new RuntimeException("shouldExecute() returned false");
+     }
+ 
+     protected abstract T doExecute();
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-2/sources/source-3.html b/resources/JUnitReport/ns-2/sources/source-3.html new file mode 100644 index 0000000..b86367a --- /dev/null +++ b/resources/JUnitReport/ns-2/sources/source-3.html @@ -0,0 +1,117 @@ + + + + + + + + Coverage Report > BaseController + + + + + + +
+ + +

Coverage Summary for Class: BaseController (com.profile.matcher.arhitecture)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
BaseController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
+ +
+
+ + +
+ package com.profile.matcher.arhitecture;
+ 
+ import org.springframework.beans.factory.BeanFactory;
+ import org.springframework.beans.factory.annotation.Autowired;
+ 
+ public abstract class BaseController extends BaseLogging {
+     @Autowired
+     protected BeanFactory beanFactory;
+ 
+     protected <T> T getCommand(Class<T> commandType, Object... args) {
+         return beanFactory.getBean(commandType, args);
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-2/sources/source-4.html b/resources/JUnitReport/ns-2/sources/source-4.html new file mode 100644 index 0000000..c926de6 --- /dev/null +++ b/resources/JUnitReport/ns-2/sources/source-4.html @@ -0,0 +1,139 @@ + + + + + + + + Coverage Report > BaseException + + + + + + +
+ + +

Coverage Summary for Class: BaseException (com.profile.matcher.arhitecture)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
BaseException + + 100% + + + (1/1) + + + + 25% + + + (1/4) + + + + 25% + + + (3/12) + +
+ +
+
+ + +
+ package com.profile.matcher.arhitecture;
+ 
+ import org.springframework.http.HttpStatus;
+ 
+ import static com.profile.matcher.utils.Constants.ErrorCode.DEFAULT_ERROR_CODE;
+ 
+ public class BaseException extends RuntimeException {
+ 
+     private final String code;
+     private final HttpStatus status;
+ 
+     public BaseException(String message) {
+         super(message);
+         this.code = DEFAULT_ERROR_CODE;
+         this.status = HttpStatus.INTERNAL_SERVER_ERROR;
+     }
+ 
+     public BaseException(String message, Throwable cause) {
+         super(message, cause);
+         this.code = DEFAULT_ERROR_CODE;
+         this.status = HttpStatus.INTERNAL_SERVER_ERROR;
+     }
+ 
+     public BaseException(String message, Throwable cause, String code, HttpStatus status) {
+         super(message, cause);
+         this.code = code;
+         this.status = status;
+     }
+ 
+     public BaseException(String message, String code, HttpStatus status) {
+         super(message);
+         this.status = status;
+         this.code = code;
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-2/sources/source-5.html b/resources/JUnitReport/ns-2/sources/source-5.html new file mode 100644 index 0000000..6546352 --- /dev/null +++ b/resources/JUnitReport/ns-2/sources/source-5.html @@ -0,0 +1,119 @@ + + + + + + + + Coverage Report > BaseLogging + + + + + + +
+ + +

Coverage Summary for Class: BaseLogging (com.profile.matcher.arhitecture)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
BaseLogging + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (4/4) + +
+ +
+
+ + +
+ package com.profile.matcher.arhitecture;
+ 
+ import org.slf4j.Logger;
+ import org.slf4j.LoggerFactory;
+ import org.slf4j.Marker;
+ import org.slf4j.MarkerFactory;
+ 
+ public abstract class BaseLogging {
+     private final Logger LOG = LoggerFactory.getLogger(getClass());
+ 
+     public void writeLog(String message, Object... args) {
+         Marker marker = MarkerFactory.getMarker(String.valueOf(getClass()));
+         LOG.info(marker, message, args);
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-2/sources/source-6.html b/resources/JUnitReport/ns-2/sources/source-6.html new file mode 100644 index 0000000..2c058e7 --- /dev/null +++ b/resources/JUnitReport/ns-2/sources/source-6.html @@ -0,0 +1,108 @@ + + + + + + + + Coverage Report > BaseService + + + + + + +
+ + +

Coverage Summary for Class: BaseService (com.profile.matcher.arhitecture)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
BaseService + + 100% + + + (1/1) + + + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
+ +
+
+ + +
+ package com.profile.matcher.arhitecture;
+ 
+ public abstract class BaseService extends BaseLogging {
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-3/index.html b/resources/JUnitReport/ns-3/index.html new file mode 100644 index 0000000..54973f9 --- /dev/null +++ b/resources/JUnitReport/ns-3/index.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.assembler + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.assembler

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-3/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-3/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..5b7a84a --- /dev/null +++ b/resources/JUnitReport/ns-3/index_SORT_BY_BLOCK.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.assembler + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.assembler

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-3/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-3/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..b26aee9 --- /dev/null +++ b/resources/JUnitReport/ns-3/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.assembler + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.assembler

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-3/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-3/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..7411eae --- /dev/null +++ b/resources/JUnitReport/ns-3/index_SORT_BY_CLASS.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.assembler + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.assembler

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-3/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-3/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..ba99d60 --- /dev/null +++ b/resources/JUnitReport/ns-3/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.assembler + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.assembler

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-3/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-3/index_SORT_BY_LINE.html new file mode 100644 index 0000000..09685c9 --- /dev/null +++ b/resources/JUnitReport/ns-3/index_SORT_BY_LINE.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.assembler + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.assembler

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-3/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-3/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..99076a6 --- /dev/null +++ b/resources/JUnitReport/ns-3/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.assembler + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.assembler

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-3/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-3/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..9df60a0 --- /dev/null +++ b/resources/JUnitReport/ns-3/index_SORT_BY_METHOD.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.assembler + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.assembler

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-3/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-3/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..ae2f6ec --- /dev/null +++ b/resources/JUnitReport/ns-3/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.assembler + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.assembler

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-3/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-3/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..aee945f --- /dev/null +++ b/resources/JUnitReport/ns-3/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.assembler + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.assembler

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.assembler + + 100% + + + (4/4) + + + + 41.7% + + + (5/12) + + + + 43.4% + + + (33/76) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-3/sources/source-1.html b/resources/JUnitReport/ns-3/sources/source-1.html new file mode 100644 index 0000000..4e530d9 --- /dev/null +++ b/resources/JUnitReport/ns-3/sources/source-1.html @@ -0,0 +1,141 @@ + + + + + + + + Coverage Report > ClanAssembler + + + + + + +
+ + +

Coverage Summary for Class: ClanAssembler (com.profile.matcher.assembler)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
ClanAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 8.3% + + + (1/12) + +
+ +
+
+ + +
+ package com.profile.matcher.assembler;
+ 
+ import com.profile.matcher.arhitecture.BaseAssembler;
+ import com.profile.matcher.dto.player.ClanDto;
+ import com.profile.matcher.entity.player.Clan;
+ import org.springframework.stereotype.Component;
+ import org.springframework.util.CollectionUtils;
+ 
+ import java.util.ArrayList;
+ import java.util.List;
+ 
+ @Component
+ public class ClanAssembler extends BaseAssembler<Clan, ClanDto> {
+ 
+     @Override
+     public ClanDto toResource(Clan clan) {
+         ClanDto clanDto = new ClanDto();
+ 
+         if (null != clan) {
+             clanDto.setId(clan.getIdClan());
+             clanDto.setName(clan.getName());
+         }
+         return clanDto;
+     }
+ 
+     @Override
+     public List<ClanDto> toCollectionResource(List<Clan> clans) {
+         List<ClanDto> clanDtos = new ArrayList<>();
+ 
+         if (!CollectionUtils.isEmpty(clans)) {
+             for (Clan clan : clans) {
+                 clanDtos.add(toResource(clan));
+             }
+         }
+         return clanDtos;
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-3/sources/source-2.html b/resources/JUnitReport/ns-3/sources/source-2.html new file mode 100644 index 0000000..43961cf --- /dev/null +++ b/resources/JUnitReport/ns-3/sources/source-2.html @@ -0,0 +1,144 @@ + + + + + + + + Coverage Report > DeviceAssembler + + + + + + +
+ + +

Coverage Summary for Class: DeviceAssembler (com.profile.matcher.assembler)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
DeviceAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
+ +
+
+ + +
+ package com.profile.matcher.assembler;
+ 
+ import com.profile.matcher.arhitecture.BaseAssembler;
+ import com.profile.matcher.dto.player.DeviceDto;
+ import com.profile.matcher.entity.player.Device;
+ import org.springframework.stereotype.Component;
+ import org.springframework.util.CollectionUtils;
+ 
+ import java.util.ArrayList;
+ import java.util.List;
+ 
+ @Component
+ public class DeviceAssembler extends BaseAssembler<Device, DeviceDto> {
+ 
+ 
+     @Override
+     public DeviceDto toResource(Device device) {
+         DeviceDto deviceDto = new DeviceDto();
+ 
+         if (null != device) {
+             deviceDto.setId(device.getIdDevice());
+             deviceDto.setModel(device.getModel());
+             deviceDto.setCarrier(device.getCarrier());
+             deviceDto.setFirmware(device.getFirmware());
+         }
+         return deviceDto;
+     }
+ 
+     @Override
+     public List<DeviceDto> toCollectionResource(List<Device> devices) {
+         List<DeviceDto> deviceDtos = new ArrayList<>();
+ 
+         if (!CollectionUtils.isEmpty(devices)) {
+             for (Device device : devices) {
+                 deviceDtos.add(toResource(device));
+             }
+         }
+         return deviceDtos;
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-3/sources/source-3.html b/resources/JUnitReport/ns-3/sources/source-3.html new file mode 100644 index 0000000..93cf26b --- /dev/null +++ b/resources/JUnitReport/ns-3/sources/source-3.html @@ -0,0 +1,149 @@ + + + + + + + + Coverage Report > InventoryAssembler + + + + + + +
+ + +

Coverage Summary for Class: InventoryAssembler (com.profile.matcher.assembler)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
InventoryAssembler + + 100% + + + (1/1) + + + + 33.3% + + + (1/3) + + + + 7.1% + + + (1/14) + +
+ +
+
+ + +
+ package com.profile.matcher.assembler;
+ 
+ import com.profile.matcher.arhitecture.BaseAssembler;
+ import com.profile.matcher.entity.player.Inventory;
+ import org.springframework.stereotype.Component;
+ import org.springframework.util.CollectionUtils;
+ 
+ import java.util.ArrayList;
+ import java.util.HashMap;
+ import java.util.List;
+ import java.util.Map;
+ 
+ @Component
+ public class InventoryAssembler extends BaseAssembler<Inventory, Map<String, String>> {
+ 
+     @Override
+     public Map<String, String> toResource(Inventory inventory) {
+         Map<String, String> inventoryDto = new HashMap<>();
+ 
+         if (null != inventory) {
+             // Add cash and coins to the JSON object
+             inventoryDto.put("cash", inventory.getCash().toString());
+             inventoryDto.put("coins", inventory.getCoins().toString());
+ 
+             // Add items to the JSON object
+             if (null != inventory.getItems()) {
+                 inventory.getItems().forEach(item -> inventoryDto.put(item.getName(), item.getQuantity().toString()));
+             }
+         }
+ 
+         return inventoryDto;
+     }
+ 
+     @Override
+     public List<Map<String, String>> toCollectionResource(List<Inventory> inventories) {
+         List<Map<String, String>> inventoryDtos = new ArrayList<>();
+ 
+         if (!CollectionUtils.isEmpty(inventories)) {
+             for (Inventory inventory : inventories) {
+                 inventoryDtos.add(toResource(inventory));
+             }
+         }
+         return inventoryDtos;
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-3/sources/source-4.html b/resources/JUnitReport/ns-3/sources/source-4.html new file mode 100644 index 0000000..8d7bc99 --- /dev/null +++ b/resources/JUnitReport/ns-3/sources/source-4.html @@ -0,0 +1,178 @@ + + + + + + + + Coverage Report > PlayerAssembler + + + + + + +
+ + +

Coverage Summary for Class: PlayerAssembler (com.profile.matcher.assembler)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
PlayerAssembler + + 100% + + + (1/1) + + + + 66.7% + + + (2/3) + + + + 83.3% + + + (30/36) + +
+ +
+
+ + +
+ package com.profile.matcher.assembler;
+ 
+ import com.profile.matcher.arhitecture.BaseAssembler;
+ import com.profile.matcher.dto.player.PlayerDto;
+ import com.profile.matcher.entity.campaign.Campaign;
+ import com.profile.matcher.entity.player.Player;
+ import com.profile.matcher.utils.DateHelper;
+ import org.springframework.beans.factory.annotation.Autowired;
+ import org.springframework.stereotype.Component;
+ import org.springframework.util.CollectionUtils;
+ 
+ import java.util.ArrayList;
+ import java.util.List;
+ import java.util.stream.Collectors;
+ 
+ @Component
+ public class PlayerAssembler extends BaseAssembler<Player, PlayerDto> {
+ 
+     @Autowired
+     private DeviceAssembler deviceAssembler;
+     @Autowired
+     private InventoryAssembler inventoryAssembler;
+     @Autowired
+     private ClanAssembler clanAssembler;
+ 
+     @Override
+     public PlayerDto toResource(Player player) {
+         PlayerDto playerDto = new PlayerDto();
+         if (null != player) {
+             playerDto.setPlayer_id(player.getIdPlayer());
+             playerDto.setCredential(player.getCredential());
+             playerDto.setCreated(DateHelper.toFormattedDateTimeString(player.getCreated()));
+             playerDto.setModified(DateHelper.toFormattedDateTimeString(player.getModified()));
+             playerDto.setLast_session(DateHelper.toFormattedDateTimeString(player.getLastSession()));
+             playerDto.setTotal_spent(player.getTotalSpent());
+             playerDto.setTotal_refund(player.getTotalRefund());
+             playerDto.setTotal_transactions(player.getTotalTransactions());
+             playerDto.setLast_purchase(DateHelper.toFormattedDateTimeString(player.getLastPurchase()));
+             // Set the names for the player's campaigns
+             if (!CollectionUtils.isEmpty(player.getCampaigns())) {
+                 playerDto.setActive_campaigns(
+                         player.getCampaigns()
+                                 .stream()
+                                 .map(Campaign::getName)
+                                 .collect(Collectors.toList())
+                 );
+             }
+             playerDto.setDevices(deviceAssembler.toCollectionResource(player.getDevices()));
+             playerDto.setLevel(player.getLevel());
+             playerDto.setXp(player.getXp());
+             playerDto.setTotal_playtime(player.getTotalPlaytime());
+             playerDto.setCountry(player.getCountry());
+             playerDto.setLanguage(player.getLanguage());
+             playerDto.setBirthdate(DateHelper.toFormattedDateTimeString(player.getBirthdate()));
+             playerDto.setGender(player.getGender());
+             playerDto.setInventory(inventoryAssembler.toResource(player.getInventory()));
+             playerDto.setClan(clanAssembler.toResource(player.getClan()));
+             playerDto.set_customField(player.getCustomField());
+         }
+         return playerDto;
+     }
+ 
+     @Override
+     public List<PlayerDto> toCollectionResource(List<Player> players) {
+         List<PlayerDto> playerDtos = new ArrayList<>();
+ 
+         if (!CollectionUtils.isEmpty(players)) {
+             for (Player player : players) {
+                 playerDtos.add(toResource(player));
+             }
+         }
+         return playerDtos;
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-4/index.html b/resources/JUnitReport/ns-4/index.html new file mode 100644 index 0000000..31237e8 --- /dev/null +++ b/resources/JUnitReport/ns-4/index.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.command + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.command

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-4/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-4/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..c6598c4 --- /dev/null +++ b/resources/JUnitReport/ns-4/index_SORT_BY_BLOCK.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.command + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.command

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-4/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-4/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..1d1a5b1 --- /dev/null +++ b/resources/JUnitReport/ns-4/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.command + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.command

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-4/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-4/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..d1084ce --- /dev/null +++ b/resources/JUnitReport/ns-4/index_SORT_BY_CLASS.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.command + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.command

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-4/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-4/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..b5b70f0 --- /dev/null +++ b/resources/JUnitReport/ns-4/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.command + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.command

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-4/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-4/index_SORT_BY_LINE.html new file mode 100644 index 0000000..9d2d42f --- /dev/null +++ b/resources/JUnitReport/ns-4/index_SORT_BY_LINE.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.command + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.command

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-4/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-4/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..0a77d92 --- /dev/null +++ b/resources/JUnitReport/ns-4/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.command + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.command

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-4/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-4/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..63d5d76 --- /dev/null +++ b/resources/JUnitReport/ns-4/index_SORT_BY_METHOD.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.command + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.command

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-4/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-4/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..431d43c --- /dev/null +++ b/resources/JUnitReport/ns-4/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.command + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.command

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-4/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-4/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..2f95f49 --- /dev/null +++ b/resources/JUnitReport/ns-4/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.command + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.command

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.command + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-4/sources/source-1.html b/resources/JUnitReport/ns-4/sources/source-1.html new file mode 100644 index 0000000..a6ff2da --- /dev/null +++ b/resources/JUnitReport/ns-4/sources/source-1.html @@ -0,0 +1,131 @@ + + + + + + + + Coverage Report > PlayerCommand + + + + + + +
+ + +

Coverage Summary for Class: PlayerCommand (com.profile.matcher.command)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
PlayerCommand + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (3/3) + +
+ +
+
+ + +
+ package com.profile.matcher.command;
+ 
+ import com.profile.matcher.arhitecture.BaseCommand;
+ import com.profile.matcher.entity.player.Player;
+ import com.profile.matcher.service.PlayerService;
+ import lombok.RequiredArgsConstructor;
+ import org.springframework.beans.factory.annotation.Autowired;
+ import org.springframework.context.annotation.Scope;
+ import org.springframework.stereotype.Component;
+ 
+ import java.util.Optional;
+ 
+ @Component
+ @Scope("prototype")
+ @RequiredArgsConstructor
+ public class PlayerCommand extends BaseCommand<Optional<Player>> {
+     @Autowired
+     private PlayerService playerService;
+ 
+     private final String idPlayer;
+ 
+     @Override
+     public Optional<Player> doExecute() {
+         writeLog("PlayerCommand.doExecute() - command IN with idPlayer: {}", idPlayer);
+         return this.playerService.getPlayerDetails(idPlayer);
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-5/index.html b/resources/JUnitReport/ns-5/index.html new file mode 100644 index 0000000..b3a54a2 --- /dev/null +++ b/resources/JUnitReport/ns-5/index.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.controller + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.controller

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-5/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-5/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..acdea90 --- /dev/null +++ b/resources/JUnitReport/ns-5/index_SORT_BY_BLOCK.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.controller + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.controller

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-5/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-5/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..ebd772d --- /dev/null +++ b/resources/JUnitReport/ns-5/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.controller + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.controller

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-5/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-5/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..25d2201 --- /dev/null +++ b/resources/JUnitReport/ns-5/index_SORT_BY_CLASS.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.controller + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.controller

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-5/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-5/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..dc9a57e --- /dev/null +++ b/resources/JUnitReport/ns-5/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.controller + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.controller

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-5/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-5/index_SORT_BY_LINE.html new file mode 100644 index 0000000..17c39e1 --- /dev/null +++ b/resources/JUnitReport/ns-5/index_SORT_BY_LINE.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.controller + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.controller

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-5/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-5/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..10d898e --- /dev/null +++ b/resources/JUnitReport/ns-5/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.controller + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.controller

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-5/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-5/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..9812df1 --- /dev/null +++ b/resources/JUnitReport/ns-5/index_SORT_BY_METHOD.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.controller + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.controller

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-5/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-5/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..9492a0d --- /dev/null +++ b/resources/JUnitReport/ns-5/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.controller + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.controller

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-5/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-5/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..0f5b337 --- /dev/null +++ b/resources/JUnitReport/ns-5/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.controller + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.controller

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.controller + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-5/sources/source-1.html b/resources/JUnitReport/ns-5/sources/source-1.html new file mode 100644 index 0000000..01da885 --- /dev/null +++ b/resources/JUnitReport/ns-5/sources/source-1.html @@ -0,0 +1,146 @@ + + + + + + + + Coverage Report > PlayerController + + + + + + +
+ + +

Coverage Summary for Class: PlayerController (com.profile.matcher.controller)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
PlayerController + + 100% + + + (1/1) + + + + 100% + + + (2/2) + + + + 100% + + + (10/10) + +
+ +
+
+ + +
+ package com.profile.matcher.controller;
+ 
+ import com.profile.matcher.arhitecture.BaseController;
+ import com.profile.matcher.assembler.PlayerAssembler;
+ import com.profile.matcher.command.PlayerCommand;
+ import com.profile.matcher.dto.player.PlayerDto;
+ import com.profile.matcher.entity.player.Player;
+ import org.springframework.beans.factory.annotation.Autowired;
+ import org.springframework.http.HttpHeaders;
+ import org.springframework.http.HttpStatus;
+ import org.springframework.http.ResponseEntity;
+ import org.springframework.web.bind.annotation.GetMapping;
+ import org.springframework.web.bind.annotation.PathVariable;
+ import org.springframework.web.bind.annotation.RestController;
+ 
+ import java.util.Optional;
+ import java.util.UUID;
+ 
+ @RestController
+ public class PlayerController extends BaseController {
+ 
+     @Autowired
+     private PlayerAssembler playerAssembler;
+ 
+     @GetMapping("/get_client_config/{player_id}")
+     public ResponseEntity<PlayerDto> getClientConfig(@PathVariable("player_id") String idPlayer) {
+         writeLog("PlayerController.getClientConfig() - get player with id: {}", idPlayer);
+ 
+         PlayerCommand playerCommand = getCommand(PlayerCommand.class, idPlayer);
+         Optional<Player> playerOptional = playerCommand.execute();
+ 
+         if (playerOptional.isPresent()) {
+             PlayerDto playerDto = playerAssembler.toResource(playerOptional.get());
+             writeLog("PlayerController.getClientConfig() - player found: {}", playerDto);
+             return ResponseEntity.ok(playerDto);
+         } else {
+             writeLog("PlayerController.getClientConfig() - player not found");
+             return ResponseEntity.status(HttpStatus.NO_CONTENT).headers(HttpHeaders.EMPTY).build();
+         }
+     }
+ 
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-6/index.html b/resources/JUnitReport/ns-6/index.html new file mode 100644 index 0000000..6aeb813 --- /dev/null +++ b/resources/JUnitReport/ns-6/index.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.dto.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignDto + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-6/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-6/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..96dadcc --- /dev/null +++ b/resources/JUnitReport/ns-6/index_SORT_BY_BLOCK.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.dto.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignDto + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-6/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-6/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..9a1d476 --- /dev/null +++ b/resources/JUnitReport/ns-6/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.dto.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignDto + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-6/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-6/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..909f9c1 --- /dev/null +++ b/resources/JUnitReport/ns-6/index_SORT_BY_CLASS.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.dto.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignDto + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-6/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-6/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..a7344b6 --- /dev/null +++ b/resources/JUnitReport/ns-6/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.dto.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignDto + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-6/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-6/index_SORT_BY_LINE.html new file mode 100644 index 0000000..db197fb --- /dev/null +++ b/resources/JUnitReport/ns-6/index_SORT_BY_LINE.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.dto.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignDto + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-6/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-6/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..24beea6 --- /dev/null +++ b/resources/JUnitReport/ns-6/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.dto.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignDto + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-6/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-6/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..21a7917 --- /dev/null +++ b/resources/JUnitReport/ns-6/index_SORT_BY_METHOD.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.dto.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignDto + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-6/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-6/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..f95e2e5 --- /dev/null +++ b/resources/JUnitReport/ns-6/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.dto.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignDto + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-6/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-6/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..3e2ac74 --- /dev/null +++ b/resources/JUnitReport/ns-6/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.dto.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.campaign + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignDto + + 100% + + + (5/5) + + + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-6/sources/source-1.html b/resources/JUnitReport/ns-6/sources/source-1.html new file mode 100644 index 0000000..bc92990 --- /dev/null +++ b/resources/JUnitReport/ns-6/sources/source-1.html @@ -0,0 +1,240 @@ + + + + + + + + Coverage Report > CampaignDto + + + + + + +
+ + +

Coverage Summary for Class: CampaignDto (com.profile.matcher.dto.campaign)

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
CampaignDto + + 100% + + + (9/9) + + + + 100% + + + (9/9) + +
CampaignDto$Matchers + + 100% + + + (4/4) + + + + 100% + + + (4/4) + +
CampaignDto$Matchers$DoesNotHave + + 100% + + + (2/2) + + + + 100% + + + (2/2) + +
CampaignDto$Matchers$Has + + 100% + + + (3/3) + + + + 100% + + + (3/3) + +
CampaignDto$Matchers$Range + + 100% + + + (3/3) + + + + 100% + + + (3/3) + +
Total + + 100% + + + (21/21) + + + + 100% + + + (21/21) + +
+ +
+
+ + +
+ package com.profile.matcher.dto.campaign;
+ 
+ import jakarta.validation.constraints.NotBlank;
+ import lombok.Data;
+ 
+ import java.math.BigDecimal;
+ import java.util.List;
+ 
+ @Data
+ public class CampaignDto {
+ 
+     @NotBlank(message = "Game is mandatory")
+     private String game;
+ 
+     @NotBlank(message = "Name is mandatory")
+     private String name;
+ 
+     private BigDecimal priority;
+ 
+     private Matchers matchers;
+ 
+     private Boolean enabled;
+ 
+     private String last_updated;
+ 
+     private String start_date;
+ 
+     private String end_date;
+ 
+     @Data
+     public static class Matchers {
+         private Range level;
+         private Has has;
+         private DoesNotHave doesNotHave;
+ 
+         @Data
+         public static class Range {
+             private Integer min;
+             private Integer max;
+         }
+ 
+         @Data
+         public static class Has {
+             private List<String> country;
+             private List<String> items;
+         }
+ 
+         @Data
+         public static class DoesNotHave {
+             private List<String> items;
+         }
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-7/index.html b/resources/JUnitReport/ns-7/index.html new file mode 100644 index 0000000..17dafc4 --- /dev/null +++ b/resources/JUnitReport/ns-7/index.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.dto.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-7/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-7/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..e24e79a --- /dev/null +++ b/resources/JUnitReport/ns-7/index_SORT_BY_BLOCK.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.dto.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-7/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-7/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..9c6836d --- /dev/null +++ b/resources/JUnitReport/ns-7/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.dto.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-7/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-7/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..3e47022 --- /dev/null +++ b/resources/JUnitReport/ns-7/index_SORT_BY_CLASS.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.dto.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-7/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-7/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..9dcd9d3 --- /dev/null +++ b/resources/JUnitReport/ns-7/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.dto.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-7/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-7/index_SORT_BY_LINE.html new file mode 100644 index 0000000..b58973c --- /dev/null +++ b/resources/JUnitReport/ns-7/index_SORT_BY_LINE.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.dto.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-7/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-7/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..6e30236 --- /dev/null +++ b/resources/JUnitReport/ns-7/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.dto.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-7/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-7/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..e3a3db4 --- /dev/null +++ b/resources/JUnitReport/ns-7/index_SORT_BY_METHOD.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.dto.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-7/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-7/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..ebcc479 --- /dev/null +++ b/resources/JUnitReport/ns-7/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.dto.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-7/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-7/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..09051c6 --- /dev/null +++ b/resources/JUnitReport/ns-7/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,224 @@ + + + + + + Coverage Report > com.profile.matcher.dto.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.dto.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.dto.player + + 75% + + + (3/4) + + + + 77.6% + + + (38/49) + + + + 77.6% + + + (38/49) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-7/sources/source-1.html b/resources/JUnitReport/ns-7/sources/source-1.html new file mode 100644 index 0000000..2fbd072 --- /dev/null +++ b/resources/JUnitReport/ns-7/sources/source-1.html @@ -0,0 +1,127 @@ + + + + + + + + Coverage Report > ClanDto + + + + + + +
+ + +

Coverage Summary for Class: ClanDto (com.profile.matcher.dto.player)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
ClanDto + + 100% + + + (1/1) + + + + 85.7% + + + (6/7) + + + + 85.7% + + + (6/7) + +
+ +
+
+ + +
+ package com.profile.matcher.dto.player;
+ 
+ import jakarta.validation.constraints.NotBlank;
+ import lombok.Getter;
+ import lombok.NoArgsConstructor;
+ import lombok.Setter;
+ import lombok.ToString;
+ 
+ @Getter
+ @Setter
+ @ToString
+ @NoArgsConstructor
+ public class ClanDto {
+ 
+     private Long id;
+ 
+     @NotBlank(message = "Name is mandatory")
+     private String name;
+ 
+     private String startDate;
+ 
+     private String endDate;
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-7/sources/source-2.html b/resources/JUnitReport/ns-7/sources/source-2.html new file mode 100644 index 0000000..2d570d3 --- /dev/null +++ b/resources/JUnitReport/ns-7/sources/source-2.html @@ -0,0 +1,128 @@ + + + + + + + + Coverage Report > DeviceDto + + + + + + +
+ + +

Coverage Summary for Class: DeviceDto (com.profile.matcher.dto.player)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
DeviceDto + + 100% + + + (1/1) + + + + 88.9% + + + (8/9) + + + + 88.9% + + + (8/9) + +
+ +
+
+ + +
+ package com.profile.matcher.dto.player;
+ 
+ import lombok.Getter;
+ import lombok.NoArgsConstructor;
+ import lombok.Setter;
+ import lombok.ToString;
+ 
+ @Getter
+ @Setter
+ @ToString
+ @NoArgsConstructor
+ public class DeviceDto {
+     private Long id;
+ 
+     private String model;
+ 
+     private String carrier;
+ 
+     private String firmware;
+ 
+     private String startDate;
+ 
+     private String endDate;
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-7/sources/source-3.html b/resources/JUnitReport/ns-7/sources/source-3.html new file mode 100644 index 0000000..5ced2af --- /dev/null +++ b/resources/JUnitReport/ns-7/sources/source-3.html @@ -0,0 +1,133 @@ + + + + + + + + Coverage Report > InventoryDto + + + + + + +
+ + +

Coverage Summary for Class: InventoryDto (com.profile.matcher.dto.player)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
InventoryDto + + 0% + + + (0/1) + + + + 0% + + + (0/9) + + + + 0% + + + (0/9) + +
+ +
+
+ + +
+ package com.profile.matcher.dto.player;
+ 
+ import com.profile.matcher.entity.player.Item;
+ import lombok.Getter;
+ import lombok.NoArgsConstructor;
+ import lombok.Setter;
+ import lombok.ToString;
+ 
+ import java.math.BigDecimal;
+ import java.util.List;
+ 
+ @Getter
+ @Setter
+ @ToString
+ @NoArgsConstructor
+ public class InventoryDto {
+     private Long idInventory;
+ 
+     private BigDecimal cash;
+ 
+     private BigDecimal coins;
+ 
+     // TODO - format like JSON format string
+     private List<Item> item;
+ 
+     private String startDate;
+ 
+     private String endDate;
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-7/sources/source-4.html b/resources/JUnitReport/ns-7/sources/source-4.html new file mode 100644 index 0000000..2bbf0b1 --- /dev/null +++ b/resources/JUnitReport/ns-7/sources/source-4.html @@ -0,0 +1,167 @@ + + + + + + + + Coverage Report > PlayerDto + + + + + + +
+ + +

Coverage Summary for Class: PlayerDto (com.profile.matcher.dto.player)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
PlayerDto + + 100% + + + (1/1) + + + + 100% + + + (24/24) + + + + 100% + + + (24/24) + +
+ +
+
+ + +
+ package com.profile.matcher.dto.player;
+ 
+ import jakarta.validation.constraints.NotNull;
+ import jakarta.validation.constraints.Size;
+ import lombok.Getter;
+ import lombok.NoArgsConstructor;
+ import lombok.Setter;
+ import lombok.ToString;
+ 
+ import java.math.BigDecimal;
+ import java.util.List;
+ import java.util.Map;
+ import java.util.UUID;
+ 
+ @Getter
+ @Setter
+ @ToString
+ @NoArgsConstructor
+ public class PlayerDto {
+     private UUID player_id;
+ 
+     @NotNull
+     @Size(max = 255)
+     private String credential;
+ 
+     private String created;
+ 
+     private String modified;
+ 
+     private String last_session;
+ 
+     private BigDecimal total_spent;
+ 
+     private BigDecimal total_refund;
+ 
+     private Integer total_transactions;
+ 
+     private String last_purchase;
+ 
+     private List<String> active_campaigns;
+ 
+     private List<DeviceDto> devices;
+ 
+     private Integer level;
+ 
+     private Integer xp;
+ 
+     private BigDecimal total_playtime;
+ 
+     private String country;
+ 
+     private String language;
+ 
+     private String birthdate;
+ 
+     private String gender;
+ 
+     private Map<String, String> inventory;
+ 
+     private ClanDto clan;
+ 
+     private String _customField;
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-8/index.html b/resources/JUnitReport/ns-8/index.html new file mode 100644 index 0000000..08b7184 --- /dev/null +++ b/resources/JUnitReport/ns-8/index.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.entity.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-8/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-8/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..7c71bdf --- /dev/null +++ b/resources/JUnitReport/ns-8/index_SORT_BY_BLOCK.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.entity.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-8/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-8/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..78d6571 --- /dev/null +++ b/resources/JUnitReport/ns-8/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.entity.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-8/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-8/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..81723bf --- /dev/null +++ b/resources/JUnitReport/ns-8/index_SORT_BY_CLASS.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.entity.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-8/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-8/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..769882f --- /dev/null +++ b/resources/JUnitReport/ns-8/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.entity.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-8/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-8/index_SORT_BY_LINE.html new file mode 100644 index 0000000..15a055f --- /dev/null +++ b/resources/JUnitReport/ns-8/index_SORT_BY_LINE.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.entity.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-8/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-8/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..8ab599e --- /dev/null +++ b/resources/JUnitReport/ns-8/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.entity.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-8/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-8/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..1c7c327 --- /dev/null +++ b/resources/JUnitReport/ns-8/index_SORT_BY_METHOD.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.entity.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-8/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-8/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..5fafb6b --- /dev/null +++ b/resources/JUnitReport/ns-8/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.entity.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-8/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-8/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..e35ee7e --- /dev/null +++ b/resources/JUnitReport/ns-8/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,143 @@ + + + + + + Coverage Report > com.profile.matcher.entity.campaign + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.campaign

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Campaign + + 100% + + + (1/1) + + + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-8/sources/source-1.html b/resources/JUnitReport/ns-8/sources/source-1.html new file mode 100644 index 0000000..47a1f19 --- /dev/null +++ b/resources/JUnitReport/ns-8/sources/source-1.html @@ -0,0 +1,181 @@ + + + + + + + + Coverage Report > Campaign + + + + + + +
+ + +

Coverage Summary for Class: Campaign (com.profile.matcher.entity.campaign)

+ + + + + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
Campaign + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
Campaign$HibernateInstantiator$vzToZyNF
Campaign$HibernateProxy$uTWByFlg
Total + + 21.4% + + + (3/14) + + + + 21.4% + + + (3/14) + +
+ +
+
+ + +
+ package com.profile.matcher.entity.campaign;
+ 
+ import com.profile.matcher.entity.player.Player;
+ import jakarta.persistence.*;
+ import jakarta.validation.constraints.NotNull;
+ import lombok.Getter;
+ import lombok.NoArgsConstructor;
+ import lombok.Setter;
+ import lombok.ToString;
+ 
+ import java.math.BigDecimal;
+ import java.sql.Timestamp;
+ import java.time.Instant;
+ import java.util.List;
+ 
+ @Getter
+ @Setter
+ @ToString
+ @NoArgsConstructor
+ @Entity
+ @Table(name = "CAMPAIGN", schema = "matcherapplication")
+ public class Campaign {
+     @Id
+     @GeneratedValue(strategy = GenerationType.IDENTITY)
+     @Column(name = "ID_CAMPAIGN")
+     private Long campaignId;
+ 
+     @NotNull
+     @Column(name = "GAME")
+     private String game;
+ 
+     @NotNull
+     @Column(name = "NAME")
+     private String name;
+ 
+     @Column(name = "priority")
+     private BigDecimal priority;
+ 
+     @NotNull
+     @Column(name = "ENABLED")
+     private Boolean enabled;
+ 
+     @ManyToMany(fetch = FetchType.LAZY, mappedBy = "campaigns")
+     private List<Player> players;
+ 
+     @Column(name = "LAST_UPDATED")
+     private Timestamp lastUpdated;
+ 
+     @Column(name = "START_DATE")
+     private Timestamp startDate;
+ 
+     @Column(name = "END_DATE")
+     private Timestamp endDate;
+ 
+     @PrePersist
+     public void setStartDate() {
+         this.setStartDate(Timestamp.from(Instant.now()));
+     }
+ 
+     @PreUpdate
+     public void setLastUpdated() {
+         this.setLastUpdated(Timestamp.from(Instant.now()));
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-9/index.html b/resources/JUnitReport/ns-9/index.html new file mode 100644 index 0000000..bfbf87b --- /dev/null +++ b/resources/JUnitReport/ns-9/index.html @@ -0,0 +1,251 @@ + + + + + + Coverage Report > com.profile.matcher.entity.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Clan + + 100% + + + (1/1) + + + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
Device + + 100% + + + (1/1) + + + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
Inventory + + 100% + + + (1/1) + + + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Item + + 100% + + + (1/1) + + + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Player + + 100% + + + (1/1) + + + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-9/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-9/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..e0b696f --- /dev/null +++ b/resources/JUnitReport/ns-9/index_SORT_BY_BLOCK.html @@ -0,0 +1,251 @@ + + + + + + Coverage Report > com.profile.matcher.entity.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Clan + + 100% + + + (1/1) + + + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
Device + + 100% + + + (1/1) + + + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
Inventory + + 100% + + + (1/1) + + + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Item + + 100% + + + (1/1) + + + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Player + + 100% + + + (1/1) + + + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-9/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-9/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..f9c95fa --- /dev/null +++ b/resources/JUnitReport/ns-9/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,251 @@ + + + + + + Coverage Report > com.profile.matcher.entity.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Player + + 100% + + + (1/1) + + + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
Item + + 100% + + + (1/1) + + + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Inventory + + 100% + + + (1/1) + + + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Device + + 100% + + + (1/1) + + + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
Clan + + 100% + + + (1/1) + + + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-9/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-9/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..16b4f3a --- /dev/null +++ b/resources/JUnitReport/ns-9/index_SORT_BY_CLASS.html @@ -0,0 +1,251 @@ + + + + + + Coverage Report > com.profile.matcher.entity.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Clan + + 100% + + + (1/1) + + + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
Device + + 100% + + + (1/1) + + + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
Inventory + + 100% + + + (1/1) + + + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Item + + 100% + + + (1/1) + + + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Player + + 100% + + + (1/1) + + + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-9/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-9/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..07a256b --- /dev/null +++ b/resources/JUnitReport/ns-9/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,251 @@ + + + + + + Coverage Report > com.profile.matcher.entity.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Player + + 100% + + + (1/1) + + + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
Item + + 100% + + + (1/1) + + + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Inventory + + 100% + + + (1/1) + + + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Device + + 100% + + + (1/1) + + + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
Clan + + 100% + + + (1/1) + + + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-9/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-9/index_SORT_BY_LINE.html new file mode 100644 index 0000000..e73a310 --- /dev/null +++ b/resources/JUnitReport/ns-9/index_SORT_BY_LINE.html @@ -0,0 +1,251 @@ + + + + + + Coverage Report > com.profile.matcher.entity.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Device + + 100% + + + (1/1) + + + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
Clan + + 100% + + + (1/1) + + + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
Inventory + + 100% + + + (1/1) + + + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Item + + 100% + + + (1/1) + + + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Player + + 100% + + + (1/1) + + + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-9/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-9/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..fc71be7 --- /dev/null +++ b/resources/JUnitReport/ns-9/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,251 @@ + + + + + + Coverage Report > com.profile.matcher.entity.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Player + + 100% + + + (1/1) + + + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
Item + + 100% + + + (1/1) + + + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Inventory + + 100% + + + (1/1) + + + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Clan + + 100% + + + (1/1) + + + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
Device + + 100% + + + (1/1) + + + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-9/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-9/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..6c858e6 --- /dev/null +++ b/resources/JUnitReport/ns-9/index_SORT_BY_METHOD.html @@ -0,0 +1,251 @@ + + + + + + Coverage Report > com.profile.matcher.entity.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Device + + 100% + + + (1/1) + + + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
Clan + + 100% + + + (1/1) + + + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
Inventory + + 100% + + + (1/1) + + + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Item + + 100% + + + (1/1) + + + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Player + + 100% + + + (1/1) + + + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-9/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-9/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..20913b2 --- /dev/null +++ b/resources/JUnitReport/ns-9/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,251 @@ + + + + + + Coverage Report > com.profile.matcher.entity.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Player + + 100% + + + (1/1) + + + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
Item + + 100% + + + (1/1) + + + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Inventory + + 100% + + + (1/1) + + + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Clan + + 100% + + + (1/1) + + + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
Device + + 100% + + + (1/1) + + + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-9/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-9/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..ad0cd93 --- /dev/null +++ b/resources/JUnitReport/ns-9/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,251 @@ + + + + + + Coverage Report > com.profile.matcher.entity.player + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.entity.player

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.entity.player + + 100% + + + (5/5) + + + + 47.7% + + + (31/65) + + + + 47.7% + + + (31/65) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Player + + 100% + + + (1/1) + + + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
Item + + 100% + + + (1/1) + + + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Inventory + + 100% + + + (1/1) + + + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Device + + 100% + + + (1/1) + + + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
Clan + + 100% + + + (1/1) + + + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-9/sources/source-1.html b/resources/JUnitReport/ns-9/sources/source-1.html new file mode 100644 index 0000000..449f8b3 --- /dev/null +++ b/resources/JUnitReport/ns-9/sources/source-1.html @@ -0,0 +1,158 @@ + + + + + + + + Coverage Report > Clan + + + + + + +
+ + +

Coverage Summary for Class: Clan (com.profile.matcher.entity.player)

+ + + + + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
Clan + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
Clan$HibernateInstantiator$qciPsoor
Clan$HibernateProxy$GaTIWQEO
Total + + 11.1% + + + (1/9) + + + + 11.1% + + + (1/9) + +
+ +
+
+ + +
+ package com.profile.matcher.entity.player;
+ 
+ import jakarta.persistence.*;
+ import lombok.Getter;
+ import lombok.NoArgsConstructor;
+ import lombok.Setter;
+ import lombok.ToString;
+ 
+ import java.sql.Timestamp;
+ import java.time.Instant;
+ import java.util.List;
+ 
+ @Getter
+ @Setter
+ @ToString
+ @NoArgsConstructor
+ @Entity
+ @Table(name = "CLAN", schema = "matcherapplication")
+ public class Clan {
+     @Id
+     @GeneratedValue(strategy = GenerationType.IDENTITY)
+     @Column(name = "ID_CLAN")
+     private Long idClan;
+ 
+     @Column(name = "NAME")
+     private String name;
+ 
+     @OneToMany(mappedBy = "clan", fetch = FetchType.LAZY, cascade = CascadeType.MERGE)
+     private List<Player> player;
+ 
+     @Column(name = "START_DATE")
+     private Timestamp startDate;
+ 
+     @Column(name = "END_DATE")
+     private Timestamp endDate;
+ 
+     @PrePersist
+     public void setStartDate() {
+         this.setStartDate(Timestamp.from(Instant.now()));
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-9/sources/source-2.html b/resources/JUnitReport/ns-9/sources/source-2.html new file mode 100644 index 0000000..66b51c3 --- /dev/null +++ b/resources/JUnitReport/ns-9/sources/source-2.html @@ -0,0 +1,164 @@ + + + + + + + + Coverage Report > Device + + + + + + +
+ + +

Coverage Summary for Class: Device (com.profile.matcher.entity.player)

+ + + + + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
Device + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
Device$HibernateInstantiator$plmDIulw
Device$HibernateProxy$10m5Y4UE
Total + + 9.1% + + + (1/11) + + + + 9.1% + + + (1/11) + +
+ +
+
+ + +
+ package com.profile.matcher.entity.player;
+ 
+ import jakarta.persistence.*;
+ import lombok.Getter;
+ import lombok.NoArgsConstructor;
+ import lombok.Setter;
+ import lombok.ToString;
+ 
+ import java.sql.Timestamp;
+ import java.time.Instant;
+ 
+ @Getter
+ @Setter
+ @ToString
+ @NoArgsConstructor
+ @Entity
+ @Table(name = "DEVICE", schema = "matcherapplication")
+ public class Device {
+     @Id
+     @GeneratedValue(strategy = GenerationType.IDENTITY)
+     @Column(name = "ID_DEVICE")
+     private Long idDevice;
+ 
+     @ManyToOne(fetch = FetchType.EAGER, cascade = {CascadeType.MERGE, CascadeType.REFRESH})
+     @JoinColumn(name = "PLAYER", referencedColumnName = "ID_PLAYER")
+     private Player player;
+ 
+     @Column(name = "MODEL")
+     private String model;
+ 
+     @Column(name = "CARRIER")
+     private String carrier;
+ 
+     @Column(name = "FIRMWARE")
+     private String firmware;
+ 
+     @Column(name = "START_DATE")
+     private Timestamp startDate;
+ 
+     @Column(name = "END_DATE")
+     private Timestamp endDate;
+ 
+     @PrePersist
+     public void setStartDate() {
+         this.setStartDate(Timestamp.from(Instant.now()));
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-9/sources/source-3.html b/resources/JUnitReport/ns-9/sources/source-3.html new file mode 100644 index 0000000..a61cd8b --- /dev/null +++ b/resources/JUnitReport/ns-9/sources/source-3.html @@ -0,0 +1,166 @@ + + + + + + + + Coverage Report > Inventory + + + + + + +
+ + +

Coverage Summary for Class: Inventory (com.profile.matcher.entity.player)

+ + + + + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
Inventory + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
Inventory$HibernateInstantiator$a6nEA7wL
Inventory$HibernateProxy$AItVGoYh
Total + + 27.3% + + + (3/11) + + + + 27.3% + + + (3/11) + +
+ +
+
+ + +
+ package com.profile.matcher.entity.player;
+ 
+ import jakarta.persistence.*;
+ import lombok.Getter;
+ import lombok.NoArgsConstructor;
+ import lombok.Setter;
+ import lombok.ToString;
+ 
+ import java.math.BigDecimal;
+ import java.sql.Timestamp;
+ import java.time.Instant;
+ import java.util.List;
+ 
+ @Getter
+ @Setter
+ @ToString
+ @NoArgsConstructor
+ @Entity
+ @Table(name = "INVENTORY", schema = "matcherapplication")
+ public class Inventory {
+     @Id
+     @GeneratedValue(strategy = GenerationType.IDENTITY)
+     @Column(name = "ID_INVENTORY")
+     private Long idInventory;
+ 
+     @OneToOne(mappedBy = "inventory", fetch = FetchType.EAGER, cascade = CascadeType.ALL)
+     private Player player;
+ 
+     @Column(name = "CASH")
+     private BigDecimal cash;
+ 
+     @Column(name = "COINS")
+     private BigDecimal coins;
+ 
+     @OneToMany(mappedBy = "inventory", fetch = FetchType.LAZY, cascade = CascadeType.MERGE)
+     private List<Item> items;
+ 
+     @Column(name = "START_DATE")
+     private Timestamp startDate;
+ 
+     @Column(name = "END_DATE")
+     private Timestamp endDate;
+ 
+     @PrePersist
+     public void setStartDate() {
+         this.setStartDate(Timestamp.from(Instant.now()));
+     }
+ }
+ 
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-9/sources/source-4.html b/resources/JUnitReport/ns-9/sources/source-4.html new file mode 100644 index 0000000..f279a93 --- /dev/null +++ b/resources/JUnitReport/ns-9/sources/source-4.html @@ -0,0 +1,161 @@ + + + + + + + + Coverage Report > Item + + + + + + +
+ + +

Coverage Summary for Class: Item (com.profile.matcher.entity.player)

+ + + + + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
Item + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
Item$HibernateInstantiator$tfkWyGKx
Item$HibernateProxy$A7nvnJog
Total + + 30% + + + (3/10) + + + + 30% + + + (3/10) + +
+ +
+
+ + +
+ package com.profile.matcher.entity.player;
+ 
+ import jakarta.persistence.*;
+ import lombok.Getter;
+ import lombok.NoArgsConstructor;
+ import lombok.Setter;
+ import lombok.ToString;
+ 
+ import java.sql.Timestamp;
+ import java.time.Instant;
+ 
+ @Getter
+ @Setter
+ @ToString
+ @NoArgsConstructor
+ @Entity
+ @Table(name = "ITEM", schema = "matcherapplication")
+ public class Item {
+     @Id
+     @GeneratedValue(strategy = GenerationType.IDENTITY)
+     @Column(name = "ID_ITEM")
+     private Long idItem;
+ 
+     @Column(name = "NAME")
+     private String name;
+ 
+     @Column(name = "QUANTITY")
+     private Integer quantity;
+ 
+     @ManyToOne(fetch = FetchType.EAGER, cascade = {CascadeType.MERGE, CascadeType.REFRESH})
+     @JoinColumn(name = "INVENTORY", referencedColumnName = "ID_INVENTORY")
+     private Inventory inventory;
+ 
+     @Column(name = "START_DATE")
+     private Timestamp startDate;
+ 
+     @Column(name = "END_DATE")
+     private Timestamp endDate;
+ 
+     @PrePersist
+     public void setStartDate() {
+         this.setStartDate(Timestamp.from(Instant.now()));
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-9/sources/source-5.html b/resources/JUnitReport/ns-9/sources/source-5.html new file mode 100644 index 0000000..26b8312 --- /dev/null +++ b/resources/JUnitReport/ns-9/sources/source-5.html @@ -0,0 +1,215 @@ + + + + + + + + Coverage Report > Player + + + + + + +
+ + +

Coverage Summary for Class: Player (com.profile.matcher.entity.player)

+ + + + + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
Player + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
Player$HibernateInstantiator$9Sfq3NWK
Player$HibernateProxy$qfeoUl7F
Total + + 95.8% + + + (23/24) + + + + 95.8% + + + (23/24) + +
+ +
+
+ + +
+ package com.profile.matcher.entity.player;
+ 
+ import com.profile.matcher.entity.campaign.Campaign;
+ import jakarta.persistence.*;
+ import jakarta.validation.constraints.NotNull;
+ import lombok.Getter;
+ import lombok.NoArgsConstructor;
+ import lombok.Setter;
+ import lombok.ToString;
+ import org.hibernate.annotations.JdbcTypeCode;
+ import org.hibernate.type.SqlTypes;
+ 
+ import java.math.BigDecimal;
+ import java.sql.Timestamp;
+ import java.util.List;
+ import java.util.UUID;
+ 
+ @Getter
+ @Setter
+ @ToString
+ @NoArgsConstructor
+ @Entity
+ @Table(name = "PLAYER", schema = "matcherapplication")
+ public class Player {
+     @Id
+     @GeneratedValue(strategy = GenerationType.UUID)
+     @Column(name = "ID_PLAYER", columnDefinition = "BINARY(16)")
+     @JdbcTypeCode(SqlTypes.BINARY)
+     private UUID idPlayer;
+ 
+     @NotNull
+     @Column(name = "CREDENTIAL")
+     private String credential;
+ 
+     @Column(name = "CREATED")
+     private Timestamp created;
+ 
+     @Column(name = "MODIFIED")
+     private Timestamp modified;
+ 
+     @Column(name = "LAST_SESSION")
+     private Timestamp lastSession;
+ 
+     @Column(name = "TOTAL_SPENT")
+     private BigDecimal totalSpent;
+ 
+     @Column(name = "TOTAL_REFUND")
+     private BigDecimal totalRefund;
+ 
+     @Column(name = "TOTAL_TRANSACTIONS")
+     private Integer totalTransactions;
+ 
+     @Column(name = "LAST_PURCHASE")
+     private Timestamp lastPurchase;
+ 
+     @ManyToMany(fetch = FetchType.LAZY,
+             cascade = {CascadeType.REFRESH, CascadeType.MERGE})
+     @JoinTable(
+             name = "CAMPAIGN_PLAYER",
+             joinColumns = @JoinColumn(name = "ID_PLAYER"),
+             inverseJoinColumns = @JoinColumn(name = "ID_CAMPAIGN"))
+     private List<Campaign> campaigns;
+ 
+     @OneToMany(mappedBy = "player", fetch = FetchType.LAZY, cascade = CascadeType.MERGE)
+     private List<Device> devices;
+ 
+     @Column(name = "LEVEL")
+     private Integer level;
+ 
+     @Column(name = "XP")
+     private Integer xp;
+ 
+     @Column(name = "TOTAL_PLAYTIME")
+     private BigDecimal totalPlaytime;
+ 
+     @Column(name = "COUNTRY")
+     private String country;
+ 
+     @Column(name = "LANGUAGE")
+     private String language;
+ 
+     @Column(name = "BIRTHDATE")
+     private Timestamp birthdate;
+ 
+     @Column(name = "GENDER")
+     private String gender;
+ 
+     @OneToOne(fetch = FetchType.EAGER, cascade = CascadeType.ALL)
+     @JoinColumn(name = "INVENTORY", referencedColumnName = "ID_INVENTORY")
+     private Inventory inventory;
+ 
+     @ManyToOne(fetch = FetchType.EAGER, cascade = {CascadeType.MERGE, CascadeType.REFRESH})
+     @JoinColumn(name = "CLAN", referencedColumnName = "ID_CLAN")
+     private Clan clan;
+ 
+     @Column(name = "CUSTOM_FIELD")
+     private String customField;
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-a/index.html b/resources/JUnitReport/ns-a/index.html new file mode 100644 index 0000000..993405f --- /dev/null +++ b/resources/JUnitReport/ns-a/index.html @@ -0,0 +1,197 @@ + + + + + + Coverage Report > com.profile.matcher.exception + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.exception

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-a/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-a/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..3015e10 --- /dev/null +++ b/resources/JUnitReport/ns-a/index_SORT_BY_BLOCK.html @@ -0,0 +1,197 @@ + + + + + + Coverage Report > com.profile.matcher.exception + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.exception

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-a/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-a/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..76d6b84 --- /dev/null +++ b/resources/JUnitReport/ns-a/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,197 @@ + + + + + + Coverage Report > com.profile.matcher.exception + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.exception

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-a/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-a/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..b5b4c39 --- /dev/null +++ b/resources/JUnitReport/ns-a/index_SORT_BY_CLASS.html @@ -0,0 +1,197 @@ + + + + + + Coverage Report > com.profile.matcher.exception + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.exception

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-a/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-a/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..fc680f6 --- /dev/null +++ b/resources/JUnitReport/ns-a/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,197 @@ + + + + + + Coverage Report > com.profile.matcher.exception + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.exception

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-a/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-a/index_SORT_BY_LINE.html new file mode 100644 index 0000000..9f22851 --- /dev/null +++ b/resources/JUnitReport/ns-a/index_SORT_BY_LINE.html @@ -0,0 +1,197 @@ + + + + + + Coverage Report > com.profile.matcher.exception + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.exception

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-a/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-a/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..809a88d --- /dev/null +++ b/resources/JUnitReport/ns-a/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,197 @@ + + + + + + Coverage Report > com.profile.matcher.exception + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.exception

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-a/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-a/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..27772b1 --- /dev/null +++ b/resources/JUnitReport/ns-a/index_SORT_BY_METHOD.html @@ -0,0 +1,197 @@ + + + + + + Coverage Report > com.profile.matcher.exception + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.exception

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-a/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-a/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..16aa8e7 --- /dev/null +++ b/resources/JUnitReport/ns-a/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,197 @@ + + + + + + Coverage Report > com.profile.matcher.exception + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.exception

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-a/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-a/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..1488aaa --- /dev/null +++ b/resources/JUnitReport/ns-a/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,197 @@ + + + + + + Coverage Report > com.profile.matcher.exception + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.exception

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.exception + + 66.7% + + + (2/3) + + + + 33.3% + + + (2/6) + + + + 33.3% + + + (2/6) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-a/sources/source-1.html b/resources/JUnitReport/ns-a/sources/source-1.html new file mode 100644 index 0000000..764df47 --- /dev/null +++ b/resources/JUnitReport/ns-a/sources/source-1.html @@ -0,0 +1,119 @@ + + + + + + + + Coverage Report > FindCurrentCampaignException + + + + + + +
+ + +

Coverage Summary for Class: FindCurrentCampaignException (com.profile.matcher.exception)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
FindCurrentCampaignException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + +
+ package com.profile.matcher.exception;
+ 
+ import com.profile.matcher.arhitecture.BaseException;
+ import org.springframework.http.HttpStatus;
+ 
+ public class FindCurrentCampaignException extends BaseException {
+ 
+     public FindCurrentCampaignException(String message, Throwable cause) {
+         super(message, cause);
+     }
+ 
+     public FindCurrentCampaignException(String message, String code, HttpStatus status) {
+         super(message, code, status);
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-a/sources/source-2.html b/resources/JUnitReport/ns-a/sources/source-2.html new file mode 100644 index 0000000..029fcf6 --- /dev/null +++ b/resources/JUnitReport/ns-a/sources/source-2.html @@ -0,0 +1,119 @@ + + + + + + + + Coverage Report > FindPlayerDetailsException + + + + + + +
+ + +

Coverage Summary for Class: FindPlayerDetailsException (com.profile.matcher.exception)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
FindPlayerDetailsException + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 50% + + + (1/2) + +
+ +
+
+ + +
+ package com.profile.matcher.exception;
+ 
+ import com.profile.matcher.arhitecture.BaseException;
+ import org.springframework.http.HttpStatus;
+ 
+ public class FindPlayerDetailsException extends BaseException {
+ 
+     public FindPlayerDetailsException(String message, Throwable cause) {
+         super(message, cause);
+     }
+ 
+     public FindPlayerDetailsException(String message, String code, HttpStatus status) {
+         super(message, code, status);
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-a/sources/source-3.html b/resources/JUnitReport/ns-a/sources/source-3.html new file mode 100644 index 0000000..f82df4d --- /dev/null +++ b/resources/JUnitReport/ns-a/sources/source-3.html @@ -0,0 +1,118 @@ + + + + + + + + Coverage Report > UpdatePlayerDetailsException + + + + + + +
+ + +

Coverage Summary for Class: UpdatePlayerDetailsException (com.profile.matcher.exception)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
UpdatePlayerDetailsException + + 0% + + + (0/1) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+
+ + +
+ package com.profile.matcher.exception;
+ 
+ import com.profile.matcher.arhitecture.BaseException;
+ 
+ public class UpdatePlayerDetailsException extends BaseException {
+ 
+     public UpdatePlayerDetailsException(String message) {
+         super(message);
+     }
+ 
+     public UpdatePlayerDetailsException(String message, Throwable cause) {
+         super(message, cause);
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-b/index.html b/resources/JUnitReport/ns-b/index.html new file mode 100644 index 0000000..deca9a0 --- /dev/null +++ b/resources/JUnitReport/ns-b/index.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.service + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.service

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignService + + 100% + + + (2/2) + + + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
PlayerService + + 100% + + + (1/1) + + + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-b/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-b/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..3528f37 --- /dev/null +++ b/resources/JUnitReport/ns-b/index_SORT_BY_BLOCK.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.service + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.service

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignService + + 100% + + + (2/2) + + + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
PlayerService + + 100% + + + (1/1) + + + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-b/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-b/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..57ef254 --- /dev/null +++ b/resources/JUnitReport/ns-b/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.service + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.service

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerService + + 100% + + + (1/1) + + + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
CampaignService + + 100% + + + (2/2) + + + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-b/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-b/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..30b996d --- /dev/null +++ b/resources/JUnitReport/ns-b/index_SORT_BY_CLASS.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.service + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.service

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignService + + 100% + + + (2/2) + + + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
PlayerService + + 100% + + + (1/1) + + + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-b/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-b/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..aaf2c96 --- /dev/null +++ b/resources/JUnitReport/ns-b/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.service + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.service

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerService + + 100% + + + (1/1) + + + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
CampaignService + + 100% + + + (2/2) + + + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-b/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-b/index_SORT_BY_LINE.html new file mode 100644 index 0000000..17f96d0 --- /dev/null +++ b/resources/JUnitReport/ns-b/index_SORT_BY_LINE.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.service + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.service

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignService + + 100% + + + (2/2) + + + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
PlayerService + + 100% + + + (1/1) + + + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-b/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-b/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..123ac33 --- /dev/null +++ b/resources/JUnitReport/ns-b/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.service + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.service

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerService + + 100% + + + (1/1) + + + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
CampaignService + + 100% + + + (2/2) + + + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-b/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-b/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..767a8ef --- /dev/null +++ b/resources/JUnitReport/ns-b/index_SORT_BY_METHOD.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.service + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.service

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
CampaignService + + 100% + + + (2/2) + + + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
PlayerService + + 100% + + + (1/1) + + + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-b/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-b/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..4c7f6b9 --- /dev/null +++ b/resources/JUnitReport/ns-b/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.service + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.service

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerService + + 100% + + + (1/1) + + + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
CampaignService + + 100% + + + (2/2) + + + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-b/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-b/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..00f1e1a --- /dev/null +++ b/resources/JUnitReport/ns-b/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.service + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.service

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.service + + 100% + + + (3/3) + + + + 87.5% + + + (14/16) + + + + 76.7% + + + (89/116) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
PlayerService + + 100% + + + (1/1) + + + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
CampaignService + + 100% + + + (2/2) + + + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-b/sources/source-1.html b/resources/JUnitReport/ns-b/sources/source-1.html new file mode 100644 index 0000000..aebba1a --- /dev/null +++ b/resources/JUnitReport/ns-b/sources/source-1.html @@ -0,0 +1,253 @@ + + + + + + + + Coverage Report > CampaignService + + + + + + +
+ + +

Coverage Summary for Class: CampaignService (com.profile.matcher.service)

+ + + + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
CampaignService + + 75% + + + (3/4) + + + + 69.2% + + + (36/52) + +
CampaignService$1 + + 100% + + + (1/1) + + + + 100% + + + (1/1) + +
Total + + 80% + + + (4/5) + + + + 69.8% + + + (37/53) + +
+ +
+
+ + +
+ package com.profile.matcher.service;
+ 
+ import com.profile.matcher.arhitecture.BaseService;
+ import com.profile.matcher.dto.campaign.CampaignDto;
+ import com.profile.matcher.entity.campaign.Campaign;
+ import com.profile.matcher.entity.player.Player;
+ import com.profile.matcher.repository.CampaignRepository;
+ import org.springframework.beans.factory.annotation.Autowired;
+ import org.springframework.beans.factory.annotation.Value;
+ import org.springframework.core.ParameterizedTypeReference;
+ import org.springframework.http.*;
+ import org.springframework.stereotype.Service;
+ import org.springframework.web.client.RestTemplate;
+ 
+ import java.math.BigDecimal;
+ import java.util.ArrayList;
+ import java.util.Collections;
+ import java.util.List;
+ import java.util.Optional;
+ 
+ @Service
+ public class CampaignService extends BaseService {
+     @Value("${campaign.api.url}")
+     private String campaignApiUrl;
+ 
+     @Autowired
+     private CampaignRepository campaignRepository;
+ 
+     /**
+      * @return
+      */
+     public List<CampaignDto> getCurrentCampaignsRealService() {
+         writeLog("CampaignService.getCurrentCampaignsRealService() IN");
+ 
+         final RestTemplate restTemplate = new RestTemplate();
+         List<CampaignDto> campaignDtoList = new ArrayList<>();
+         final HttpHeaders headers = new HttpHeaders();
+         headers.setContentType(MediaType.APPLICATION_JSON);
+         HttpEntity<String> entity = new HttpEntity<>(headers);
+ 
+         try {
+             ResponseEntity<List<CampaignDto>> response = restTemplate.exchange(
+                     campaignApiUrl,
+                     HttpMethod.GET,
+                     entity,
+                     new ParameterizedTypeReference<>() {
+                     }
+             );
+             campaignDtoList = response.getBody();
+             writeLog("CampaignService.getCurrentCampaignsRealService() get current campaigns: {}", campaignDtoList);
+             return campaignDtoList;
+         } catch (Exception e) {
+             writeLog("Error getting current campaigns - exception: {}", e.getMessage());
+         }
+         return campaignDtoList;
+     }
+ 
+     /**
+      * @return
+      */
+     public List<CampaignDto> getCurrentCampaignsMockedService() {
+         writeLog("CampaignService.getCurrentCampaignsMockedService() IN");
+ 
+         CampaignDto campaign = new CampaignDto();
+         campaign.setGame("mygame");
+         campaign.setName("mycampaign");
+         campaign.setPriority(BigDecimal.valueOf(10.5));
+ 
+         CampaignDto.Matchers.Range levelRange = new CampaignDto.Matchers.Range();
+         levelRange.setMin(1);
+         levelRange.setMax(3);
+ 
+         CampaignDto.Matchers.Has has = new CampaignDto.Matchers.Has();
+         has.setCountry(List.of("US", "RO", "CA"));
+         has.setItems(List.of("item_1"));
+ 
+         CampaignDto.Matchers.DoesNotHave doesNotHave = new CampaignDto.Matchers.DoesNotHave();
+         doesNotHave.setItems(List.of("item_4"));
+ 
+         CampaignDto.Matchers matchers = new CampaignDto.Matchers();
+         matchers.setLevel(levelRange);
+         matchers.setHas(has);
+         matchers.setDoesNotHave(doesNotHave);
+ 
+         campaign.setMatchers(matchers);
+ 
+         campaign.setStart_date("2022-01-25 00:00:00Z");
+         campaign.setEnd_date("2022-02-25 00:00:00Z");
+         campaign.setEnabled(true);
+         campaign.setLast_updated("2021-07-13 11:46:58Z");
+         List<CampaignDto> campaignDtoList = Collections.singletonList(campaign);
+ 
+         writeLog("CampaignService.getCurrentCampaignsMockedService() current campaigns: {}", campaignDtoList);
+ 
+         return campaignDtoList;
+     }
+ 
+     /**
+      * @param campaignDto
+      * @param player
+      * @return
+      */
+     public Optional<Campaign> createCampaignEntity(CampaignDto campaignDto, Player player) {
+         if (null != campaignDto) {
+             writeLog("CampaignService.createCampaignEntity() entity from dto: {}", campaignDto);
+ 
+             Campaign campaign = new Campaign();
+             campaign.setGame(campaignDto.getGame());
+             campaign.setName(campaignDto.getName());
+             campaign.setPriority(campaignDto.getPriority());
+             campaign.setEnabled(campaignDto.getEnabled());
+             List<Player> players = new ArrayList<>();
+             players.add(player);
+             campaign.setPlayers(players);
+ 
+             writeLog("CampaignService.createCampaignEntity() campaign entity created: {}", campaign.getName());
+ 
+             return Optional.of(campaign);
+         }
+ 
+         return Optional.empty();
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-b/sources/source-2.html b/resources/JUnitReport/ns-b/sources/source-2.html new file mode 100644 index 0000000..b652de4 --- /dev/null +++ b/resources/JUnitReport/ns-b/sources/source-2.html @@ -0,0 +1,286 @@ + + + + + + + + Coverage Report > PlayerService + + + + + + +
+ + +

Coverage Summary for Class: PlayerService (com.profile.matcher.service)

+ + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
PlayerService + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
PlayerService$$SpringCGLIB$$0
Total + + 90.9% + + + (10/11) + + + + 82.5% + + + (52/63) + +
+ +
+
+ + +
+ package com.profile.matcher.service;
+ 
+ import com.profile.matcher.arhitecture.BaseService;
+ import com.profile.matcher.dto.campaign.CampaignDto;
+ import com.profile.matcher.entity.player.Item;
+ import com.profile.matcher.entity.player.Player;
+ import com.profile.matcher.exception.FindCurrentCampaignException;
+ import com.profile.matcher.exception.FindPlayerDetailsException;
+ import com.profile.matcher.exception.UpdatePlayerDetailsException;
+ import com.profile.matcher.repository.PlayerRepository;
+ import org.springframework.beans.factory.annotation.Autowired;
+ import org.springframework.http.HttpStatus;
+ import org.springframework.stereotype.Service;
+ import org.springframework.transaction.annotation.Propagation;
+ import org.springframework.transaction.annotation.Transactional;
+ import org.springframework.util.CollectionUtils;
+ 
+ import java.util.Collections;
+ import java.util.List;
+ import java.util.Optional;
+ import java.util.UUID;
+ import java.util.function.BiPredicate;
+ 
+ import static com.profile.matcher.utils.Constants.ErrorCode.ERROR_CURRENT_CAMPAIGN;
+ import static com.profile.matcher.utils.Constants.ErrorCode.ERROR_PLAYER_DETAIL;
+ 
+ @Service
+ public class PlayerService extends BaseService {
+ 
+     @Autowired
+     private CampaignService campaignService;
+     @Autowired
+     private PlayerRepository playerRepository;
+ 
+     /**
+      * @param idPlayer
+      * @return
+      */
+     @Transactional(rollbackFor = {Exception.class, UpdatePlayerDetailsException.class}, propagation = Propagation.REQUIRED)
+     public Optional<Player> getPlayerDetails(String idPlayer) {
+         Optional<Player> optionalPlayer;
+ 
+         try {
+             writeLog("PlayerService.getPlayerDetails() - get player by idPlayer: {}", idPlayer);
+             optionalPlayer = playerRepository.findByIdPlayer(UUID.fromString(idPlayer));
+         } catch (Exception e) {
+             writeLog("PlayerService.getPlayerDetails() - failed to retrieve player: {}", e.getMessage());
+             throw new FindPlayerDetailsException(e.getMessage(), ERROR_PLAYER_DETAIL, HttpStatus.INTERNAL_SERVER_ERROR);
+         }
+ 
+         if (optionalPlayer.isPresent()) {
+             Player player = optionalPlayer.get();
+             writeLog("PlayerService.getPlayerDetails() - player found: {}", player.getIdPlayer());
+ 
+             try {
+                 List<CampaignDto> campaignDtoList = campaignService.getCurrentCampaignsMockedService();
+ 
+                 if (!CollectionUtils.isEmpty(campaignDtoList)) {
+                     campaignDtoList.forEach(campaignDto -> {
+                         if (matchCurrentCampaign(player, campaignDto) && checkNewCampaignForPlayer(player, campaignDto)) {
+ 
+                             campaignService.createCampaignEntity(campaignDto, player).ifPresent(campaign -> {
+                                 player.getCampaigns().add(campaign);
+                                 playerRepository.save(player);
+                                 writeLog("PlayerService.getPlayerDetails() - player updated with a new campaign: {}",
+                                         campaign.getName());
+                             });
+                         }
+                     });
+                 }
+                 writeLog("PlayerService.getPlayerDetails() - player: {}", player.getIdPlayer());
+                 return Optional.of(player);
+             } catch (Exception e) {
+                 writeLog("PlayerService.getPlayerDetails() - failed to retrieve current campaign: {}",
+                         e.getMessage());
+                 throw new FindCurrentCampaignException(e.getMessage(), ERROR_CURRENT_CAMPAIGN, HttpStatus.INTERNAL_SERVER_ERROR);
+             }
+         }
+ 
+         return Optional.empty();
+     }
+ 
+     /**
+      * @param player
+      * @param campaignDto
+      * @return
+      */
+     public static boolean checkNewCampaignForPlayer(Player player, CampaignDto campaignDto) {
+         if (!CollectionUtils.isEmpty(player.getCampaigns())) {
+             return player.getCampaigns()
+                     .stream()
+                     .noneMatch(campaign -> campaign.getName().equals(campaignDto.getName()));
+         }
+         return true;
+     }
+ 
+     /**
+      * @param player
+      * @param campaign
+      * @return
+      */
+     public static boolean matchCurrentCampaign(Player player, CampaignDto campaign) {
+         List<BiPredicate<Player, CampaignDto>> matchers = List.of(
+                 matchLevel,
+                 matchCountry,
+                 matchItems,
+                 matchDoesNotHaveItems
+                 // Add new matchers here
+         );
+ 
+         return matchers.stream().allMatch(matcher -> matcher.test(player, campaign));
+     }
+ 
+     /**
+      *
+      */
+     private static final BiPredicate<Player, CampaignDto> matchLevel = (player, campaign) -> {
+         if (null != player.getLevel()) {
+             int playerLevel = player.getLevel();
+             ;
+             int minLevel = campaign.getMatchers() != null && campaign.getMatchers().getLevel() != null ?
+                     campaign.getMatchers().getLevel().getMin() : Integer.MAX_VALUE;
+             int maxLevel = campaign.getMatchers() != null && campaign.getMatchers().getLevel() != null ?
+                     campaign.getMatchers().getLevel().getMax() : Integer.MIN_VALUE;
+ 
+             return playerLevel >= minLevel && playerLevel <= maxLevel;
+         }
+         return false;
+     };
+ 
+     /**
+      *
+      */
+     private static final BiPredicate<Player, CampaignDto> matchCountry = (player, campaign) -> {
+         if (null != player.getCountry()) {
+             String playerCountry = player.getCountry();
+             List<String> campaignCountries = null != campaign.getMatchers() && null != campaign.getMatchers().getHas() ?
+                     campaign.getMatchers().getHas().getCountry() : Collections.emptyList();
+ 
+             return campaignCountries.contains(playerCountry);
+         }
+         return false;
+     };
+ 
+     /**
+      *
+      */
+     private static final BiPredicate<Player, CampaignDto> matchItems = (player, campaign) -> {
+         if (null != player.getInventory() && !CollectionUtils.isEmpty(player.getInventory().getItems())) {
+             List<Item> playerItems = player.getInventory().getItems();
+             List<String> campaignItems = null != campaign.getMatchers() && null != campaign.getMatchers().getHas() ?
+                     campaign.getMatchers().getHas().getItems() : Collections.emptyList();
+ 
+             return playerItems.stream().map(Item::getName).anyMatch(campaignItems::contains);
+         }
+         return false;
+     };
+ 
+     /**
+      *
+      */
+     private static final BiPredicate<Player, CampaignDto> matchDoesNotHaveItems = (player, campaign) -> {
+         if (null != player.getInventory() && !CollectionUtils.isEmpty(player.getInventory().getItems())) {
+             List<Item> playerItems = player.getInventory().getItems();
+             List<String> campaignDoesNotHaveItems = null != campaign.getMatchers() && null != campaign.getMatchers().getDoesNotHave() ?
+                     campaign.getMatchers().getDoesNotHave().getItems() : Collections.emptyList();
+ 
+             return playerItems.stream().map(Item::getName).noneMatch(campaignDoesNotHaveItems::contains);
+         }
+         return false;
+     };
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-c/index.html b/resources/JUnitReport/ns-c/index.html new file mode 100644 index 0000000..5944b96 --- /dev/null +++ b/resources/JUnitReport/ns-c/index.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.utils + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.utils

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Constants + + 0% + + + (0/2) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-c/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-c/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..4578c9d --- /dev/null +++ b/resources/JUnitReport/ns-c/index_SORT_BY_BLOCK.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.utils + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.utils

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Constants + + 0% + + + (0/2) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-c/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-c/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..95553c4 --- /dev/null +++ b/resources/JUnitReport/ns-c/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.utils + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.utils

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
Constants + + 0% + + + (0/2) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-c/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-c/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..c4beb61 --- /dev/null +++ b/resources/JUnitReport/ns-c/index_SORT_BY_CLASS.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.utils + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.utils

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Constants + + 0% + + + (0/2) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-c/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-c/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..bb4fc20 --- /dev/null +++ b/resources/JUnitReport/ns-c/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.utils + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.utils

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
Constants + + 0% + + + (0/2) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-c/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-c/index_SORT_BY_LINE.html new file mode 100644 index 0000000..f4e450d --- /dev/null +++ b/resources/JUnitReport/ns-c/index_SORT_BY_LINE.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.utils + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.utils

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Constants + + 0% + + + (0/2) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-c/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-c/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..b6c7a98 --- /dev/null +++ b/resources/JUnitReport/ns-c/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.utils + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.utils

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
Constants + + 0% + + + (0/2) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-c/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-c/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..9e63d3b --- /dev/null +++ b/resources/JUnitReport/ns-c/index_SORT_BY_METHOD.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.utils + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.utils

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
Constants + + 0% + + + (0/2) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-c/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-c/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..875d46e --- /dev/null +++ b/resources/JUnitReport/ns-c/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.utils + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.utils

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
Constants + + 0% + + + (0/2) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-c/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-c/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..62bf589 --- /dev/null +++ b/resources/JUnitReport/ns-c/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,170 @@ + + + + + + Coverage Report > com.profile.matcher.utils + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.utils

+ + + + + + + + + + + + + +
Package + Class, % + + Method, % + + Line, % +
com.profile.matcher.utils + + 33.3% + + + (1/3) + + + + 25% + + + (1/4) + + + + 28.6% + + + (2/7) + +
+ +
+
+ + + + + + + + + + + + + + + + + + + + +
+Class + Class, % + + Method, % + + Line, % +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
Constants + + 0% + + + (0/2) + + + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-c/sources/source-1.html b/resources/JUnitReport/ns-c/sources/source-1.html new file mode 100644 index 0000000..6c01999 --- /dev/null +++ b/resources/JUnitReport/ns-c/sources/source-1.html @@ -0,0 +1,147 @@ + + + + + + + + Coverage Report > Constants + + + + + + +
+ + +

Coverage Summary for Class: Constants (com.profile.matcher.utils)

+ + + + + + + + + + + + + + + + + + + + + + + +
Class + Method, % + + Line, % +
Constants$DateTimePatterns + + 0% + + + (0/1) + + + + 0% + + + (0/1) + +
Constants$ErrorCode + + 0% + + + (0/1) + + + + 0% + + + (0/1) + +
Total + + 0% + + + (0/2) + + + + 0% + + + (0/2) + +
+ +
+
+ + +
+ package com.profile.matcher.utils;
+ 
+ public class Constants {
+ 
+     private Constants() {
+     }
+ 
+     public static final class DateTimePatterns {
+         public static final String DATE_WITH_TIME = "yyyy-MM-dd HH:mm:ss'Z'";
+     }
+ 
+     public static final class ErrorCode {
+         public static final String DEFAULT_ERROR_CODE = "generic.error";
+         public static final String ERROR_PLAYER_DETAIL = "error.player.detail";
+         public static final String ERROR_CURRENT_CAMPAIGN = "error.current.campaign";
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-c/sources/source-2.html b/resources/JUnitReport/ns-c/sources/source-2.html new file mode 100644 index 0000000..d5e2963 --- /dev/null +++ b/resources/JUnitReport/ns-c/sources/source-2.html @@ -0,0 +1,121 @@ + + + + + + + + Coverage Report > DateHelper + + + + + + +
+ + +

Coverage Summary for Class: DateHelper (com.profile.matcher.utils)

+ + + + + + + + + + + + + + + +
Class + Class, % + + Method, % + + Line, % +
DateHelper + + 100% + + + (1/1) + + + + 50% + + + (1/2) + + + + 40% + + + (2/5) + +
+ +
+
+ + +
+ package com.profile.matcher.utils;
+ 
+ import java.sql.Timestamp;
+ import java.text.SimpleDateFormat;
+ 
+ import static com.profile.matcher.utils.Constants.DateTimePatterns.DATE_WITH_TIME;
+ 
+ public final class DateHelper {
+ 
+     public static String toFormattedDateTimeString(Timestamp dateTime) {
+         if (null == dateTime) {
+             return null;
+         }
+         SimpleDateFormat formatter = new SimpleDateFormat(DATE_WITH_TIME);
+         return formatter.format(dateTime);
+     }
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-d/index.html b/resources/JUnitReport/ns-d/index.html new file mode 100644 index 0000000..95f3e8a --- /dev/null +++ b/resources/JUnitReport/ns-d/index.html @@ -0,0 +1,68 @@ + + + + + + Coverage Report > com.profile.matcher.repository + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.repository

+ + + + + + + +
Package
com.profile.matcher.repository
+ +
+
+ + + + + +
+Class
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-d/index_SORT_BY_BLOCK.html b/resources/JUnitReport/ns-d/index_SORT_BY_BLOCK.html new file mode 100644 index 0000000..5cb4b2c --- /dev/null +++ b/resources/JUnitReport/ns-d/index_SORT_BY_BLOCK.html @@ -0,0 +1,68 @@ + + + + + + Coverage Report > com.profile.matcher.repository + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.repository

+ + + + + + + +
Package
com.profile.matcher.repository
+ +
+
+ + + + + +
+Class
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-d/index_SORT_BY_BLOCK_DESC.html b/resources/JUnitReport/ns-d/index_SORT_BY_BLOCK_DESC.html new file mode 100644 index 0000000..27c28fa --- /dev/null +++ b/resources/JUnitReport/ns-d/index_SORT_BY_BLOCK_DESC.html @@ -0,0 +1,68 @@ + + + + + + Coverage Report > com.profile.matcher.repository + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.repository

+ + + + + + + +
Package
com.profile.matcher.repository
+ +
+
+ + + + + +
+Class
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-d/index_SORT_BY_CLASS.html b/resources/JUnitReport/ns-d/index_SORT_BY_CLASS.html new file mode 100644 index 0000000..05112d6 --- /dev/null +++ b/resources/JUnitReport/ns-d/index_SORT_BY_CLASS.html @@ -0,0 +1,68 @@ + + + + + + Coverage Report > com.profile.matcher.repository + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.repository

+ + + + + + + +
Package
com.profile.matcher.repository
+ +
+
+ + + + + +
+Class
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-d/index_SORT_BY_CLASS_DESC.html b/resources/JUnitReport/ns-d/index_SORT_BY_CLASS_DESC.html new file mode 100644 index 0000000..0dad418 --- /dev/null +++ b/resources/JUnitReport/ns-d/index_SORT_BY_CLASS_DESC.html @@ -0,0 +1,68 @@ + + + + + + Coverage Report > com.profile.matcher.repository + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.repository

+ + + + + + + +
Package
com.profile.matcher.repository
+ +
+
+ + + + + +
+Class
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-d/index_SORT_BY_LINE.html b/resources/JUnitReport/ns-d/index_SORT_BY_LINE.html new file mode 100644 index 0000000..c87980b --- /dev/null +++ b/resources/JUnitReport/ns-d/index_SORT_BY_LINE.html @@ -0,0 +1,68 @@ + + + + + + Coverage Report > com.profile.matcher.repository + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.repository

+ + + + + + + +
Package
com.profile.matcher.repository
+ +
+
+ + + + + +
+Class
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-d/index_SORT_BY_LINE_DESC.html b/resources/JUnitReport/ns-d/index_SORT_BY_LINE_DESC.html new file mode 100644 index 0000000..0d1bdee --- /dev/null +++ b/resources/JUnitReport/ns-d/index_SORT_BY_LINE_DESC.html @@ -0,0 +1,68 @@ + + + + + + Coverage Report > com.profile.matcher.repository + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.repository

+ + + + + + + +
Package
com.profile.matcher.repository
+ +
+
+ + + + + +
+Class
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-d/index_SORT_BY_METHOD.html b/resources/JUnitReport/ns-d/index_SORT_BY_METHOD.html new file mode 100644 index 0000000..7795e07 --- /dev/null +++ b/resources/JUnitReport/ns-d/index_SORT_BY_METHOD.html @@ -0,0 +1,68 @@ + + + + + + Coverage Report > com.profile.matcher.repository + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.repository

+ + + + + + + +
Package
com.profile.matcher.repository
+ +
+
+ + + + + +
+Class
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-d/index_SORT_BY_METHOD_DESC.html b/resources/JUnitReport/ns-d/index_SORT_BY_METHOD_DESC.html new file mode 100644 index 0000000..7b0de33 --- /dev/null +++ b/resources/JUnitReport/ns-d/index_SORT_BY_METHOD_DESC.html @@ -0,0 +1,68 @@ + + + + + + Coverage Report > com.profile.matcher.repository + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.repository

+ + + + + + + +
Package
com.profile.matcher.repository
+ +
+
+ + + + + +
+Class
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-d/index_SORT_BY_NAME_DESC.html b/resources/JUnitReport/ns-d/index_SORT_BY_NAME_DESC.html new file mode 100644 index 0000000..ee9da6a --- /dev/null +++ b/resources/JUnitReport/ns-d/index_SORT_BY_NAME_DESC.html @@ -0,0 +1,68 @@ + + + + + + Coverage Report > com.profile.matcher.repository + + + + + + +
+ + + +

Coverage Summary for Package: com.profile.matcher.repository

+ + + + + + + +
Package
com.profile.matcher.repository
+ +
+
+ + + + + +
+Class
+ +
+ + + + + + diff --git a/resources/JUnitReport/ns-d/sources/source-1.html b/resources/JUnitReport/ns-d/sources/source-1.html new file mode 100644 index 0000000..7bdf29e --- /dev/null +++ b/resources/JUnitReport/ns-d/sources/source-1.html @@ -0,0 +1,86 @@ + + + + + + + + Coverage Report > CampaignRepository + + + + + + +
+ + +

Coverage Summary for Class: CampaignRepository (com.profile.matcher.repository)

+ + + + + + + + + + + + + + + + + + +
Class
CampaignRepository$MockitoMock$rNoRGiUw
CampaignRepository$MockitoMock$rNoRGiUw$auxiliary$1kztI7D5
CampaignRepository$MockitoMock$rNoRGiUw$auxiliary$gQH78EMI
Total
+ +
+
+ + +
+ package com.profile.matcher.repository;
+ 
+ import com.profile.matcher.entity.campaign.Campaign;
+ import org.springframework.data.jpa.repository.JpaRepository;
+ import org.springframework.stereotype.Repository;
+ 
+ @Repository
+ public interface CampaignRepository extends JpaRepository<Campaign, Long> {
+ }
+
+
+
+ + + + + + diff --git a/resources/JUnitReport/ns-d/sources/source-2.html b/resources/JUnitReport/ns-d/sources/source-2.html new file mode 100644 index 0000000..f5a2345 --- /dev/null +++ b/resources/JUnitReport/ns-d/sources/source-2.html @@ -0,0 +1,91 @@ + + + + + + + + Coverage Report > PlayerRepository + + + + + + +
+ + +

Coverage Summary for Class: PlayerRepository (com.profile.matcher.repository)

+ + + + + + + + + + + + + + + + + + +
Class
PlayerRepository$MockitoMock$N2ojyooS
PlayerRepository$MockitoMock$N2ojyooS$auxiliary$cTnm7MOY
PlayerRepository$MockitoMock$N2ojyooS$auxiliary$xbb5F4Ja
Total
+ +
+
+ + +
+ package com.profile.matcher.repository;
+ 
+ import com.profile.matcher.entity.player.Player;
+ import org.springframework.data.jpa.repository.JpaRepository;
+ import org.springframework.data.jpa.repository.Query;
+ 
+ import java.util.Optional;
+ import java.util.UUID;
+ 
+ public interface PlayerRepository extends JpaRepository<Player, UUID> {
+ 
+     // @Query(nativeQuery = true, value = "SELECT * FROM PLAYER PL WHERE PL.ID_PLAYER = UUID_TO_BIN(?1)")
+     Optional<Player> findByIdPlayer(UUID idPlayer);
+ }
+
+
+
+ + + + + +