├── UnitTesting02.Projects ├── Category.cs ├── UnitTesting02.Projects.csproj ├── Priority.cs ├── Exceptions │ └── InvalidIssueDescriptionException.cs └── Issue.cs ├── UnitTesting02.ProjectsTests ├── CodeCovArtifacts │ ├── icon_down-dir_active.svg │ ├── icon_minus.svg │ ├── icon_minus_dark.svg │ ├── icon_up-dir.svg │ ├── icon_up-dir_active.svg │ ├── icon_down-dir_active_dark.svg │ ├── icon_plus.svg │ ├── icon_plus_dark.svg │ ├── icon_cube.svg │ ├── icon_cube_dark.svg │ ├── icon_sponsor.svg │ ├── icon_star.svg │ ├── icon_star_dark.svg │ ├── icon_wrench.svg │ ├── icon_wrench_dark.svg │ ├── icon_info-circled.svg │ ├── icon_info-circled_dark.svg │ ├── icon_search-minus.svg │ ├── icon_search-minus_dark.svg │ ├── icon_fork_dark.svg │ ├── icon_search-plus.svg │ ├── icon_search-plus_dark.svg │ ├── icon_fork.svg │ ├── index.htm │ ├── index.html │ ├── UnitTesting02.Projects_InvalidIssueDescriptionException.html │ ├── UnitTesting02.Projects_Issue.html │ ├── class.js │ └── report.css ├── UnitTesting02.ProjectsTests.csproj └── IssueTests.cs ├── UnitTesting02.ConsoleApp ├── UnitTesting02.ConsoleApp.csproj └── Program.cs ├── .vscode ├── launch.json └── tasks.json ├── UnitTesting02.sln └── .gitignore /UnitTesting02.Projects/Category.cs: -------------------------------------------------------------------------------- 1 | namespace UnitTesting02.Projects 2 | { 3 | public enum Category 4 | { 5 | Hardware, 6 | Software, 7 | UnKnown 8 | } 9 | } 10 | -------------------------------------------------------------------------------- /UnitTesting02.Projects/UnitTesting02.Projects.csproj: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | net5.0 5 | 6 | 7 | 8 | -------------------------------------------------------------------------------- /UnitTesting02.Projects/Priority.cs: -------------------------------------------------------------------------------- 1 | namespace UnitTesting02.Projects 2 | { 3 | public enum Priority 4 | { 5 | Low, 6 | Medium, 7 | High, 8 | Urgent 9 | } 10 | } 11 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_down-dir_active.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_minus.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_minus_dark.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_up-dir.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_up-dir_active.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_down-dir_active_dark.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /UnitTesting02.ConsoleApp/UnitTesting02.ConsoleApp.csproj: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | Exe 5 | net5.0 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_plus.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_plus_dark.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_cube.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_cube_dark.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_sponsor.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_star.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_star_dark.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.Projects/Exceptions/InvalidIssueDescriptionException.cs: -------------------------------------------------------------------------------- 1 | using System; 2 | using System.Collections.Generic; 3 | using System.Linq; 4 | using System.Text; 5 | using System.Threading.Tasks; 6 | 7 | namespace UnitTesting02.Projects 8 | { 9 | public class InvalidIssueDescriptionException: Exception 10 | { 11 | public InvalidIssueDescriptionException(): base("issue description cannot be null or whitespace") 12 | { 13 | } 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_wrench.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_wrench_dark.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_info-circled.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_info-circled_dark.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_search-minus.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_search-minus_dark.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_fork_dark.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_search-plus.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_search-plus_dark.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/icon_fork.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/UnitTesting02.ProjectsTests.csproj: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | net5.0 5 | 6 | false 7 | 8 | 9 | 10 | 11 | 12 | 13 | runtime; build; native; contentfiles; analyzers; buildtransitive 14 | all 15 | 16 | 17 | runtime; build; native; contentfiles; analyzers; buildtransitive 18 | all 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | { 2 | "version": "0.2.0", 3 | "configurations": [ 4 | { 5 | // Use IntelliSense to find out which attributes exist for C# debugging 6 | // Use hover for the description of the existing attributes 7 | // For further information visit https://github.com/OmniSharp/omnisharp-vscode/blob/master/debugger-launchjson.md 8 | "name": ".NET Core Launch (console)", 9 | "type": "coreclr", 10 | "request": "launch", 11 | "preLaunchTask": "build", 12 | // If you have changed target frameworks, make sure to update the program path. 13 | "program": "${workspaceFolder}/UnitTesting02.ConsoleApp/bin/Debug/net5.0/UnitTesting02.ConsoleApp.dll", 14 | "args": [], 15 | "cwd": "${workspaceFolder}/UnitTesting02.ConsoleApp", 16 | // For more information about the 'console' field, see https://aka.ms/VSCode-CS-LaunchJson-Console 17 | "console": "internalConsole", 18 | "stopAtEntry": false 19 | }, 20 | { 21 | "name": ".NET Core Attach", 22 | "type": "coreclr", 23 | "request": "attach" 24 | } 25 | ] 26 | } -------------------------------------------------------------------------------- /.vscode/tasks.json: -------------------------------------------------------------------------------- 1 | { 2 | "version": "2.0.0", 3 | "tasks": [ 4 | { 5 | "label": "build", 6 | "command": "dotnet", 7 | "type": "process", 8 | "args": [ 9 | "build", 10 | "${workspaceFolder}/UnitTesting02.ConsoleApp/UnitTesting02.ConsoleApp.csproj", 11 | "/property:GenerateFullPaths=true", 12 | "/consoleloggerparameters:NoSummary" 13 | ], 14 | "problemMatcher": "$msCompile" 15 | }, 16 | { 17 | "label": "publish", 18 | "command": "dotnet", 19 | "type": "process", 20 | "args": [ 21 | "publish", 22 | "${workspaceFolder}/UnitTesting02.ConsoleApp/UnitTesting02.ConsoleApp.csproj", 23 | "/property:GenerateFullPaths=true", 24 | "/consoleloggerparameters:NoSummary" 25 | ], 26 | "problemMatcher": "$msCompile" 27 | }, 28 | { 29 | "label": "watch", 30 | "command": "dotnet", 31 | "type": "process", 32 | "args": [ 33 | "watch", 34 | "run", 35 | "--project", 36 | "${workspaceFolder}/UnitTesting02.ConsoleApp/UnitTesting02.ConsoleApp.csproj" 37 | ], 38 | "problemMatcher": "$msCompile" 39 | } 40 | ] 41 | } -------------------------------------------------------------------------------- /UnitTesting02.Projects/Issue.cs: -------------------------------------------------------------------------------- 1 | using System; 2 | 3 | namespace UnitTesting02.Projects 4 | { 5 | public class Issue 6 | { 7 | public string Key { get; private set; } // "HW-2022-U-1F7531A6", "SW-2019-L-405B417E" 8 | public string Description { get; private set; } 9 | public DateTime CreatedAt { get; private set; } // 0001-01-01 10 | public Priority Priority { get; private set; } 11 | public Category Category { get; private set; } 12 | 13 | 14 | public Issue (string description, Priority priority, Category category, 15 | DateTime? createdAt = null) 16 | { 17 | 18 | if (string.IsNullOrWhiteSpace(description)) 19 | throw new InvalidIssueDescriptionException(); 20 | 21 | Description = description; 22 | 23 | this.Priority = priority; 24 | 25 | this.Category = category; 26 | 27 | this.CreatedAt = createdAt is null ? DateTime.Now : createdAt.Value; 28 | 29 | this.Key = GenerateKey(); 30 | 31 | } 32 | 33 | private string GenerateKey() 34 | { 35 | var categorySegment = Category is Category.Hardware ? "HW" : 36 | Category is Category.Software ? "SW" : "NA"; 37 | 38 | var prioritySegment = 39 | Priority is Priority.Low ? "L" : 40 | Priority is Priority.Medium ? "M" : 41 | Priority is Priority.High ? "H" : "U"; 42 | 43 | var yearSegment = CreatedAt.Year.ToString(); // YYYY 44 | 45 | var uniqueId = Guid.NewGuid().ToString().Substring(0, 8).ToUpper(); 46 | 47 | return $"{ categorySegment }-{yearSegment}-{prioritySegment}-{uniqueId}"; 48 | } 49 | 50 | public override string ToString() 51 | { 52 | return $"[{Key}] {Description}"; 53 | } 54 | } 55 | } 56 | -------------------------------------------------------------------------------- /UnitTesting02.ConsoleApp/Program.cs: -------------------------------------------------------------------------------- 1 | using System; 2 | using System.Collections.Generic; 3 | using UnitTesting02.Projects; 4 | 5 | namespace UnitTesting02.ConsoleApp 6 | { 7 | internal class Program 8 | { 9 | static void Main(string[] args) 10 | { 11 | var issues = new List 12 | { 13 | new Issue("Secretary laptop giving blue screen", Priority.High, Category.UnKnown, DateTime.Now), 14 | new Issue("Printer switch at office #104 is broken", Priority.Urgent, Category.Hardware, DateTime.Now), 15 | new Issue("Upgrade OS for Laptop 101 to windows 11", Priority.Medium, Category.Software, DateTime.Now), 16 | new Issue("Install Password manager application on Laptop 112", Priority.Low, Category.UnKnown, DateTime.Now), 17 | new Issue("Change HDMI Cable for Cafeteria TV", Priority.Low, Category.Hardware, DateTime.Now) 18 | 19 | }; 20 | Print(issues); 21 | Console.ReadKey(); 22 | } 23 | 24 | private static void Print(List issues) 25 | { 26 | var defaultColor = Console.ForegroundColor; 27 | foreach (var item in issues) 28 | { 29 | switch (item.Priority) 30 | { 31 | case Priority.Urgent: Console.ForegroundColor = ConsoleColor.Red; break; 32 | case Priority.High: Console.ForegroundColor = ConsoleColor.DarkRed; break; 33 | case Priority.Medium: Console.ForegroundColor = ConsoleColor.Yellow; break; 34 | case Priority.Low: Console.ForegroundColor = ConsoleColor.DarkYellow; break; 35 | default: Console.ForegroundColor = ConsoleColor.Cyan; break; 36 | } 37 | 38 | 39 | Console.WriteLine(item); 40 | 41 | Console.ForegroundColor = defaultColor; 42 | 43 | } 44 | Console.WriteLine($"\n\nTotal Issues: [{issues.Count}]"); 45 | 46 | } 47 | } 48 | } 49 | -------------------------------------------------------------------------------- /UnitTesting02.sln: -------------------------------------------------------------------------------- 1 | 2 | Microsoft Visual Studio Solution File, Format Version 12.00 3 | # Visual Studio Version 17 4 | VisualStudioVersion = 17.1.32328.378 5 | MinimumVisualStudioVersion = 10.0.40219.1 6 | Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "UnitTesting02.Projects", "UnitTesting02.Projects\UnitTesting02.Projects.csproj", "{EB62EA43-ED09-4602-90FE-1CA3D1A43FAB}" 7 | EndProject 8 | Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "UnitTesting02.ConsoleApp", "UnitTesting02.ConsoleApp\UnitTesting02.ConsoleApp.csproj", "{1539413C-90C0-4650-8518-6843776C3E1E}" 9 | EndProject 10 | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "UnitTesting02.ProjectsTests", "UnitTesting02.ProjectsTests\UnitTesting02.ProjectsTests.csproj", "{113EEDD0-3B6B-4BA7-B93D-0A20D8AA233F}" 11 | EndProject 12 | Global 13 | GlobalSection(SolutionConfigurationPlatforms) = preSolution 14 | Debug|Any CPU = Debug|Any CPU 15 | Release|Any CPU = Release|Any CPU 16 | EndGlobalSection 17 | GlobalSection(ProjectConfigurationPlatforms) = postSolution 18 | {EB62EA43-ED09-4602-90FE-1CA3D1A43FAB}.Debug|Any CPU.ActiveCfg = Debug|Any CPU 19 | {EB62EA43-ED09-4602-90FE-1CA3D1A43FAB}.Debug|Any CPU.Build.0 = Debug|Any CPU 20 | {EB62EA43-ED09-4602-90FE-1CA3D1A43FAB}.Release|Any CPU.ActiveCfg = Release|Any CPU 21 | {EB62EA43-ED09-4602-90FE-1CA3D1A43FAB}.Release|Any CPU.Build.0 = Release|Any CPU 22 | {1539413C-90C0-4650-8518-6843776C3E1E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU 23 | {1539413C-90C0-4650-8518-6843776C3E1E}.Debug|Any CPU.Build.0 = Debug|Any CPU 24 | {1539413C-90C0-4650-8518-6843776C3E1E}.Release|Any CPU.ActiveCfg = Release|Any CPU 25 | {1539413C-90C0-4650-8518-6843776C3E1E}.Release|Any CPU.Build.0 = Release|Any CPU 26 | {113EEDD0-3B6B-4BA7-B93D-0A20D8AA233F}.Debug|Any CPU.ActiveCfg = Debug|Any CPU 27 | {113EEDD0-3B6B-4BA7-B93D-0A20D8AA233F}.Debug|Any CPU.Build.0 = Debug|Any CPU 28 | {113EEDD0-3B6B-4BA7-B93D-0A20D8AA233F}.Release|Any CPU.ActiveCfg = Release|Any CPU 29 | {113EEDD0-3B6B-4BA7-B93D-0A20D8AA233F}.Release|Any CPU.Build.0 = Release|Any CPU 30 | EndGlobalSection 31 | GlobalSection(SolutionProperties) = preSolution 32 | HideSolutionNode = FALSE 33 | EndGlobalSection 34 | GlobalSection(ExtensibilityGlobals) = postSolution 35 | SolutionGuid = {9B1DAB3A-97D2-4F56-BFD9-FD42750ACFFA} 36 | EndGlobalSection 37 | EndGlobal 38 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/IssueTests.cs: -------------------------------------------------------------------------------- 1 | using System; 2 | using System.Linq; 3 | using System.Reflection; 4 | using UnitTesting02.Projects; 5 | using Xunit; 6 | 7 | namespace UnitTesting02.ProjectsTests 8 | { 9 | public class IssueTests 10 | { 11 | [Fact] 12 | public void Constructor_WithIssueDescIsNull_ThrowsInvalidIssueDescriptionException() 13 | { 14 | // Arrange 15 | 16 | // Act 17 | Action ctor = () => new Issue(null, Priority.Low, Category.Hardware, DateTime.Now); 18 | 19 | // Assert 20 | 21 | Assert.Throws(() => ctor()); 22 | } 23 | 24 | [Fact] 25 | public void Constructor_WithIssueDescIsWhiteSpace_ThrowsInvalidIssueDescriptionException() 26 | { 27 | // Arrange 28 | 29 | // Act 30 | Action ctor = () => new Issue(" ", Priority.Low, Category.Hardware, DateTime.Now); 31 | 32 | // Assert 33 | 34 | Assert.Throws(() => ctor()); 35 | } 36 | 37 | [Fact] 38 | public void Constructor_WithIssueNotProvidingCreatedAt_ReturnsCreatedAtCurrentDateTime() 39 | { 40 | // Arrange 41 | var sut = new Issue("Issue #1", Priority.Low, Category.Hardware); 42 | 43 | // Act 44 | var actual = sut.CreatedAt; 45 | 46 | // Assert 47 | 48 | Assert.False(actual == default(DateTime)); 49 | } 50 | 51 | 52 | [Fact] 53 | public void GenerateKey_WithIssueValidProperties_Return18CharIssueKey() 54 | { 55 | // Arrange 56 | var sut = new Issue("Issue #1", Priority.Low, Category.Hardware, 57 | new DateTime(2022, 10, 11, 12, 30, 00)); 58 | 59 | // Act 60 | MethodInfo methodInfo = typeof(Issue).GetMethod("GenerateKey", 61 | BindingFlags.NonPublic | BindingFlags.Instance); 62 | 63 | var actual = methodInfo.Invoke(sut, null).ToString(); 64 | 65 | var expected = "HW-2022-L-ABCD1234"; 66 | 67 | // Assert 68 | Assert.NotNull(actual); 69 | Assert.Equal(expected.Length, actual.Length); 70 | 71 | } 72 | 73 | 74 | 75 | 76 | [Fact] 77 | public void GenerateKey_WithIssueCategoryHardware_ReturnIssueKeyFirstSegmentHW() 78 | { 79 | // Arrange 80 | var sut = new Issue("Issue #1", Priority.High, Category.Hardware, 81 | new DateTime(2022, 10, 11, 12, 30, 00)); 82 | 83 | // Act 84 | MethodInfo methodInfo = typeof(Issue).GetMethod("GenerateKey", 85 | BindingFlags.NonPublic | BindingFlags.Instance); 86 | 87 | var actual = methodInfo.Invoke(sut, null).ToString(); 88 | 89 | var expected = "HW"; 90 | 91 | // Assert 92 | Assert.NotNull(actual); 93 | Assert.Equal(expected, actual.Split("-")[0]); 94 | 95 | } 96 | 97 | 98 | 99 | [Fact] 100 | public void GenerateKey_WithIssuePriorityLow_ReturnIssueKeyThirdSegmentL() 101 | { 102 | // Arrange 103 | var sut = new Issue("Issue #1", Priority.Low, Category.Hardware, 104 | new DateTime(2022, 10, 11, 12, 30, 00)); 105 | 106 | // Act 107 | MethodInfo methodInfo = typeof(Issue).GetMethod("GenerateKey", 108 | BindingFlags.NonPublic | BindingFlags.Instance); 109 | 110 | var actual = methodInfo.Invoke(sut, null).ToString(); 111 | 112 | var expected = "L"; 113 | 114 | // Assert 115 | Assert.NotNull(actual); 116 | Assert.Equal(expected, actual.Split("-")[2]); 117 | 118 | } 119 | 120 | [Fact] 121 | public void GenerateKey_WithIssueCreatedAt_ReturnIssueKeySecondSegmentYYYY() 122 | { 123 | // Arrange 124 | var sut = new Issue("Issue #1", Priority.Low, Category.Hardware, 125 | new DateTime(2022, 10, 11, 12, 30, 00)); 126 | 127 | // Act 128 | MethodInfo methodInfo = typeof(Issue).GetMethod("GenerateKey", 129 | BindingFlags.NonPublic | BindingFlags.Instance); 130 | 131 | var actual = methodInfo.Invoke(sut, null).ToString(); 132 | 133 | var expected = "2022"; 134 | 135 | // Assert 136 | Assert.NotNull(actual); 137 | Assert.Equal(expected, actual.Split("-")[1]); 138 | 139 | } 140 | 141 | [Fact] 142 | public void GenerateKey_WithIssueValidProperies_ReturnIssueKeyFourthSegment8AlphaNumeric() 143 | { 144 | // Arrange 145 | var sut = new Issue("Issue #1", Priority.Low, Category.Hardware, 146 | new DateTime(2022, 10, 11, 12, 30, 00)); 147 | 148 | // Act 149 | MethodInfo methodInfo = typeof(Issue).GetMethod("GenerateKey", 150 | BindingFlags.NonPublic | BindingFlags.Instance); 151 | 152 | var fourthSegment = methodInfo.Invoke(sut, null).ToString().Split("-")[3]; 153 | var isAlphaNumeric = fourthSegment.All(x => char.IsLetterOrDigit(x)); 154 | 155 | // Assert 156 | Assert.True(isAlphaNumeric); 157 | 158 | } 159 | 160 | [Theory] 161 | [InlineData("Issue #1", Priority.Urgent, Category.Software, "2000-10-10", "SW-2000-U-ABCD1234")] 162 | [InlineData("issue #1", Priority.Low, Category.Software, "2022-10-10", "SW-2022-L-ABCD1234")] 163 | [InlineData("issue #1", Priority.Low, Category.UnKnown, "2018-10-10", "NA-2018-L-ABCD1234")] 164 | [InlineData("issue #1", Priority.Low, Category.Hardware, "1992-10-10", "HW-1992-L-ABCD1234")] 165 | [InlineData("issue #1", Priority.Medium, Category.Hardware, "2003-10-10", "HW-2003-M-ABCD1234")] 166 | [InlineData("issue #1", Priority.High, Category.Hardware, "2015-10-10", "HW-2015-H-ABCD1234")] 167 | [InlineData("issue #1", Priority.Urgent, Category.Hardware, "1980-10-10", "HW-1980-U-ABCD1234")] 168 | public void GenerateKey_WithValidIssueProperties_ReturnsExpectedKey 169 | (string desc, Priority priority, Category category, string createdAt, string expected) 170 | { 171 | // Arrange 172 | var sut = new Issue(desc, priority, category, DateTime.Parse(createdAt)); 173 | 174 | // Act 175 | MethodInfo methodInfo = typeof(Issue).GetMethod("GenerateKey", 176 | BindingFlags.NonPublic | BindingFlags.Instance); 177 | 178 | var actual = methodInfo.Invoke(sut, null).ToString(); 179 | 180 | 181 | 182 | // Assert 183 | Assert.Equal(expected.Substring(0, 10), actual.Substring(0, 10)); 184 | 185 | } 186 | } 187 | } 188 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/index.htm: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | Summary - Coverage Report 9 | 10 |
11 |

SummaryStarSponsor

12 |
13 |
14 |
Information
15 |
16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 |
Parser:Cobertura
Assemblies:1
Classes:2
Files:2
Coverage date:2022-05-02 - 11:17:11 PM
39 |
40 |
41 |
42 |
43 |
Line coverage
44 |
45 |
90%
46 |
47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 |
Covered lines:30
Uncovered lines:3
Coverable lines:33
Total lines:70
Line coverage:90.9%
69 |
70 |
71 |
72 |
73 |
Branch coverage
74 |
75 |
100%
76 |
77 | 78 | 79 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 90 |
Covered branches:14
Total branches:14
Branch coverage:100%
91 |
92 |
93 |
94 |
95 |
Method coverage
96 |
97 |
98 |

Method coverage is only available for sponsors.

99 | Upgrade to PRO version 100 |
101 |
102 |
103 |
104 |

Risk Hotspots

105 | 106 | 107 |

No risk hotspots found.

108 |

Coverage

109 | 110 |
111 | 112 | 113 | 114 | 115 | 116 | 117 | 118 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 | 128 | 129 | 130 | 131 | 132 | 133 |
Line coverageBranch coverage
NameCoveredUncoveredCoverableTotalPercentageCoveredTotalPercentage
UnitTesting02.Projects303337090.9%
  
1414100%
 
UnitTesting02.Projects.InvalidIssueDescriptionException30315100%
 
00
 
UnitTesting02.Projects.Issue273305590%
  
1414100%
 
134 |
135 |
136 |
137 | 181 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | Summary - Coverage Report 9 | 10 |
11 |

SummaryStarSponsor

12 |
13 |
14 |
Information
15 |
16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 |
Parser:Cobertura
Assemblies:1
Classes:2
Files:2
Coverage date:2022-05-02 - 11:17:11 PM
39 |
40 |
41 |
42 |
43 |
Line coverage
44 |
45 |
90%
46 |
47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 |
Covered lines:30
Uncovered lines:3
Coverable lines:33
Total lines:70
Line coverage:90.9%
69 |
70 |
71 |
72 |
73 |
Branch coverage
74 |
75 |
100%
76 |
77 | 78 | 79 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 90 |
Covered branches:14
Total branches:14
Branch coverage:100%
91 |
92 |
93 |
94 |
95 |
Method coverage
96 |
97 |
98 |

Method coverage is only available for sponsors.

99 | Upgrade to PRO version 100 |
101 |
102 |
103 |
104 |

Risk Hotspots

105 | 106 | 107 |

No risk hotspots found.

108 |

Coverage

109 | 110 |
111 | 112 | 113 | 114 | 115 | 116 | 117 | 118 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 | 128 | 129 | 130 | 131 | 132 | 133 |
Line coverageBranch coverage
NameCoveredUncoveredCoverableTotalPercentageCoveredTotalPercentage
UnitTesting02.Projects303337090.9%
  
1414100%
 
UnitTesting02.Projects.InvalidIssueDescriptionException30315100%
 
00
 
UnitTesting02.Projects.Issue273305590%
  
1414100%
 
134 |
135 |
136 |
137 | 181 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | ## Ignore Visual Studio temporary files, build results, and 2 | ## files generated by popular Visual Studio add-ons. 3 | ## 4 | ## Get latest from https://github.com/github/gitignore/blob/master/VisualStudio.gitignore 5 | 6 | # User-specific files 7 | *.rsuser 8 | *.suo 9 | *.user 10 | *.userosscache 11 | *.sln.docstates 12 | 13 | # User-specific files (MonoDevelop/Xamarin Studio) 14 | *.userprefs 15 | 16 | # Mono auto generated files 17 | mono_crash.* 18 | 19 | # Build results 20 | [Dd]ebug/ 21 | [Dd]ebugPublic/ 22 | [Rr]elease/ 23 | [Rr]eleases/ 24 | x64/ 25 | x86/ 26 | [Ww][Ii][Nn]32/ 27 | [Aa][Rr][Mm]/ 28 | [Aa][Rr][Mm]64/ 29 | bld/ 30 | [Bb]in/ 31 | [Oo]bj/ 32 | [Ll]og/ 33 | [Ll]ogs/ 34 | 35 | # Visual Studio 2015/2017 cache/options directory 36 | .vs/ 37 | # Uncomment if you have tasks that create the project's static files in wwwroot 38 | #wwwroot/ 39 | 40 | # Visual Studio 2017 auto generated files 41 | Generated\ Files/ 42 | 43 | # MSTest test Results 44 | [Tt]est[Rr]esult*/ 45 | [Bb]uild[Ll]og.* 46 | 47 | # NUnit 48 | *.VisualState.xml 49 | TestResult.xml 50 | nunit-*.xml 51 | 52 | # Build Results of an ATL Project 53 | [Dd]ebugPS/ 54 | [Rr]eleasePS/ 55 | dlldata.c 56 | 57 | # Benchmark Results 58 | BenchmarkDotNet.Artifacts/ 59 | 60 | # .NET 61 | project.lock.json 62 | project.fragment.lock.json 63 | artifacts/ 64 | 65 | # Tye 66 | .tye/ 67 | 68 | # ASP.NET Scaffolding 69 | ScaffoldingReadMe.txt 70 | 71 | # StyleCop 72 | StyleCopReport.xml 73 | 74 | # Files built by Visual Studio 75 | *_i.c 76 | *_p.c 77 | *_h.h 78 | *.ilk 79 | *.meta 80 | *.obj 81 | *.iobj 82 | *.pch 83 | *.pdb 84 | *.ipdb 85 | *.pgc 86 | *.pgd 87 | *.rsp 88 | *.sbr 89 | *.tlb 90 | *.tli 91 | *.tlh 92 | *.tmp 93 | *.tmp_proj 94 | *_wpftmp.csproj 95 | *.log 96 | *.vspscc 97 | *.vssscc 98 | .builds 99 | *.pidb 100 | *.svclog 101 | *.scc 102 | 103 | # Chutzpah Test files 104 | _Chutzpah* 105 | 106 | # Visual C++ cache files 107 | ipch/ 108 | *.aps 109 | *.ncb 110 | *.opendb 111 | *.opensdf 112 | *.sdf 113 | *.cachefile 114 | *.VC.db 115 | *.VC.VC.opendb 116 | 117 | # Visual Studio profiler 118 | *.psess 119 | *.vsp 120 | *.vspx 121 | *.sap 122 | 123 | # Visual Studio Trace Files 124 | *.e2e 125 | 126 | # TFS 2012 Local Workspace 127 | $tf/ 128 | 129 | # Guidance Automation Toolkit 130 | *.gpState 131 | 132 | # ReSharper is a .NET coding add-in 133 | _ReSharper*/ 134 | *.[Rr]e[Ss]harper 135 | *.DotSettings.user 136 | 137 | # TeamCity is a build add-in 138 | _TeamCity* 139 | 140 | # DotCover is a Code Coverage Tool 141 | *.dotCover 142 | 143 | # AxoCover is a Code Coverage Tool 144 | .axoCover/* 145 | !.axoCover/settings.json 146 | 147 | # Coverlet is a free, cross platform Code Coverage Tool 148 | coverage*.json 149 | coverage*.xml 150 | coverage*.info 151 | 152 | # Visual Studio code coverage results 153 | *.coverage 154 | *.coveragexml 155 | 156 | # NCrunch 157 | _NCrunch_* 158 | .*crunch*.local.xml 159 | nCrunchTemp_* 160 | 161 | # MightyMoose 162 | *.mm.* 163 | AutoTest.Net/ 164 | 165 | # Web workbench (sass) 166 | .sass-cache/ 167 | 168 | # Installshield output folder 169 | [Ee]xpress/ 170 | 171 | # DocProject is a documentation generator add-in 172 | DocProject/buildhelp/ 173 | DocProject/Help/*.HxT 174 | DocProject/Help/*.HxC 175 | DocProject/Help/*.hhc 176 | DocProject/Help/*.hhk 177 | DocProject/Help/*.hhp 178 | DocProject/Help/Html2 179 | DocProject/Help/html 180 | 181 | # Click-Once directory 182 | publish/ 183 | 184 | # Publish Web Output 185 | *.[Pp]ublish.xml 186 | *.azurePubxml 187 | # Note: Comment the next line if you want to checkin your web deploy settings, 188 | # but database connection strings (with potential passwords) will be unencrypted 189 | *.pubxml 190 | *.publishproj 191 | 192 | # Microsoft Azure Web App publish settings. Comment the next line if you want to 193 | # checkin your Azure Web App publish settings, but sensitive information contained 194 | # in these scripts will be unencrypted 195 | PublishScripts/ 196 | 197 | # NuGet Packages 198 | *.nupkg 199 | # NuGet Symbol Packages 200 | *.snupkg 201 | # The packages folder can be ignored because of Package Restore 202 | **/[Pp]ackages/* 203 | # except build/, which is used as an MSBuild target. 204 | !**/[Pp]ackages/build/ 205 | # Uncomment if necessary however generally it will be regenerated when needed 206 | #!**/[Pp]ackages/repositories.config 207 | # NuGet v3's project.json files produces more ignorable files 208 | *.nuget.props 209 | *.nuget.targets 210 | 211 | # Microsoft Azure Build Output 212 | csx/ 213 | *.build.csdef 214 | 215 | # Microsoft Azure Emulator 216 | ecf/ 217 | rcf/ 218 | 219 | # Windows Store app package directories and files 220 | AppPackages/ 221 | BundleArtifacts/ 222 | Package.StoreAssociation.xml 223 | _pkginfo.txt 224 | *.appx 225 | *.appxbundle 226 | *.appxupload 227 | 228 | # Visual Studio cache files 229 | # files ending in .cache can be ignored 230 | *.[Cc]ache 231 | # but keep track of directories ending in .cache 232 | !?*.[Cc]ache/ 233 | 234 | # Others 235 | ClientBin/ 236 | ~$* 237 | *~ 238 | *.dbmdl 239 | *.dbproj.schemaview 240 | *.jfm 241 | *.pfx 242 | *.publishsettings 243 | orleans.codegen.cs 244 | 245 | # Including strong name files can present a security risk 246 | # (https://github.com/github/gitignore/pull/2483#issue-259490424) 247 | #*.snk 248 | 249 | # Since there are multiple workflows, uncomment next line to ignore bower_components 250 | # (https://github.com/github/gitignore/pull/1529#issuecomment-104372622) 251 | #bower_components/ 252 | 253 | # RIA/Silverlight projects 254 | Generated_Code/ 255 | 256 | # Backup & report files from converting an old project file 257 | # to a newer Visual Studio version. Backup files are not needed, 258 | # because we have git ;-) 259 | _UpgradeReport_Files/ 260 | Backup*/ 261 | UpgradeLog*.XML 262 | UpgradeLog*.htm 263 | ServiceFabricBackup/ 264 | *.rptproj.bak 265 | 266 | # SQL Server files 267 | *.mdf 268 | *.ldf 269 | *.ndf 270 | 271 | # Business Intelligence projects 272 | *.rdl.data 273 | *.bim.layout 274 | *.bim_*.settings 275 | *.rptproj.rsuser 276 | *- [Bb]ackup.rdl 277 | *- [Bb]ackup ([0-9]).rdl 278 | *- [Bb]ackup ([0-9][0-9]).rdl 279 | 280 | # Microsoft Fakes 281 | FakesAssemblies/ 282 | 283 | # GhostDoc plugin setting file 284 | *.GhostDoc.xml 285 | 286 | # Node.js Tools for Visual Studio 287 | .ntvs_analysis.dat 288 | node_modules/ 289 | 290 | # Visual Studio 6 build log 291 | *.plg 292 | 293 | # Visual Studio 6 workspace options file 294 | *.opt 295 | 296 | # Visual Studio 6 auto-generated workspace file (contains which files were open etc.) 297 | *.vbw 298 | 299 | # Visual Studio LightSwitch build output 300 | **/*.HTMLClient/GeneratedArtifacts 301 | **/*.DesktopClient/GeneratedArtifacts 302 | **/*.DesktopClient/ModelManifest.xml 303 | **/*.Server/GeneratedArtifacts 304 | **/*.Server/ModelManifest.xml 305 | _Pvt_Extensions 306 | 307 | # Paket dependency manager 308 | .paket/paket.exe 309 | paket-files/ 310 | 311 | # FAKE - F# Make 312 | .fake/ 313 | 314 | # CodeRush personal settings 315 | .cr/personal 316 | 317 | # Python Tools for Visual Studio (PTVS) 318 | __pycache__/ 319 | *.pyc 320 | 321 | # Cake - Uncomment if you are using it 322 | # tools/** 323 | # !tools/packages.config 324 | 325 | # Tabs Studio 326 | *.tss 327 | 328 | # Telerik's JustMock configuration file 329 | *.jmconfig 330 | 331 | # BizTalk build output 332 | *.btp.cs 333 | *.btm.cs 334 | *.odx.cs 335 | *.xsd.cs 336 | 337 | # OpenCover UI analysis results 338 | OpenCover/ 339 | 340 | # Azure Stream Analytics local run output 341 | ASALocalRun/ 342 | 343 | # MSBuild Binary and Structured Log 344 | *.binlog 345 | 346 | # NVidia Nsight GPU debugger configuration file 347 | *.nvuser 348 | 349 | # MFractors (Xamarin productivity tool) working folder 350 | .mfractor/ 351 | 352 | # Local History for Visual Studio 353 | .localhistory/ 354 | 355 | # BeatPulse healthcheck temp database 356 | healthchecksdb 357 | 358 | # Backup folder for Package Reference Convert tool in Visual Studio 2017 359 | MigrationBackup/ 360 | 361 | # Ionide (cross platform F# VS Code tools) working folder 362 | .ionide/ 363 | 364 | # Fody - auto-generated XML schema 365 | FodyWeavers.xsd 366 | 367 | ## 368 | ## Visual studio for Mac 369 | ## 370 | 371 | 372 | # globs 373 | Makefile.in 374 | *.userprefs 375 | *.usertasks 376 | config.make 377 | config.status 378 | aclocal.m4 379 | install-sh 380 | autom4te.cache/ 381 | *.tar.gz 382 | tarballs/ 383 | test-results/ 384 | 385 | # Mac bundle stuff 386 | *.dmg 387 | *.app 388 | 389 | # content below from: https://github.com/github/gitignore/blob/master/Global/macOS.gitignore 390 | # General 391 | .DS_Store 392 | .AppleDouble 393 | .LSOverride 394 | 395 | # Icon must end with two \r 396 | Icon 397 | 398 | 399 | # Thumbnails 400 | ._* 401 | 402 | # Files that might appear in the root of a volume 403 | .DocumentRevisions-V100 404 | .fseventsd 405 | .Spotlight-V100 406 | .TemporaryItems 407 | .Trashes 408 | .VolumeIcon.icns 409 | .com.apple.timemachine.donotpresent 410 | 411 | # Directories potentially created on remote AFP share 412 | .AppleDB 413 | .AppleDesktop 414 | Network Trash Folder 415 | Temporary Items 416 | .apdisk 417 | 418 | # content below from: https://github.com/github/gitignore/blob/master/Global/Windows.gitignore 419 | # Windows thumbnail cache files 420 | Thumbs.db 421 | ehthumbs.db 422 | ehthumbs_vista.db 423 | 424 | # Dump file 425 | *.stackdump 426 | 427 | # Folder config file 428 | [Dd]esktop.ini 429 | 430 | # Recycle Bin used on file shares 431 | $RECYCLE.BIN/ 432 | 433 | # Windows Installer files 434 | *.cab 435 | *.msi 436 | *.msix 437 | *.msm 438 | *.msp 439 | 440 | # Windows shortcuts 441 | *.lnk 442 | 443 | # JetBrains Rider 444 | .idea/ 445 | *.sln.iml 446 | 447 | ## 448 | ## Visual Studio Code 449 | ## 450 | .vscode/* 451 | !.vscode/settings.json 452 | !.vscode/tasks.json 453 | !.vscode/launch.json 454 | !.vscode/extensions.json 455 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/UnitTesting02.Projects_InvalidIssueDescriptionException.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | UnitTesting02.Projects.InvalidIssueDescriptionException - Coverage Report 9 | 10 |
11 |

< Summary

12 |
13 |
14 |
Information
15 |
16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 |
Class:UnitTesting02.Projects.InvalidIssueDescriptionException
Assembly:UnitTesting02.Projects
File(s):C:\TFS\UnitTesting02\UnitTesting02.Projects\Exceptions\InvalidIssueDescriptionException.cs
31 |
32 |
33 |
34 |
35 |
36 |
37 |
Line coverage
38 |
39 |
100%
40 |
41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 |
Covered lines:3
Uncovered lines:0
Coverable lines:3
Total lines:15
Line coverage:100%
63 |
64 |
65 |
66 |
67 |
Branch coverage
68 |
69 |
N/A
70 |
71 | 72 | 73 | 74 | 75 | 76 | 77 | 78 | 79 | 80 | 81 | 82 | 83 | 84 |
Covered branches:0
Total branches:0
Branch coverage:N/A
85 |
86 |
87 |
88 |
89 |
Method coverage
90 |
91 |
92 |

Method coverage is only available for sponsors.

93 | Upgrade to PRO version 94 |
95 |
96 |
97 |
98 |

Metrics

99 |
100 | 101 | 102 | 103 | 104 | 105 |
MethodBranch coverage Cyclomatic complexity Line coverage
.ctor()100%1100%
106 |
107 |

File(s)

108 |

C:\TFS\UnitTesting02\UnitTesting02.Projects\Exceptions\InvalidIssueDescriptionException.cs

109 |
110 | 111 | 112 | 113 | 114 | 115 | 116 | 117 | 118 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 | 128 | 129 |
#LineLine coverage
 1using System;
 2using System.Collections.Generic;
 3using System.Linq;
 4using System.Text;
 5using System.Threading.Tasks;
 6
 7namespace UnitTesting02.Projects
 8{
 9    public class InvalidIssueDescriptionException: Exception
 10    {
 211        public InvalidIssueDescriptionException(): base("issue description cannot be null or whitespace")
 212        {
 213        }
 14    }
 15}
130 |
131 |
132 |
133 |
134 |

Methods/Properties

135 | .ctor()
136 |
137 |
138 | 182 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/UnitTesting02.Projects_Issue.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | UnitTesting02.Projects.Issue - Coverage Report 9 | 10 |
11 |

< Summary

12 |
13 |
14 |
Information
15 |
16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 |
Class:UnitTesting02.Projects.Issue
Assembly:UnitTesting02.Projects
File(s):C:\TFS\UnitTesting02\UnitTesting02.Projects\Issue.cs
31 |
32 |
33 |
34 |
35 |
36 |
37 |
Line coverage
38 |
39 |
90%
40 |
41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 |
Covered lines:27
Uncovered lines:3
Coverable lines:30
Total lines:55
Line coverage:90%
63 |
64 |
65 |
66 |
67 |
Branch coverage
68 |
69 |
100%
70 |
71 | 72 | 73 | 74 | 75 | 76 | 77 | 78 | 79 | 80 | 81 | 82 | 83 | 84 |
Covered branches:14
Total branches:14
Branch coverage:100%
85 |
86 |
87 |
88 |
89 |
Method coverage
90 |
91 |
92 |

Method coverage is only available for sponsors.

93 | Upgrade to PRO version 94 |
95 |
96 |
97 |
98 |

Metrics

99 |
100 | 101 | 102 | 103 | 104 | 105 | 106 | 107 | 108 | 109 | 110 | 111 | 112 |
MethodBranch coverage Cyclomatic complexity Line coverage
get_Key()100%1100%
get_Description()100%1100%
get_CreatedAt()100%1100%
get_Priority()100%1100%
get_Category()100%1100%
.ctor(...)100%4100%
GenerateKey()100%10100%
ToString()100%10%
113 |
114 |

File(s)

115 |

C:\TFS\UnitTesting02\UnitTesting02.Projects\Issue.cs

116 |
117 | 118 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 | 128 | 129 | 130 | 131 | 132 | 133 | 134 | 135 | 136 | 137 | 138 | 139 | 140 | 141 | 142 | 143 | 144 | 145 | 146 | 147 | 148 | 149 | 150 | 151 | 152 | 153 | 154 | 155 | 156 | 157 | 158 | 159 | 160 | 161 | 162 | 163 | 164 | 165 | 166 | 167 | 168 | 169 | 170 | 171 | 172 | 173 | 174 | 175 | 176 |
#LineLine coverage
 1using System;
 2
 3namespace UnitTesting02.Projects
 4{
 5    public class Issue
 6    {
 137        public string Key { get; private set; } // "HW-2022-U-1F7531A6", "SW-2019-L-405B417E"
 138        public string Description { get; private set; }
 399        public DateTime CreatedAt { get; private set; } // 0001-01-01
 5610        public Priority Priority { get; private set; }
 4411        public Category Category { get; private set; }
 12
 13
 1514        public Issue (string description, Priority priority, Category category,
 1515            DateTime? createdAt = null)
 1516        {
 17
 1518            if (string.IsNullOrWhiteSpace(description))
 219                throw new InvalidIssueDescriptionException();
 20
 1321            Description = description;
 22
 1323            this.Priority = priority;
 24
 1325            this.Category = category;
 26
 1327            this.CreatedAt = createdAt is null ? DateTime.Now : createdAt.Value;
 28
 1329            this.Key = GenerateKey();
 30
 1331        }
 32
 33        private string GenerateKey()
 2534        {
 2535            var categorySegment = Category is Category.Hardware ? "HW" :
 2536            Category is Category.Software ? "SW" : "NA";
 37
 2538            var prioritySegment =
 2539                Priority is Priority.Low ? "L" :
 2540                   Priority is Priority.Medium ? "M" :
 2541                         Priority is Priority.High ? "H" : "U";
 42
 2543            var yearSegment = CreatedAt.Year.ToString(); // YYYY
 44
 2545            var uniqueId = Guid.NewGuid().ToString().Substring(0, 8).ToUpper();
 46
 2547            return $"{ categorySegment }-{yearSegment}-{prioritySegment}-{uniqueId}";
 2548        }
 49
 50        public override string ToString()
 051        {
 052            return $"[{Key}] {Description}";
 053        }
 54    }
 55}
177 |
178 |
179 |
192 | 236 | -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/class.js: -------------------------------------------------------------------------------- 1 | /* Chartist.js 0.11.4 2 | * Copyright © 2019 Gion Kunz 3 | * Free to use under either the WTFPL license or the MIT license. 4 | * https://raw.githubusercontent.com/gionkunz/chartist-js/master/LICENSE-WTFPL 5 | * https://raw.githubusercontent.com/gionkunz/chartist-js/master/LICENSE-MIT 6 | */ 7 | 8 | !function (a, b) { "function" == typeof define && define.amd ? define("Chartist", [], function () { return a.Chartist = b() }) : "object" == typeof module && module.exports ? module.exports = b() : a.Chartist = b() }(this, function () { 9 | var a = { version: "0.11.4" }; return function (a, b) { "use strict"; var c = a.window, d = a.document; b.namespaces = { svg: "http://www.w3.org/2000/svg", xmlns: "http://www.w3.org/2000/xmlns/", xhtml: "http://www.w3.org/1999/xhtml", xlink: "http://www.w3.org/1999/xlink", ct: "http://gionkunz.github.com/chartist-js/ct" }, b.noop = function (a) { return a }, b.alphaNumerate = function (a) { return String.fromCharCode(97 + a % 26) }, b.extend = function (a) { var c, d, e; for (a = a || {}, c = 1; c < arguments.length; c++) { d = arguments[c]; for (var f in d) e = d[f], "object" != typeof e || null === e || e instanceof Array ? a[f] = e : a[f] = b.extend(a[f], e) } return a }, b.replaceAll = function (a, b, c) { return a.replace(new RegExp(b, "g"), c) }, b.ensureUnit = function (a, b) { return "number" == typeof a && (a += b), a }, b.quantity = function (a) { if ("string" == typeof a) { var b = /^(\d+)\s*(.*)$/g.exec(a); return { value: +b[1], unit: b[2] || void 0 } } return { value: a } }, b.querySelector = function (a) { return a instanceof Node ? a : d.querySelector(a) }, b.times = function (a) { return Array.apply(null, new Array(a)) }, b.sum = function (a, b) { return a + (b ? b : 0) }, b.mapMultiply = function (a) { return function (b) { return b * a } }, b.mapAdd = function (a) { return function (b) { return b + a } }, b.serialMap = function (a, c) { var d = [], e = Math.max.apply(null, a.map(function (a) { return a.length })); return b.times(e).forEach(function (b, e) { var f = a.map(function (a) { return a[e] }); d[e] = c.apply(null, f) }), d }, b.roundWithPrecision = function (a, c) { var d = Math.pow(10, c || b.precision); return Math.round(a * d) / d }, b.precision = 8, b.escapingMap = { "&": "&", "<": "<", ">": ">", '"': """, "'": "'" }, b.serialize = function (a) { return null === a || void 0 === a ? a : ("number" == typeof a ? a = "" + a : "object" == typeof a && (a = JSON.stringify({ data: a })), Object.keys(b.escapingMap).reduce(function (a, c) { return b.replaceAll(a, c, b.escapingMap[c]) }, a)) }, b.deserialize = function (a) { if ("string" != typeof a) return a; a = Object.keys(b.escapingMap).reduce(function (a, c) { return b.replaceAll(a, b.escapingMap[c], c) }, a); try { a = JSON.parse(a), a = void 0 !== a.data ? a.data : a } catch (c) { } return a }, b.createSvg = function (a, c, d, e) { var f; return c = c || "100%", d = d || "100%", Array.prototype.slice.call(a.querySelectorAll("svg")).filter(function (a) { return a.getAttributeNS(b.namespaces.xmlns, "ct") }).forEach(function (b) { a.removeChild(b) }), f = new b.Svg("svg").attr({ width: c, height: d }).addClass(e), f._node.style.width = c, f._node.style.height = d, a.appendChild(f._node), f }, b.normalizeData = function (a, c, d) { var e, f = { raw: a, normalized: {} }; return f.normalized.series = b.getDataArray({ series: a.series || [] }, c, d), e = f.normalized.series.every(function (a) { return a instanceof Array }) ? Math.max.apply(null, f.normalized.series.map(function (a) { return a.length })) : f.normalized.series.length, f.normalized.labels = (a.labels || []).slice(), Array.prototype.push.apply(f.normalized.labels, b.times(Math.max(0, e - f.normalized.labels.length)).map(function () { return "" })), c && b.reverseData(f.normalized), f }, b.safeHasProperty = function (a, b) { return null !== a && "object" == typeof a && a.hasOwnProperty(b) }, b.isDataHoleValue = function (a) { return null === a || void 0 === a || "number" == typeof a && isNaN(a) }, b.reverseData = function (a) { a.labels.reverse(), a.series.reverse(); for (var b = 0; b < a.series.length; b++)"object" == typeof a.series[b] && void 0 !== a.series[b].data ? a.series[b].data.reverse() : a.series[b] instanceof Array && a.series[b].reverse() }, b.getDataArray = function (a, c, d) { function e(a) { if (b.safeHasProperty(a, "value")) return e(a.value); if (b.safeHasProperty(a, "data")) return e(a.data); if (a instanceof Array) return a.map(e); if (!b.isDataHoleValue(a)) { if (d) { var c = {}; return "string" == typeof d ? c[d] = b.getNumberOrUndefined(a) : c.y = b.getNumberOrUndefined(a), c.x = a.hasOwnProperty("x") ? b.getNumberOrUndefined(a.x) : c.x, c.y = a.hasOwnProperty("y") ? b.getNumberOrUndefined(a.y) : c.y, c } return b.getNumberOrUndefined(a) } } return a.series.map(e) }, b.normalizePadding = function (a, b) { return b = b || 0, "number" == typeof a ? { top: a, right: a, bottom: a, left: a } : { top: "number" == typeof a.top ? a.top : b, right: "number" == typeof a.right ? a.right : b, bottom: "number" == typeof a.bottom ? a.bottom : b, left: "number" == typeof a.left ? a.left : b } }, b.getMetaData = function (a, b) { var c = a.data ? a.data[b] : a[b]; return c ? c.meta : void 0 }, b.orderOfMagnitude = function (a) { return Math.floor(Math.log(Math.abs(a)) / Math.LN10) }, b.projectLength = function (a, b, c) { return b / c.range * a }, b.getAvailableHeight = function (a, c) { return Math.max((b.quantity(c.height).value || a.height()) - (c.chartPadding.top + c.chartPadding.bottom) - c.axisX.offset, 0) }, b.getHighLow = function (a, c, d) { function e(a) { if (void 0 !== a) if (a instanceof Array) for (var b = 0; b < a.length; b++)e(a[b]); else { var c = d ? +a[d] : +a; g && c > f.high && (f.high = c), h && c < f.low && (f.low = c) } } c = b.extend({}, c, d ? c["axis" + d.toUpperCase()] : {}); var f = { high: void 0 === c.high ? -Number.MAX_VALUE : +c.high, low: void 0 === c.low ? Number.MAX_VALUE : +c.low }, g = void 0 === c.high, h = void 0 === c.low; return (g || h) && e(a), (c.referenceValue || 0 === c.referenceValue) && (f.high = Math.max(c.referenceValue, f.high), f.low = Math.min(c.referenceValue, f.low)), f.high <= f.low && (0 === f.low ? f.high = 1 : f.low < 0 ? f.high = 0 : f.high > 0 ? f.low = 0 : (f.high = 1, f.low = 0)), f }, b.isNumeric = function (a) { return null !== a && isFinite(a) }, b.isFalseyButZero = function (a) { return !a && 0 !== a }, b.getNumberOrUndefined = function (a) { return b.isNumeric(a) ? +a : void 0 }, b.isMultiValue = function (a) { return "object" == typeof a && ("x" in a || "y" in a) }, b.getMultiValue = function (a, c) { return b.isMultiValue(a) ? b.getNumberOrUndefined(a[c || "y"]) : b.getNumberOrUndefined(a) }, b.rho = function (a) { function b(a, c) { return a % c === 0 ? c : b(c, a % c) } function c(a) { return a * a + 1 } if (1 === a) return a; var d, e = 2, f = 2; if (a % 2 === 0) return 2; do e = c(e) % a, f = c(c(f)) % a, d = b(Math.abs(e - f), a); while (1 === d); return d }, b.getBounds = function (a, c, d, e) { function f(a, b) { return a === (a += b) && (a *= 1 + (b > 0 ? o : -o)), a } var g, h, i, j = 0, k = { high: c.high, low: c.low }; k.valueRange = k.high - k.low, k.oom = b.orderOfMagnitude(k.valueRange), k.step = Math.pow(10, k.oom), k.min = Math.floor(k.low / k.step) * k.step, k.max = Math.ceil(k.high / k.step) * k.step, k.range = k.max - k.min, k.numberOfSteps = Math.round(k.range / k.step); var l = b.projectLength(a, k.step, k), m = l < d, n = e ? b.rho(k.range) : 0; if (e && b.projectLength(a, 1, k) >= d) k.step = 1; else if (e && n < k.step && b.projectLength(a, n, k) >= d) k.step = n; else for (; ;) { if (m && b.projectLength(a, k.step, k) <= d) k.step *= 2; else { if (m || !(b.projectLength(a, k.step / 2, k) >= d)) break; if (k.step /= 2, e && k.step % 1 !== 0) { k.step *= 2; break } } if (j++ > 1e3) throw new Error("Exceeded maximum number of iterations while optimizing scale step!") } var o = 2.221e-16; for (k.step = Math.max(k.step, o), h = k.min, i = k.max; h + k.step <= k.low;)h = f(h, k.step); for (; i - k.step >= k.high;)i = f(i, -k.step); k.min = h, k.max = i, k.range = k.max - k.min; var p = []; for (g = k.min; g <= k.max; g = f(g, k.step)) { var q = b.roundWithPrecision(g); q !== p[p.length - 1] && p.push(q) } return k.values = p, k }, b.polarToCartesian = function (a, b, c, d) { var e = (d - 90) * Math.PI / 180; return { x: a + c * Math.cos(e), y: b + c * Math.sin(e) } }, b.createChartRect = function (a, c, d) { var e = !(!c.axisX && !c.axisY), f = e ? c.axisY.offset : 0, g = e ? c.axisX.offset : 0, h = a.width() || b.quantity(c.width).value || 0, i = a.height() || b.quantity(c.height).value || 0, j = b.normalizePadding(c.chartPadding, d); h = Math.max(h, f + j.left + j.right), i = Math.max(i, g + j.top + j.bottom); var k = { padding: j, width: function () { return this.x2 - this.x1 }, height: function () { return this.y1 - this.y2 } }; return e ? ("start" === c.axisX.position ? (k.y2 = j.top + g, k.y1 = Math.max(i - j.bottom, k.y2 + 1)) : (k.y2 = j.top, k.y1 = Math.max(i - j.bottom - g, k.y2 + 1)), "start" === c.axisY.position ? (k.x1 = j.left + f, k.x2 = Math.max(h - j.right, k.x1 + 1)) : (k.x1 = j.left, k.x2 = Math.max(h - j.right - f, k.x1 + 1))) : (k.x1 = j.left, k.x2 = Math.max(h - j.right, k.x1 + 1), k.y2 = j.top, k.y1 = Math.max(i - j.bottom, k.y2 + 1)), k }, b.createGrid = function (a, c, d, e, f, g, h, i) { var j = {}; j[d.units.pos + "1"] = a, j[d.units.pos + "2"] = a, j[d.counterUnits.pos + "1"] = e, j[d.counterUnits.pos + "2"] = e + f; var k = g.elem("line", j, h.join(" ")); i.emit("draw", b.extend({ type: "grid", axis: d, index: c, group: g, element: k }, j)) }, b.createGridBackground = function (a, b, c, d) { var e = a.elem("rect", { x: b.x1, y: b.y2, width: b.width(), height: b.height() }, c, !0); d.emit("draw", { type: "gridBackground", group: a, element: e }) }, b.createLabel = function (a, c, e, f, g, h, i, j, k, l, m) { var n, o = {}; if (o[g.units.pos] = a + i[g.units.pos], o[g.counterUnits.pos] = i[g.counterUnits.pos], o[g.units.len] = c, o[g.counterUnits.len] = Math.max(0, h - 10), l) { var p = d.createElement("span"); p.className = k.join(" "), p.setAttribute("xmlns", b.namespaces.xhtml), p.innerText = f[e], p.style[g.units.len] = Math.round(o[g.units.len]) + "px", p.style[g.counterUnits.len] = Math.round(o[g.counterUnits.len]) + "px", n = j.foreignObject(p, b.extend({ style: "overflow: visible;" }, o)) } else n = j.elem("text", o, k.join(" ")).text(f[e]); m.emit("draw", b.extend({ type: "label", axis: g, index: e, group: j, element: n, text: f[e] }, o)) }, b.getSeriesOption = function (a, b, c) { if (a.name && b.series && b.series[a.name]) { var d = b.series[a.name]; return d.hasOwnProperty(c) ? d[c] : b[c] } return b[c] }, b.optionsProvider = function (a, d, e) { function f(a) { var f = h; if (h = b.extend({}, j), d) for (i = 0; i < d.length; i++) { var g = c.matchMedia(d[i][0]); g.matches && (h = b.extend(h, d[i][1])) } e && a && e.emit("optionsChanged", { previousOptions: f, currentOptions: h }) } function g() { k.forEach(function (a) { a.removeListener(f) }) } var h, i, j = b.extend({}, a), k = []; if (!c.matchMedia) throw "window.matchMedia not found! Make sure you're using a polyfill."; if (d) for (i = 0; i < d.length; i++) { var l = c.matchMedia(d[i][0]); l.addListener(f), k.push(l) } return f(), { removeMediaQueryListeners: g, getCurrentOptions: function () { return b.extend({}, h) } } }, b.splitIntoSegments = function (a, c, d) { var e = { increasingX: !1, fillHoles: !1 }; d = b.extend({}, e, d); for (var f = [], g = !0, h = 0; h < a.length; h += 2)void 0 === b.getMultiValue(c[h / 2].value) ? d.fillHoles || (g = !0) : (d.increasingX && h >= 2 && a[h] <= a[h - 2] && (g = !0), g && (f.push({ pathCoordinates: [], valueData: [] }), g = !1), f[f.length - 1].pathCoordinates.push(a[h], a[h + 1]), f[f.length - 1].valueData.push(c[h / 2])); return f } }(this || global, a), function (a, b) { "use strict"; b.Interpolation = {}, b.Interpolation.none = function (a) { var c = { fillHoles: !1 }; return a = b.extend({}, c, a), function (c, d) { for (var e = new b.Svg.Path, f = !0, g = 0; g < c.length; g += 2) { var h = c[g], i = c[g + 1], j = d[g / 2]; void 0 !== b.getMultiValue(j.value) ? (f ? e.move(h, i, !1, j) : e.line(h, i, !1, j), f = !1) : a.fillHoles || (f = !0) } return e } }, b.Interpolation.simple = function (a) { var c = { divisor: 2, fillHoles: !1 }; a = b.extend({}, c, a); var d = 1 / Math.max(1, a.divisor); return function (c, e) { for (var f, g, h, i = new b.Svg.Path, j = 0; j < c.length; j += 2) { var k = c[j], l = c[j + 1], m = (k - f) * d, n = e[j / 2]; void 0 !== n.value ? (void 0 === h ? i.move(k, l, !1, n) : i.curve(f + m, g, k - m, l, k, l, !1, n), f = k, g = l, h = n) : a.fillHoles || (f = k = h = void 0) } return i } }, b.Interpolation.cardinal = function (a) { var c = { tension: 1, fillHoles: !1 }; a = b.extend({}, c, a); var d = Math.min(1, Math.max(0, a.tension)), e = 1 - d; return function f(c, g) { var h = b.splitIntoSegments(c, g, { fillHoles: a.fillHoles }); if (h.length) { if (h.length > 1) { var i = []; return h.forEach(function (a) { i.push(f(a.pathCoordinates, a.valueData)) }), b.Svg.Path.join(i) } if (c = h[0].pathCoordinates, g = h[0].valueData, c.length <= 4) return b.Interpolation.none()(c, g); for (var j, k = (new b.Svg.Path).move(c[0], c[1], !1, g[0]), l = 0, m = c.length; m - 2 * !j > l; l += 2) { var n = [{ x: +c[l - 2], y: +c[l - 1] }, { x: +c[l], y: +c[l + 1] }, { x: +c[l + 2], y: +c[l + 3] }, { x: +c[l + 4], y: +c[l + 5] }]; j ? l ? m - 4 === l ? n[3] = { x: +c[0], y: +c[1] } : m - 2 === l && (n[2] = { x: +c[0], y: +c[1] }, n[3] = { x: +c[2], y: +c[3] }) : n[0] = { x: +c[m - 2], y: +c[m - 1] } : m - 4 === l ? n[3] = n[2] : l || (n[0] = { x: +c[l], y: +c[l + 1] }), k.curve(d * (-n[0].x + 6 * n[1].x + n[2].x) / 6 + e * n[2].x, d * (-n[0].y + 6 * n[1].y + n[2].y) / 6 + e * n[2].y, d * (n[1].x + 6 * n[2].x - n[3].x) / 6 + e * n[2].x, d * (n[1].y + 6 * n[2].y - n[3].y) / 6 + e * n[2].y, n[2].x, n[2].y, !1, g[(l + 2) / 2]) } return k } return b.Interpolation.none()([]) } }, b.Interpolation.monotoneCubic = function (a) { var c = { fillHoles: !1 }; return a = b.extend({}, c, a), function d(c, e) { var f = b.splitIntoSegments(c, e, { fillHoles: a.fillHoles, increasingX: !0 }); if (f.length) { if (f.length > 1) { var g = []; return f.forEach(function (a) { g.push(d(a.pathCoordinates, a.valueData)) }), b.Svg.Path.join(g) } if (c = f[0].pathCoordinates, e = f[0].valueData, c.length <= 4) return b.Interpolation.none()(c, e); var h, i, j = [], k = [], l = c.length / 2, m = [], n = [], o = [], p = []; for (h = 0; h < l; h++)j[h] = c[2 * h], k[h] = c[2 * h + 1]; for (h = 0; h < l - 1; h++)o[h] = k[h + 1] - k[h], p[h] = j[h + 1] - j[h], n[h] = o[h] / p[h]; for (m[0] = n[0], m[l - 1] = n[l - 2], h = 1; h < l - 1; h++)0 === n[h] || 0 === n[h - 1] || n[h - 1] > 0 != n[h] > 0 ? m[h] = 0 : (m[h] = 3 * (p[h - 1] + p[h]) / ((2 * p[h] + p[h - 1]) / n[h - 1] + (p[h] + 2 * p[h - 1]) / n[h]), isFinite(m[h]) || (m[h] = 0)); for (i = (new b.Svg.Path).move(j[0], k[0], !1, e[0]), h = 0; h < l - 1; h++)i.curve(j[h] + p[h] / 3, k[h] + m[h] * p[h] / 3, j[h + 1] - p[h] / 3, k[h + 1] - m[h + 1] * p[h] / 3, j[h + 1], k[h + 1], !1, e[h + 1]); return i } return b.Interpolation.none()([]) } }, b.Interpolation.step = function (a) { var c = { postpone: !0, fillHoles: !1 }; return a = b.extend({}, c, a), function (c, d) { for (var e, f, g, h = new b.Svg.Path, i = 0; i < c.length; i += 2) { var j = c[i], k = c[i + 1], l = d[i / 2]; void 0 !== l.value ? (void 0 === g ? h.move(j, k, !1, l) : (a.postpone ? h.line(j, f, !1, g) : h.line(e, k, !1, l), h.line(j, k, !1, l)), e = j, f = k, g = l) : a.fillHoles || (e = f = g = void 0) } return h } } }(this || global, a), function (a, b) { "use strict"; b.EventEmitter = function () { function a(a, b) { d[a] = d[a] || [], d[a].push(b) } function b(a, b) { d[a] && (b ? (d[a].splice(d[a].indexOf(b), 1), 0 === d[a].length && delete d[a]) : delete d[a]) } function c(a, b) { d[a] && d[a].forEach(function (a) { a(b) }), d["*"] && d["*"].forEach(function (c) { c(a, b) }) } var d = []; return { addEventHandler: a, removeEventHandler: b, emit: c } } }(this || global, a), function (a, b) { "use strict"; function c(a) { var b = []; if (a.length) for (var c = 0; c < a.length; c++)b.push(a[c]); return b } function d(a, c) { var d = c || this.prototype || b.Class, e = Object.create(d); b.Class.cloneDefinitions(e, a); var f = function () { var a, c = e.constructor || function () { }; return a = this === b ? Object.create(e) : this, c.apply(a, Array.prototype.slice.call(arguments, 0)), a }; return f.prototype = e, f["super"] = d, f.extend = this.extend, f } function e() { var a = c(arguments), b = a[0]; return a.splice(1, a.length - 1).forEach(function (a) { Object.getOwnPropertyNames(a).forEach(function (c) { delete b[c], Object.defineProperty(b, c, Object.getOwnPropertyDescriptor(a, c)) }) }), b } b.Class = { extend: d, cloneDefinitions: e } }(this || global, a), function (a, b) { "use strict"; function c(a, c, d) { return a && (this.data = a || {}, this.data.labels = this.data.labels || [], this.data.series = this.data.series || [], this.eventEmitter.emit("data", { type: "update", data: this.data })), c && (this.options = b.extend({}, d ? this.options : this.defaultOptions, c), this.initializeTimeoutId || (this.optionsProvider.removeMediaQueryListeners(), this.optionsProvider = b.optionsProvider(this.options, this.responsiveOptions, this.eventEmitter))), this.initializeTimeoutId || this.createChart(this.optionsProvider.getCurrentOptions()), this } function d() { return this.initializeTimeoutId ? i.clearTimeout(this.initializeTimeoutId) : (i.removeEventListener("resize", this.resizeListener), this.optionsProvider.removeMediaQueryListeners()), this } function e(a, b) { return this.eventEmitter.addEventHandler(a, b), this } function f(a, b) { return this.eventEmitter.removeEventHandler(a, b), this } function g() { i.addEventListener("resize", this.resizeListener), this.optionsProvider = b.optionsProvider(this.options, this.responsiveOptions, this.eventEmitter), this.eventEmitter.addEventHandler("optionsChanged", function () { this.update() }.bind(this)), this.options.plugins && this.options.plugins.forEach(function (a) { a instanceof Array ? a[0](this, a[1]) : a(this) }.bind(this)), this.eventEmitter.emit("data", { type: "initial", data: this.data }), this.createChart(this.optionsProvider.getCurrentOptions()), this.initializeTimeoutId = void 0 } function h(a, c, d, e, f) { this.container = b.querySelector(a), this.data = c || {}, this.data.labels = this.data.labels || [], this.data.series = this.data.series || [], this.defaultOptions = d, this.options = e, this.responsiveOptions = f, this.eventEmitter = b.EventEmitter(), this.supportsForeignObject = b.Svg.isSupported("Extensibility"), this.supportsAnimations = b.Svg.isSupported("AnimationEventsAttribute"), this.resizeListener = function () { this.update() }.bind(this), this.container && (this.container.__chartist__ && this.container.__chartist__.detach(), this.container.__chartist__ = this), this.initializeTimeoutId = setTimeout(g.bind(this), 0) } var i = a.window; b.Base = b.Class.extend({ constructor: h, optionsProvider: void 0, container: void 0, svg: void 0, eventEmitter: void 0, createChart: function () { throw new Error("Base chart type can't be instantiated!") }, update: c, detach: d, on: e, off: f, version: b.version, supportsForeignObject: !1 }) }(this || global, a), function (a, b) { "use strict"; function c(a, c, d, e, f) { a instanceof Element ? this._node = a : (this._node = y.createElementNS(b.namespaces.svg, a), "svg" === a && this.attr({ "xmlns:ct": b.namespaces.ct })), c && this.attr(c), d && this.addClass(d), e && (f && e._node.firstChild ? e._node.insertBefore(this._node, e._node.firstChild) : e._node.appendChild(this._node)) } function d(a, c) { return "string" == typeof a ? c ? this._node.getAttributeNS(c, a) : this._node.getAttribute(a) : (Object.keys(a).forEach(function (c) { if (void 0 !== a[c]) if (c.indexOf(":") !== -1) { var d = c.split(":"); this._node.setAttributeNS(b.namespaces[d[0]], c, a[c]) } else this._node.setAttribute(c, a[c]) }.bind(this)), this) } function e(a, c, d, e) { return new b.Svg(a, c, d, this, e) } function f() { return this._node.parentNode instanceof SVGElement ? new b.Svg(this._node.parentNode) : null } function g() { for (var a = this._node; "svg" !== a.nodeName;)a = a.parentNode; return new b.Svg(a) } function h(a) { var c = this._node.querySelector(a); return c ? new b.Svg(c) : null } function i(a) { var c = this._node.querySelectorAll(a); return c.length ? new b.Svg.List(c) : null } function j() { return this._node } function k(a, c, d, e) { if ("string" == typeof a) { var f = y.createElement("div"); f.innerHTML = a, a = f.firstChild } a.setAttribute("xmlns", b.namespaces.xmlns); var g = this.elem("foreignObject", c, d, e); return g._node.appendChild(a), g } function l(a) { return this._node.appendChild(y.createTextNode(a)), this } function m() { for (; this._node.firstChild;)this._node.removeChild(this._node.firstChild); return this } function n() { return this._node.parentNode.removeChild(this._node), this.parent() } function o(a) { return this._node.parentNode.replaceChild(a._node, this._node), a } function p(a, b) { return b && this._node.firstChild ? this._node.insertBefore(a._node, this._node.firstChild) : this._node.appendChild(a._node), this } function q() { return this._node.getAttribute("class") ? this._node.getAttribute("class").trim().split(/\s+/) : [] } function r(a) { return this._node.setAttribute("class", this.classes(this._node).concat(a.trim().split(/\s+/)).filter(function (a, b, c) { return c.indexOf(a) === b }).join(" ")), this } function s(a) { var b = a.trim().split(/\s+/); return this._node.setAttribute("class", this.classes(this._node).filter(function (a) { return b.indexOf(a) === -1 }).join(" ")), this } function t() { return this._node.setAttribute("class", ""), this } function u() { return this._node.getBoundingClientRect().height } function v() { return this._node.getBoundingClientRect().width } function w(a, c, d) { return void 0 === c && (c = !0), Object.keys(a).forEach(function (e) { function f(a, c) { var f, g, h, i = {}; a.easing && (h = a.easing instanceof Array ? a.easing : b.Svg.Easing[a.easing], delete a.easing), a.begin = b.ensureUnit(a.begin, "ms"), a.dur = b.ensureUnit(a.dur, "ms"), h && (a.calcMode = "spline", a.keySplines = h.join(" "), a.keyTimes = "0;1"), c && (a.fill = "freeze", i[e] = a.from, this.attr(i), g = b.quantity(a.begin || 0).value, a.begin = "indefinite"), f = this.elem("animate", b.extend({ attributeName: e }, a)), c && setTimeout(function () { try { f._node.beginElement() } catch (b) { i[e] = a.to, this.attr(i), f.remove() } }.bind(this), g), d && f._node.addEventListener("beginEvent", function () { d.emit("animationBegin", { element: this, animate: f._node, params: a }) }.bind(this)), f._node.addEventListener("endEvent", function () { d && d.emit("animationEnd", { element: this, animate: f._node, params: a }), c && (i[e] = a.to, this.attr(i), f.remove()) }.bind(this)) } a[e] instanceof Array ? a[e].forEach(function (a) { f.bind(this)(a, !1) }.bind(this)) : f.bind(this)(a[e], c) }.bind(this)), this } function x(a) { var c = this; this.svgElements = []; for (var d = 0; d < a.length; d++)this.svgElements.push(new b.Svg(a[d])); Object.keys(b.Svg.prototype).filter(function (a) { return ["constructor", "parent", "querySelector", "querySelectorAll", "replace", "append", "classes", "height", "width"].indexOf(a) === -1 }).forEach(function (a) { c[a] = function () { var d = Array.prototype.slice.call(arguments, 0); return c.svgElements.forEach(function (c) { b.Svg.prototype[a].apply(c, d) }), c } }) } var y = a.document; b.Svg = b.Class.extend({ constructor: c, attr: d, elem: e, parent: f, root: g, querySelector: h, querySelectorAll: i, getNode: j, foreignObject: k, text: l, empty: m, remove: n, replace: o, append: p, classes: q, addClass: r, removeClass: s, removeAllClasses: t, height: u, width: v, animate: w }), b.Svg.isSupported = function (a) { return y.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#" + a, "1.1") }; var z = { easeInSine: [.47, 0, .745, .715], easeOutSine: [.39, .575, .565, 1], easeInOutSine: [.445, .05, .55, .95], easeInQuad: [.55, .085, .68, .53], easeOutQuad: [.25, .46, .45, .94], easeInOutQuad: [.455, .03, .515, .955], easeInCubic: [.55, .055, .675, .19], easeOutCubic: [.215, .61, .355, 1], easeInOutCubic: [.645, .045, .355, 1], easeInQuart: [.895, .03, .685, .22], easeOutQuart: [.165, .84, .44, 1], easeInOutQuart: [.77, 0, .175, 1], easeInQuint: [.755, .05, .855, .06], easeOutQuint: [.23, 1, .32, 1], easeInOutQuint: [.86, 0, .07, 1], easeInExpo: [.95, .05, .795, .035], easeOutExpo: [.19, 1, .22, 1], easeInOutExpo: [1, 0, 0, 1], easeInCirc: [.6, .04, .98, .335], easeOutCirc: [.075, .82, .165, 1], easeInOutCirc: [.785, .135, .15, .86], easeInBack: [.6, -.28, .735, .045], easeOutBack: [.175, .885, .32, 1.275], easeInOutBack: [.68, -.55, .265, 1.55] }; b.Svg.Easing = z, b.Svg.List = b.Class.extend({ constructor: x }) }(this || global, a), function (a, b) { "use strict"; function c(a, c, d, e, f, g) { var h = b.extend({ command: f ? a.toLowerCase() : a.toUpperCase() }, c, g ? { data: g } : {}); d.splice(e, 0, h) } function d(a, b) { a.forEach(function (c, d) { t[c.command.toLowerCase()].forEach(function (e, f) { b(c, e, d, f, a) }) }) } function e(a, c) { this.pathElements = [], this.pos = 0, this.close = a, this.options = b.extend({}, u, c) } function f(a) { return void 0 !== a ? (this.pos = Math.max(0, Math.min(this.pathElements.length, a)), this) : this.pos } function g(a) { return this.pathElements.splice(this.pos, a), this } function h(a, b, d, e) { return c("M", { x: +a, y: +b }, this.pathElements, this.pos++, d, e), this } function i(a, b, d, e) { return c("L", { x: +a, y: +b }, this.pathElements, this.pos++, d, e), this } function j(a, b, d, e, f, g, h, i) { return c("C", { x1: +a, y1: +b, x2: +d, y2: +e, x: +f, y: +g }, this.pathElements, this.pos++, h, i), this } function k(a, b, d, e, f, g, h, i, j) { return c("A", { rx: +a, ry: +b, xAr: +d, lAf: +e, sf: +f, x: +g, y: +h }, this.pathElements, this.pos++, i, j), this } function l(a) { var c = a.replace(/([A-Za-z])([0-9])/g, "$1 $2").replace(/([0-9])([A-Za-z])/g, "$1 $2").split(/[\s,]+/).reduce(function (a, b) { return b.match(/[A-Za-z]/) && a.push([]), a[a.length - 1].push(b), a }, []); "Z" === c[c.length - 1][0].toUpperCase() && c.pop(); var d = c.map(function (a) { var c = a.shift(), d = t[c.toLowerCase()]; return b.extend({ command: c }, d.reduce(function (b, c, d) { return b[c] = +a[d], b }, {})) }), e = [this.pos, 0]; return Array.prototype.push.apply(e, d), Array.prototype.splice.apply(this.pathElements, e), this.pos += d.length, this } function m() { var a = Math.pow(10, this.options.accuracy); return this.pathElements.reduce(function (b, c) { var d = t[c.command.toLowerCase()].map(function (b) { return this.options.accuracy ? Math.round(c[b] * a) / a : c[b] }.bind(this)); return b + c.command + d.join(",") }.bind(this), "") + (this.close ? "Z" : "") } function n(a, b) { return d(this.pathElements, function (c, d) { c[d] *= "x" === d[0] ? a : b }), this } function o(a, b) { return d(this.pathElements, function (c, d) { c[d] += "x" === d[0] ? a : b }), this } function p(a) { return d(this.pathElements, function (b, c, d, e, f) { var g = a(b, c, d, e, f); (g || 0 === g) && (b[c] = g) }), this } function q(a) { var c = new b.Svg.Path(a || this.close); return c.pos = this.pos, c.pathElements = this.pathElements.slice().map(function (a) { return b.extend({}, a) }), c.options = b.extend({}, this.options), c } function r(a) { var c = [new b.Svg.Path]; return this.pathElements.forEach(function (d) { d.command === a.toUpperCase() && 0 !== c[c.length - 1].pathElements.length && c.push(new b.Svg.Path), c[c.length - 1].pathElements.push(d) }), c } function s(a, c, d) { for (var e = new b.Svg.Path(c, d), f = 0; f < a.length; f++)for (var g = a[f], h = 0; h < g.pathElements.length; h++)e.pathElements.push(g.pathElements[h]); return e } var t = { m: ["x", "y"], l: ["x", "y"], c: ["x1", "y1", "x2", "y2", "x", "y"], a: ["rx", "ry", "xAr", "lAf", "sf", "x", "y"] }, u = { accuracy: 3 }; b.Svg.Path = b.Class.extend({ constructor: e, position: f, remove: g, move: h, line: i, curve: j, arc: k, scale: n, translate: o, transform: p, parse: l, stringify: m, clone: q, splitByCommand: r }), b.Svg.Path.elementDescriptions = t, b.Svg.Path.join = s }(this || global, a), function (a, b) { "use strict"; function c(a, b, c, d) { this.units = a, this.counterUnits = a === e.x ? e.y : e.x, this.chartRect = b, this.axisLength = b[a.rectEnd] - b[a.rectStart], this.gridOffset = b[a.rectOffset], this.ticks = c, this.options = d } function d(a, c, d, e, f) { var g = e["axis" + this.units.pos.toUpperCase()], h = this.ticks.map(this.projectValue.bind(this)), i = this.ticks.map(g.labelInterpolationFnc); h.forEach(function (j, k) { var l, m = { x: 0, y: 0 }; l = h[k + 1] ? h[k + 1] - j : Math.max(this.axisLength - j, 30), b.isFalseyButZero(i[k]) && "" !== i[k] || ("x" === this.units.pos ? (j = this.chartRect.x1 + j, m.x = e.axisX.labelOffset.x, "start" === e.axisX.position ? m.y = this.chartRect.padding.top + e.axisX.labelOffset.y + (d ? 5 : 20) : m.y = this.chartRect.y1 + e.axisX.labelOffset.y + (d ? 5 : 20)) : (j = this.chartRect.y1 - j, m.y = e.axisY.labelOffset.y - (d ? l : 0), "start" === e.axisY.position ? m.x = d ? this.chartRect.padding.left + e.axisY.labelOffset.x : this.chartRect.x1 - 10 : m.x = this.chartRect.x2 + e.axisY.labelOffset.x + 10), g.showGrid && b.createGrid(j, k, this, this.gridOffset, this.chartRect[this.counterUnits.len](), a, [e.classNames.grid, e.classNames[this.units.dir]], f), g.showLabel && b.createLabel(j, l, k, i, this, g.offset, m, c, [e.classNames.label, e.classNames[this.units.dir], "start" === g.position ? e.classNames[g.position] : e.classNames.end], d, f)) }.bind(this)) } var e = (a.window, a.document, { x: { pos: "x", len: "width", dir: "horizontal", rectStart: "x1", rectEnd: "x2", rectOffset: "y2" }, y: { pos: "y", len: "height", dir: "vertical", rectStart: "y2", rectEnd: "y1", rectOffset: "x1" } }); b.Axis = b.Class.extend({ constructor: c, createGridAndLabels: d, projectValue: function (a, b, c) { throw new Error("Base axis can't be instantiated!") } }), b.Axis.units = e }(this || global, a), function (a, b) { "use strict"; function c(a, c, d, e) { var f = e.highLow || b.getHighLow(c, e, a.pos); this.bounds = b.getBounds(d[a.rectEnd] - d[a.rectStart], f, e.scaleMinSpace || 20, e.onlyInteger), this.range = { min: this.bounds.min, max: this.bounds.max }, b.AutoScaleAxis["super"].constructor.call(this, a, d, this.bounds.values, e) } function d(a) { return this.axisLength * (+b.getMultiValue(a, this.units.pos) - this.bounds.min) / this.bounds.range } a.window, a.document; b.AutoScaleAxis = b.Axis.extend({ constructor: c, projectValue: d }) }(this || global, a), function (a, b) { "use strict"; function c(a, c, d, e) { var f = e.highLow || b.getHighLow(c, e, a.pos); this.divisor = e.divisor || 1, this.ticks = e.ticks || b.times(this.divisor).map(function (a, b) { return f.low + (f.high - f.low) / this.divisor * b }.bind(this)), this.ticks.sort(function (a, b) { return a - b }), this.range = { min: f.low, max: f.high }, b.FixedScaleAxis["super"].constructor.call(this, a, d, this.ticks, e), this.stepLength = this.axisLength / this.divisor } function d(a) { return this.axisLength * (+b.getMultiValue(a, this.units.pos) - this.range.min) / (this.range.max - this.range.min) } a.window, a.document; b.FixedScaleAxis = b.Axis.extend({ constructor: c, projectValue: d }) }(this || global, a), function (a, b) { "use strict"; function c(a, c, d, e) { b.StepAxis["super"].constructor.call(this, a, d, e.ticks, e); var f = Math.max(1, e.ticks.length - (e.stretch ? 1 : 0)); this.stepLength = this.axisLength / f } function d(a, b) { return this.stepLength * b } a.window, a.document; b.StepAxis = b.Axis.extend({ constructor: c, projectValue: d }) }(this || global, a), function (a, b) { "use strict"; function c(a) { var c = b.normalizeData(this.data, a.reverseData, !0); this.svg = b.createSvg(this.container, a.width, a.height, a.classNames.chart); var d, f, g = this.svg.elem("g").addClass(a.classNames.gridGroup), h = this.svg.elem("g"), i = this.svg.elem("g").addClass(a.classNames.labelGroup), j = b.createChartRect(this.svg, a, e.padding); d = void 0 === a.axisX.type ? new b.StepAxis(b.Axis.units.x, c.normalized.series, j, b.extend({}, a.axisX, { ticks: c.normalized.labels, stretch: a.fullWidth })) : a.axisX.type.call(b, b.Axis.units.x, c.normalized.series, j, a.axisX), f = void 0 === a.axisY.type ? new b.AutoScaleAxis(b.Axis.units.y, c.normalized.series, j, b.extend({}, a.axisY, { high: b.isNumeric(a.high) ? a.high : a.axisY.high, low: b.isNumeric(a.low) ? a.low : a.axisY.low })) : a.axisY.type.call(b, b.Axis.units.y, c.normalized.series, j, a.axisY), d.createGridAndLabels(g, i, this.supportsForeignObject, a, this.eventEmitter), f.createGridAndLabels(g, i, this.supportsForeignObject, a, this.eventEmitter), a.showGridBackground && b.createGridBackground(g, j, a.classNames.gridBackground, this.eventEmitter), c.raw.series.forEach(function (e, g) { var i = h.elem("g"); i.attr({ "ct:series-name": e.name, "ct:meta": b.serialize(e.meta) }), i.addClass([a.classNames.series, e.className || a.classNames.series + "-" + b.alphaNumerate(g)].join(" ")); var k = [], l = []; c.normalized.series[g].forEach(function (a, h) { var i = { x: j.x1 + d.projectValue(a, h, c.normalized.series[g]), y: j.y1 - f.projectValue(a, h, c.normalized.series[g]) }; k.push(i.x, i.y), l.push({ value: a, valueIndex: h, meta: b.getMetaData(e, h) }) }.bind(this)); var m = { lineSmooth: b.getSeriesOption(e, a, "lineSmooth"), showPoint: b.getSeriesOption(e, a, "showPoint"), showLine: b.getSeriesOption(e, a, "showLine"), showArea: b.getSeriesOption(e, a, "showArea"), areaBase: b.getSeriesOption(e, a, "areaBase") }, n = "function" == typeof m.lineSmooth ? m.lineSmooth : m.lineSmooth ? b.Interpolation.monotoneCubic() : b.Interpolation.none(), o = n(k, l); if (m.showPoint && o.pathElements.forEach(function (c) { var h = i.elem("line", { x1: c.x, y1: c.y, x2: c.x + .01, y2: c.y }, a.classNames.point).attr({ "ct:value": [c.data.value.x, c.data.value.y].filter(b.isNumeric).join(","), "ct:meta": b.serialize(c.data.meta) }); this.eventEmitter.emit("draw", { type: "point", value: c.data.value, index: c.data.valueIndex, meta: c.data.meta, series: e, seriesIndex: g, axisX: d, axisY: f, group: i, element: h, x: c.x, y: c.y }) }.bind(this)), m.showLine) { var p = i.elem("path", { d: o.stringify() }, a.classNames.line, !0); this.eventEmitter.emit("draw", { type: "line", values: c.normalized.series[g], path: o.clone(), chartRect: j, index: g, series: e, seriesIndex: g, seriesMeta: e.meta, axisX: d, axisY: f, group: i, element: p }) } if (m.showArea && f.range) { var q = Math.max(Math.min(m.areaBase, f.range.max), f.range.min), r = j.y1 - f.projectValue(q); o.splitByCommand("M").filter(function (a) { return a.pathElements.length > 1 }).map(function (a) { var b = a.pathElements[0], c = a.pathElements[a.pathElements.length - 1]; return a.clone(!0).position(0).remove(1).move(b.x, r).line(b.x, b.y).position(a.pathElements.length + 1).line(c.x, r) }).forEach(function (b) { var h = i.elem("path", { d: b.stringify() }, a.classNames.area, !0); this.eventEmitter.emit("draw", { type: "area", values: c.normalized.series[g], path: b.clone(), series: e, seriesIndex: g, axisX: d, axisY: f, chartRect: j, index: g, group: i, element: h }) }.bind(this)) } }.bind(this)), this.eventEmitter.emit("created", { bounds: f.bounds, chartRect: j, axisX: d, axisY: f, svg: this.svg, options: a }) } function d(a, c, d, f) { b.Line["super"].constructor.call(this, a, c, e, b.extend({}, e, d), f) } var e = (a.window, a.document, { axisX: { offset: 30, position: "end", labelOffset: { x: 0, y: 0 }, showLabel: !0, showGrid: !0, labelInterpolationFnc: b.noop, type: void 0 }, axisY: { offset: 40, position: "start", labelOffset: { x: 0, y: 0 }, showLabel: !0, showGrid: !0, labelInterpolationFnc: b.noop, type: void 0, scaleMinSpace: 20, onlyInteger: !1 }, width: void 0, height: void 0, showLine: !0, showPoint: !0, showArea: !1, areaBase: 0, lineSmooth: !0, showGridBackground: !1, low: void 0, high: void 0, chartPadding: { top: 15, right: 15, bottom: 5, left: 10 }, fullWidth: !1, reverseData: !1, classNames: { chart: "ct-chart-line", label: "ct-label", labelGroup: "ct-labels", series: "ct-series", line: "ct-line", point: "ct-point", area: "ct-area", grid: "ct-grid", gridGroup: "ct-grids", gridBackground: "ct-grid-background", vertical: "ct-vertical", horizontal: "ct-horizontal", start: "ct-start", end: "ct-end" } }); b.Line = b.Base.extend({ constructor: d, createChart: c }) }(this || global, a), function (a, b) { 10 | "use strict"; function c(a) { 11 | var c, d; a.distributeSeries ? (c = b.normalizeData(this.data, a.reverseData, a.horizontalBars ? "x" : "y"), c.normalized.series = c.normalized.series.map(function (a) { return [a] })) : c = b.normalizeData(this.data, a.reverseData, a.horizontalBars ? "x" : "y"), this.svg = b.createSvg(this.container, a.width, a.height, a.classNames.chart + (a.horizontalBars ? " " + a.classNames.horizontalBars : "")); var f = this.svg.elem("g").addClass(a.classNames.gridGroup), g = this.svg.elem("g"), h = this.svg.elem("g").addClass(a.classNames.labelGroup); 12 | if (a.stackBars && 0 !== c.normalized.series.length) { var i = b.serialMap(c.normalized.series, function () { return Array.prototype.slice.call(arguments).map(function (a) { return a }).reduce(function (a, b) { return { x: a.x + (b && b.x) || 0, y: a.y + (b && b.y) || 0 } }, { x: 0, y: 0 }) }); d = b.getHighLow([i], a, a.horizontalBars ? "x" : "y") } else d = b.getHighLow(c.normalized.series, a, a.horizontalBars ? "x" : "y"); d.high = +a.high || (0 === a.high ? 0 : d.high), d.low = +a.low || (0 === a.low ? 0 : d.low); var j, k, l, m, n, o = b.createChartRect(this.svg, a, e.padding); k = a.distributeSeries && a.stackBars ? c.normalized.labels.slice(0, 1) : c.normalized.labels, a.horizontalBars ? (j = m = void 0 === a.axisX.type ? new b.AutoScaleAxis(b.Axis.units.x, c.normalized.series, o, b.extend({}, a.axisX, { highLow: d, referenceValue: 0 })) : a.axisX.type.call(b, b.Axis.units.x, c.normalized.series, o, b.extend({}, a.axisX, { highLow: d, referenceValue: 0 })), l = n = void 0 === a.axisY.type ? new b.StepAxis(b.Axis.units.y, c.normalized.series, o, { ticks: k }) : a.axisY.type.call(b, b.Axis.units.y, c.normalized.series, o, a.axisY)) : (l = m = void 0 === a.axisX.type ? new b.StepAxis(b.Axis.units.x, c.normalized.series, o, { ticks: k }) : a.axisX.type.call(b, b.Axis.units.x, c.normalized.series, o, a.axisX), j = n = void 0 === a.axisY.type ? new b.AutoScaleAxis(b.Axis.units.y, c.normalized.series, o, b.extend({}, a.axisY, { highLow: d, referenceValue: 0 })) : a.axisY.type.call(b, b.Axis.units.y, c.normalized.series, o, b.extend({}, a.axisY, { highLow: d, referenceValue: 0 }))); var p = a.horizontalBars ? o.x1 + j.projectValue(0) : o.y1 - j.projectValue(0), q = []; l.createGridAndLabels(f, h, this.supportsForeignObject, a, this.eventEmitter), j.createGridAndLabels(f, h, this.supportsForeignObject, a, this.eventEmitter), a.showGridBackground && b.createGridBackground(f, o, a.classNames.gridBackground, this.eventEmitter), c.raw.series.forEach(function (d, e) { var f, h, i = e - (c.raw.series.length - 1) / 2; f = a.distributeSeries && !a.stackBars ? l.axisLength / c.normalized.series.length / 2 : a.distributeSeries && a.stackBars ? l.axisLength / 2 : l.axisLength / c.normalized.series[e].length / 2, h = g.elem("g"), h.attr({ "ct:series-name": d.name, "ct:meta": b.serialize(d.meta) }), h.addClass([a.classNames.series, d.className || a.classNames.series + "-" + b.alphaNumerate(e)].join(" ")), c.normalized.series[e].forEach(function (g, k) { var r, s, t, u; if (u = a.distributeSeries && !a.stackBars ? e : a.distributeSeries && a.stackBars ? 0 : k, r = a.horizontalBars ? { x: o.x1 + j.projectValue(g && g.x ? g.x : 0, k, c.normalized.series[e]), y: o.y1 - l.projectValue(g && g.y ? g.y : 0, u, c.normalized.series[e]) } : { x: o.x1 + l.projectValue(g && g.x ? g.x : 0, u, c.normalized.series[e]), y: o.y1 - j.projectValue(g && g.y ? g.y : 0, k, c.normalized.series[e]) }, l instanceof b.StepAxis && (l.options.stretch || (r[l.units.pos] += f * (a.horizontalBars ? -1 : 1)), r[l.units.pos] += a.stackBars || a.distributeSeries ? 0 : i * a.seriesBarDistance * (a.horizontalBars ? -1 : 1)), t = q[k] || p, q[k] = t - (p - r[l.counterUnits.pos]), void 0 !== g) { var v = {}; v[l.units.pos + "1"] = r[l.units.pos], v[l.units.pos + "2"] = r[l.units.pos], !a.stackBars || "accumulate" !== a.stackMode && a.stackMode ? (v[l.counterUnits.pos + "1"] = p, v[l.counterUnits.pos + "2"] = r[l.counterUnits.pos]) : (v[l.counterUnits.pos + "1"] = t, v[l.counterUnits.pos + "2"] = q[k]), v.x1 = Math.min(Math.max(v.x1, o.x1), o.x2), v.x2 = Math.min(Math.max(v.x2, o.x1), o.x2), v.y1 = Math.min(Math.max(v.y1, o.y2), o.y1), v.y2 = Math.min(Math.max(v.y2, o.y2), o.y1); var w = b.getMetaData(d, k); s = h.elem("line", v, a.classNames.bar).attr({ "ct:value": [g.x, g.y].filter(b.isNumeric).join(","), "ct:meta": b.serialize(w) }), this.eventEmitter.emit("draw", b.extend({ type: "bar", value: g, index: k, meta: w, series: d, seriesIndex: e, axisX: m, axisY: n, chartRect: o, group: h, element: s }, v)) } }.bind(this)) }.bind(this)), this.eventEmitter.emit("created", { bounds: j.bounds, chartRect: o, axisX: m, axisY: n, svg: this.svg, options: a }) 13 | } function d(a, c, d, f) { b.Bar["super"].constructor.call(this, a, c, e, b.extend({}, e, d), f) } var e = (a.window, a.document, { axisX: { offset: 30, position: "end", labelOffset: { x: 0, y: 0 }, showLabel: !0, showGrid: !0, labelInterpolationFnc: b.noop, scaleMinSpace: 30, onlyInteger: !1 }, axisY: { offset: 40, position: "start", labelOffset: { x: 0, y: 0 }, showLabel: !0, showGrid: !0, labelInterpolationFnc: b.noop, scaleMinSpace: 20, onlyInteger: !1 }, width: void 0, height: void 0, high: void 0, low: void 0, referenceValue: 0, chartPadding: { top: 15, right: 15, bottom: 5, left: 10 }, seriesBarDistance: 15, stackBars: !1, stackMode: "accumulate", horizontalBars: !1, distributeSeries: !1, reverseData: !1, showGridBackground: !1, classNames: { chart: "ct-chart-bar", horizontalBars: "ct-horizontal-bars", label: "ct-label", labelGroup: "ct-labels", series: "ct-series", bar: "ct-bar", grid: "ct-grid", gridGroup: "ct-grids", gridBackground: "ct-grid-background", vertical: "ct-vertical", horizontal: "ct-horizontal", start: "ct-start", end: "ct-end" } }); b.Bar = b.Base.extend({ constructor: d, createChart: c }) 14 | }(this || global, a), function (a, b) { "use strict"; function c(a, b, c) { var d = b.x > a.x; return d && "explode" === c || !d && "implode" === c ? "start" : d && "implode" === c || !d && "explode" === c ? "end" : "middle" } function d(a) { var d, e, g, h, i, j = b.normalizeData(this.data), k = [], l = a.startAngle; this.svg = b.createSvg(this.container, a.width, a.height, a.donut ? a.classNames.chartDonut : a.classNames.chartPie), e = b.createChartRect(this.svg, a, f.padding), g = Math.min(e.width() / 2, e.height() / 2), i = a.total || j.normalized.series.reduce(function (a, b) { return a + b }, 0); var m = b.quantity(a.donutWidth); "%" === m.unit && (m.value *= g / 100), g -= a.donut && !a.donutSolid ? m.value / 2 : 0, h = "outside" === a.labelPosition || a.donut && !a.donutSolid ? g : "center" === a.labelPosition ? 0 : a.donutSolid ? g - m.value / 2 : g / 2, h += a.labelOffset; var n = { x: e.x1 + e.width() / 2, y: e.y2 + e.height() / 2 }, o = 1 === j.raw.series.filter(function (a) { return a.hasOwnProperty("value") ? 0 !== a.value : 0 !== a }).length; j.raw.series.forEach(function (a, b) { k[b] = this.svg.elem("g", null, null) }.bind(this)), a.showLabel && (d = this.svg.elem("g", null, null)), j.raw.series.forEach(function (e, f) { if (0 !== j.normalized.series[f] || !a.ignoreEmptyValues) { k[f].attr({ "ct:series-name": e.name }), k[f].addClass([a.classNames.series, e.className || a.classNames.series + "-" + b.alphaNumerate(f)].join(" ")); var p = i > 0 ? l + j.normalized.series[f] / i * 360 : 0, q = Math.max(0, l - (0 === f || o ? 0 : .2)); p - q >= 359.99 && (p = q + 359.99); var r, s, t, u = b.polarToCartesian(n.x, n.y, g, q), v = b.polarToCartesian(n.x, n.y, g, p), w = new b.Svg.Path(!a.donut || a.donutSolid).move(v.x, v.y).arc(g, g, 0, p - l > 180, 0, u.x, u.y); a.donut ? a.donutSolid && (t = g - m.value, r = b.polarToCartesian(n.x, n.y, t, l - (0 === f || o ? 0 : .2)), s = b.polarToCartesian(n.x, n.y, t, p), w.line(r.x, r.y), w.arc(t, t, 0, p - l > 180, 1, s.x, s.y)) : w.line(n.x, n.y); var x = a.classNames.slicePie; a.donut && (x = a.classNames.sliceDonut, a.donutSolid && (x = a.classNames.sliceDonutSolid)); var y = k[f].elem("path", { d: w.stringify() }, x); if (y.attr({ "ct:value": j.normalized.series[f], "ct:meta": b.serialize(e.meta) }), a.donut && !a.donutSolid && (y._node.style.strokeWidth = m.value + "px"), this.eventEmitter.emit("draw", { type: "slice", value: j.normalized.series[f], totalDataSum: i, index: f, meta: e.meta, series: e, group: k[f], element: y, path: w.clone(), center: n, radius: g, startAngle: l, endAngle: p }), a.showLabel) { var z; z = 1 === j.raw.series.length ? { x: n.x, y: n.y } : b.polarToCartesian(n.x, n.y, h, l + (p - l) / 2); var A; A = j.normalized.labels && !b.isFalseyButZero(j.normalized.labels[f]) ? j.normalized.labels[f] : j.normalized.series[f]; var B = a.labelInterpolationFnc(A, f); if (B || 0 === B) { var C = d.elem("text", { dx: z.x, dy: z.y, "text-anchor": c(n, z, a.labelDirection) }, a.classNames.label).text("" + B); this.eventEmitter.emit("draw", { type: "label", index: f, group: d, element: C, text: "" + B, x: z.x, y: z.y }) } } l = p } }.bind(this)), this.eventEmitter.emit("created", { chartRect: e, svg: this.svg, options: a }) } function e(a, c, d, e) { b.Pie["super"].constructor.call(this, a, c, f, b.extend({}, f, d), e) } var f = (a.window, a.document, { width: void 0, height: void 0, chartPadding: 5, classNames: { chartPie: "ct-chart-pie", chartDonut: "ct-chart-donut", series: "ct-series", slicePie: "ct-slice-pie", sliceDonut: "ct-slice-donut", sliceDonutSolid: "ct-slice-donut-solid", label: "ct-label" }, startAngle: 0, total: void 0, donut: !1, donutSolid: !1, donutWidth: 60, showLabel: !0, labelOffset: 0, labelPosition: "inside", labelInterpolationFnc: b.noop, labelDirection: "neutral", reverseData: !1, ignoreEmptyValues: !1 }); b.Pie = b.Base.extend({ constructor: e, createChart: d, determineAnchorPosition: c }) }(this || global, a), a 15 | }); 16 | //# sourceMappingURL=chartist.min.js.map 17 | 18 | var i, l, selectedLine = null; 19 | 20 | /* Navigate to hash without browser history entry */ 21 | var navigateToHash = function () { 22 | if (window.history !== undefined && window.history.replaceState !== undefined) { 23 | window.history.replaceState(undefined, undefined, this.getAttribute("href")); 24 | } 25 | }; 26 | 27 | var hashLinks = document.getElementsByClassName('navigatetohash'); 28 | for (i = 0, l = hashLinks.length; i < l; i++) { 29 | hashLinks[i].addEventListener('click', navigateToHash); 30 | } 31 | 32 | /* Switch test method */ 33 | var switchTestMethod = function () { 34 | var method = this.getAttribute("value"); 35 | console.log("Selected test method: " + method); 36 | 37 | var lines, i, l, coverageData, lineAnalysis, cells; 38 | 39 | lines = document.querySelectorAll('.lineAnalysis tr'); 40 | 41 | for (i = 1, l = lines.length; i < l; i++) { 42 | coverageData = JSON.parse(lines[i].getAttribute('data-coverage').replace(/'/g, '"')); 43 | lineAnalysis = coverageData[method]; 44 | cells = lines[i].querySelectorAll('td'); 45 | if (lineAnalysis === undefined) { 46 | lineAnalysis = coverageData.AllTestMethods; 47 | if (lineAnalysis.LVS !== 'gray') { 48 | cells[0].setAttribute('class', 'red'); 49 | cells[1].innerText = cells[1].textContent = '0'; 50 | cells[4].setAttribute('class', 'lightred'); 51 | } 52 | } else { 53 | cells[0].setAttribute('class', lineAnalysis.LVS); 54 | cells[1].innerText = cells[1].textContent = lineAnalysis.VC; 55 | cells[4].setAttribute('class', 'light' + lineAnalysis.LVS); 56 | } 57 | } 58 | }; 59 | 60 | var testMethods = document.getElementsByClassName('switchtestmethod'); 61 | for (i = 0, l = testMethods.length; i < l; i++) { 62 | testMethods[i].addEventListener('change', switchTestMethod); 63 | } 64 | 65 | /* Highlight test method by line */ 66 | var toggleLine = function () { 67 | if (selectedLine === this) { 68 | selectedLine = null; 69 | } else { 70 | selectedLine = null; 71 | unhighlightTestMethods(); 72 | highlightTestMethods.call(this); 73 | selectedLine = this; 74 | } 75 | 76 | }; 77 | var highlightTestMethods = function () { 78 | if (selectedLine !== null) { 79 | return; 80 | } 81 | 82 | var lineAnalysis; 83 | var coverageData = JSON.parse(this.getAttribute('data-coverage').replace(/'/g, '"')); 84 | var testMethods = document.getElementsByClassName('testmethod'); 85 | 86 | for (i = 0, l = testMethods.length; i < l; i++) { 87 | lineAnalysis = coverageData[testMethods[i].id]; 88 | if (lineAnalysis === undefined) { 89 | testMethods[i].className = testMethods[i].className.replace(/\s*light.+/g, ""); 90 | } else { 91 | testMethods[i].className += ' light' + lineAnalysis.LVS; 92 | } 93 | } 94 | }; 95 | var unhighlightTestMethods = function () { 96 | if (selectedLine !== null) { 97 | return; 98 | } 99 | 100 | var testMethods = document.getElementsByClassName('testmethod'); 101 | for (i = 0, l = testMethods.length; i < l; i++) { 102 | testMethods[i].className = testMethods[i].className.replace(/\s*light.+/g, ""); 103 | } 104 | }; 105 | var coverableLines = document.getElementsByClassName('coverableline'); 106 | for (i = 0, l = coverableLines.length; i < l; i++) { 107 | coverableLines[i].addEventListener('click', toggleLine); 108 | coverableLines[i].addEventListener('mouseenter', highlightTestMethods); 109 | coverableLines[i].addEventListener('mouseleave', unhighlightTestMethods); 110 | } 111 | 112 | /* History charts */ 113 | var renderChart = function (chart) { 114 | // Remove current children (e.g. PNG placeholder) 115 | while (chart.firstChild) { 116 | chart.firstChild.remove(); 117 | } 118 | 119 | var chartData = window[chart.getAttribute('data-data')]; 120 | var options = { 121 | axisY: { 122 | type: undefined, 123 | onlyInteger: true 124 | }, 125 | lineSmooth: false, 126 | low: 0, 127 | high: 100, 128 | scaleMinSpace: 20, 129 | onlyInteger: true, 130 | fullWidth: true 131 | }; 132 | var lineChart = new Chartist.Line(chart, { 133 | labels: [], 134 | series: chartData.series 135 | }, options); 136 | 137 | /* Zoom */ 138 | var zoomButtonDiv = document.createElement("div"); 139 | zoomButtonDiv.className = "toggleZoom"; 140 | var zoomButtonLink = document.createElement("a"); 141 | zoomButtonLink.setAttribute("href", ""); 142 | var zoomButtonText = document.createElement("i"); 143 | zoomButtonText.className = "icon-search-plus"; 144 | 145 | zoomButtonLink.appendChild(zoomButtonText); 146 | zoomButtonDiv.appendChild(zoomButtonLink); 147 | 148 | chart.appendChild(zoomButtonDiv); 149 | 150 | zoomButtonDiv.addEventListener('click', function (event) { 151 | event.preventDefault(); 152 | 153 | if (options.axisY.type === undefined) { 154 | options.axisY.type = Chartist.AutoScaleAxis; 155 | zoomButtonText.className = "icon-search-minus"; 156 | } else { 157 | options.axisY.type = undefined; 158 | zoomButtonText.className = "icon-search-plus"; 159 | } 160 | 161 | lineChart.update(null, options); 162 | }); 163 | 164 | var tooltip = document.createElement("div"); 165 | tooltip.className = "tooltip"; 166 | 167 | chart.appendChild(tooltip); 168 | 169 | /* Tooltips */ 170 | var showToolTip = function () { 171 | var index = this.getAttribute('ct:meta'); 172 | 173 | tooltip.innerHTML = chartData.tooltips[index]; 174 | tooltip.style.display = 'block'; 175 | }; 176 | 177 | var moveToolTip = function (event) { 178 | var box = chart.getBoundingClientRect(); 179 | var left = event.pageX - box.left - window.pageXOffset; 180 | var top = event.pageY - box.top - window.pageYOffset; 181 | 182 | left = left + 20; 183 | top = top - tooltip.offsetHeight / 2; 184 | 185 | if (left + tooltip.offsetWidth > box.width) { 186 | left -= tooltip.offsetWidth + 40; 187 | } 188 | 189 | if (top < 0) { 190 | top = 0; 191 | } 192 | 193 | if (top + tooltip.offsetHeight > box.height) { 194 | top = box.height - tooltip.offsetHeight; 195 | } 196 | 197 | tooltip.style.left = left + 'px'; 198 | tooltip.style.top = top + 'px'; 199 | }; 200 | 201 | var hideToolTip = function () { 202 | tooltip.style.display = 'none'; 203 | }; 204 | chart.addEventListener('mousemove', moveToolTip); 205 | 206 | lineChart.on('created', function () { 207 | var chartPoints = chart.getElementsByClassName('ct-point'); 208 | for (i = 0, l = chartPoints.length; i < l; i++) { 209 | chartPoints[i].addEventListener('mousemove', showToolTip); 210 | chartPoints[i].addEventListener('mouseout', hideToolTip); 211 | } 212 | }); 213 | }; 214 | 215 | var charts = document.getElementsByClassName('historychart'); 216 | for (i = 0, l = charts.length; i < l; i++) { 217 | renderChart(charts[i]); 218 | } -------------------------------------------------------------------------------- /UnitTesting02.ProjectsTests/CodeCovArtifacts/report.css: -------------------------------------------------------------------------------- 1 | html { font-family: sans-serif; margin: 0; padding: 0; font-size: 0.9em; background-color: #d6d6d6; height: 100%; } 2 | body { margin: 0; padding: 0; height: 100%; color: #000; } 3 | h1 { font-family: 'Century Gothic', sans-serif; font-size: 1.2em; font-weight: normal; color: #fff; background-color: #6f6f6f; padding: 10px; margin: 20px -20px 20px -20px; } 4 | h1:first-of-type { margin-top: 0; } 5 | h2 { font-size: 1.0em; font-weight: bold; margin: 10px 0 15px 0; padding: 0; } 6 | h3 { font-size: 1.0em; font-weight: bold; margin: 0 0 10px 0; padding: 0; display: inline-block; } 7 | a { color: #c00; text-decoration: none; } 8 | a:hover { color: #000; text-decoration: none; } 9 | h1 a.back { color: #fff; background-color: #949494; display: inline-block; margin: -12px 5px -10px -10px; padding: 10px; border-right: 1px solid #fff; } 10 | h1 a.back:hover { background-color: #ccc; } 11 | h1 a.button { color: #000; background-color: #bebebe; margin: -5px 0 0 10px; padding: 5px 8px 5px 8px; border: 1px solid #fff; font-size: 0.9em; border-radius: 3px; float:right; } 12 | h1 a.button:hover { background-color: #ccc; } 13 | h1 a.button i { position: relative; top: 1px; } 14 | 15 | .container { margin: auto; max-width: 1650px; width: 90%; background-color: #fff; display: flex; box-shadow: 0 0 60px #7d7d7d; min-height: 100%; } 16 | .containerleft { padding: 0 20px 20px 20px; flex: 1; min-width: 1%; } 17 | .containerright { width: 340px; min-width: 340px; background-color: #e5e5e5; height: 100%; } 18 | .containerrightfixed { position: fixed; padding: 0 20px 20px 20px; border-left: 1px solid #6f6f6f; width: 300px; overflow-y: auto; height: 100%; top: 0; bottom: 0; } 19 | .containerrightfixed h1 { background-color: #c00; } 20 | .containerrightfixed label, .containerright a { white-space: nowrap; overflow: hidden; display: inline-block; width: 100%; max-width: 300px; text-overflow: ellipsis; } 21 | .containerright a { margin-bottom: 3px; } 22 | 23 | @media screen and (max-width:1200px){ 24 | .container { box-shadow: none; width: 100%; } 25 | .containerright { display: none; } 26 | } 27 | 28 | .footer { font-size: 0.7em; text-align: center; margin-top: 35px; } 29 | 30 | .card-group { display: flex; flex-wrap: wrap; margin-top: -15px; margin-left: -15px; } 31 | .card-group + .card-group { margin-top: 0; } 32 | .card-group .card { margin-top: 15px; margin-left: 15px; display: flex; flex-direction: column; background-color: #e4e4e4; background: radial-gradient(circle, #fefefe 0%, #f6f6f6 100%); border: 1px solid #c1c1c1; padding: 15px; color: #6f6f6f; max-width: 100% } 33 | .card-group .card .card-header { font-size: 1.5rem; font-family: 'Century Gothic', sans-serif; margin-bottom: 15px; flex-grow: 1; } 34 | .card-group .card .card-body { display: flex; flex-direction: row; gap: 15px; flex-grow: 1; } 35 | .card-group .card .card-body div.table { display: flex; flex-direction: column; } 36 | .card-group .card .large { font-size: 5rem; line-height: 5rem; font-weight: bold; align-self: flex-end; border-left-width: 4px; padding-left: 10px; } 37 | .card-group .card table { align-self: flex-end; border-collapse: collapse; } 38 | .card-group .card table tr { border-bottom: 1px solid #c1c1c1; } 39 | .card-group .card table tr:hover { background-color: #c1c1c1; } 40 | .card-group .card table tr:last-child { border-bottom: none; } 41 | .card-group .card table th, .card-group .card table td { padding: 2px; } 42 | .card-group td.limit-width { max-width: 200px; text-overflow: ellipsis; overflow: hidden; } 43 | .card-group td.overflow-wrap { overflow-wrap: anywhere; } 44 | 45 | .pro-button { color: #fff; background-color: #20A0D2; background-image: linear-gradient(50deg, #1c7ed6 0%, #23b8cf 100%); padding: 10px; border-radius: 3px; font-weight: bold; display: inline-block; } 46 | .pro-button:hover { color: #fff; background-color: #1C8EB7; background-image: linear-gradient(50deg, #1A6FBA 0%, #1EA1B5 100%); } 47 | 48 | th { text-align: left; } 49 | .table-fixed { table-layout: fixed; } 50 | .table-responsive { overflow-x: auto; } 51 | .overview { border: 1px solid #c1c1c1; border-collapse: collapse; width: 100%; word-wrap: break-word; } 52 | .overview th { border: 1px solid #c1c1c1; border-collapse: collapse; padding: 2px 4px 2px 4px; background-color: #ddd; } 53 | .overview tr.namespace th { background-color: #dcdcdc; } 54 | .overview thead th { background-color: #d1d1d1; } 55 | .overview th a { color: #000; } 56 | .overview tr.namespace a { margin-left: 15px; display: block; } 57 | .overview td { border: 1px solid #c1c1c1; border-collapse: collapse; padding: 2px 5px 2px 5px; } 58 | .overview tr.header th { background-color: #d1d1d1; } 59 | .overview tr.header th:nth-child(2n+1) { background-color: #ddd; } 60 | .overview tr.header th:first-child { border-left: 1px solid #fff; border-top: 1px solid #fff; background-color: #fff; } 61 | 62 | div.currenthistory { margin: -2px -5px 0 -5px; padding: 2px 5px 2px 5px; height: 16px; } 63 | .coverage { border-collapse: collapse; font-size: 5px; height: 10px; } 64 | .coverage td { padding: 0; border: none; } 65 | .stripped tr:nth-child(2n+1) { background-color: #F3F3F3; } 66 | 67 | .customizebox { font-size: 0.75em; margin-bottom: 7px; } 68 | .customizebox>div { width: 25%; display: inline-block; } 69 | .customizebox div.right input { width: 150px; } 70 | #namespaceslider { width: 200px; display: inline-block; margin-left: 8px; } 71 | 72 | .percentagebar { 73 | padding-left: 3px; 74 | } 75 | a.percentagebar { 76 | padding-left: 6px; 77 | } 78 | .percentagebarundefined { 79 | border-left: 2px solid #fff; 80 | } 81 | .percentagebar0 { 82 | border-left: 2px solid #c10909; 83 | } 84 | .percentagebar10 { 85 | border-left: 2px solid; 86 | border-image: linear-gradient(to bottom, #c10909 90%, #0aad0a 90%, #0aad0a 100%) 1; 87 | } 88 | .percentagebar20 { 89 | border-left: 2px solid; 90 | border-image: linear-gradient(to bottom, #c10909 80%, #0aad0a 80%, #0aad0a 100%) 1; 91 | } 92 | .percentagebar30 { 93 | border-left: 2px solid; 94 | border-image: linear-gradient(to bottom, #c10909 70%, #0aad0a 70%, #0aad0a 100%) 1; 95 | } 96 | .percentagebar40 { 97 | border-left: 2px solid; 98 | border-image: linear-gradient(to bottom, #c10909 60%, #0aad0a 60%, #0aad0a 100%) 1; 99 | } 100 | .percentagebar50 { 101 | border-left: 2px solid; 102 | border-image: linear-gradient(to bottom, #c10909 50%, #0aad0a 50%, #0aad0a 100%) 1; 103 | } 104 | .percentagebar60 { 105 | border-left: 2px solid; 106 | border-image: linear-gradient(to bottom, #c10909 40%, #0aad0a 40%, #0aad0a 100%) 1; 107 | } 108 | .percentagebar70 { 109 | border-left: 2px solid; 110 | border-image: linear-gradient(to bottom, #c10909 30%, #0aad0a 30%, #0aad0a 100%) 1; 111 | } 112 | .percentagebar80 { 113 | border-left: 2px solid; 114 | border-image: linear-gradient(to bottom, #c10909 20%, #0aad0a 20%, #0aad0a 100%) 1; 115 | } 116 | .percentagebar90 { 117 | border-left: 2px solid; 118 | border-image: linear-gradient(to bottom, #c10909 10%, #0aad0a 10%, #0aad0a 100%) 1; 119 | } 120 | .percentagebar100 { 121 | border-left: 2px solid #0aad0a; 122 | } 123 | 124 | .hidden, .ng-hide { display: none; } 125 | .right { text-align: right; } 126 | .center { text-align: center; } 127 | .rightmargin { padding-right: 8px; } 128 | .leftmargin { padding-left: 5px; } 129 | .green { background-color: #0aad0a; } 130 | .lightgreen { background-color: #dcf4dc; } 131 | .red { background-color: #c10909; } 132 | .lightred { background-color: #f7dede; } 133 | .orange { background-color: #FFA500; } 134 | .lightorange { background-color: #FFEFD5; } 135 | .gray { background-color: #dcdcdc; } 136 | .lightgray { color: #888888; } 137 | .lightgraybg { background-color: #dadada; } 138 | 139 | code { font-family: Consolas, monospace; font-size: 0.9em; } 140 | 141 | .toggleZoom { text-align:right; } 142 | 143 | .ct-chart { position: relative; } 144 | .ct-chart .ct-line { stroke-width: 2px !important; } 145 | .ct-chart .ct-point { stroke-width: 6px !important; transition: stroke-width .2s; } 146 | .ct-chart .ct-point:hover { stroke-width: 10px !important; } 147 | .ct-chart .ct-series.ct-series-a .ct-line, .ct-chart .ct-series.ct-series-a .ct-point { stroke: #c00 !important;} 148 | .ct-chart .ct-series.ct-series-b .ct-line, .ct-chart .ct-series.ct-series-b .ct-point { stroke: #1c2298 !important;} 149 | .ct-chart .ct-series.ct-series-c .ct-line, .ct-chart .ct-series.ct-series-c .ct-point { stroke: #0aad0a !important;} 150 | 151 | .tinylinecoveragechart, .tinybranchcoveragechart, .tinymethodcoveragechart { background-color: #fff; margin-left: -3px; float: left; border: 1px solid #c1c1c1; width: 30px; height: 18px; } 152 | .historiccoverageoffset { margin-top: 7px; } 153 | 154 | .tinylinecoveragechart .ct-line, .tinybranchcoveragechart .ct-line, .tinymethodcoveragechart .ct-line { stroke-width: 1px !important; } 155 | .tinybranchcoveragechart .ct-series.ct-series-a .ct-line { stroke: #1c2298 !important; } 156 | .tinymethodcoveragechart .ct-series.ct-series-a .ct-line { stroke: #0aad0a !important; } 157 | 158 | .linecoverage { background-color: #c00; width: 10px; height: 8px; border: 1px solid #000; display: inline-block; } 159 | .branchcoverage { background-color: #1c2298; width: 10px; height: 8px; border: 1px solid #000; display: inline-block; } 160 | .codeelementcoverage { background-color: #0aad0a; width: 10px; height: 8px; border: 1px solid #000; display: inline-block; } 161 | 162 | .tooltip { position: absolute; display: none; padding: 5px; background: #F4C63D; color: #453D3F; pointer-events: none; z-index: 1; min-width: 250px; } 163 | 164 | .column-min-200 { min-width: 200px; } 165 | .column60 { width: 60px; } 166 | .column70 { width: 70px; } 167 | .column90 { width: 90px; } 168 | .column98 { width: 98px; } 169 | .column100 { width: 100px; } 170 | .column105 { width: 105px; } 171 | .column112 { width: 112px; } 172 | 173 | .cardpercentagebar { border-left-style: solid; } 174 | .cardpercentagebar0 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 0%, #0aad0a 0%) 1; } 175 | .cardpercentagebar1 { border-image: linear-gradient(to bottom, #c10909 1%, #c10909 1%, #0aad0a 1%) 1; } 176 | .cardpercentagebar2 { border-image: linear-gradient(to bottom, #c10909 2%, #c10909 2%, #0aad0a 2%) 1; } 177 | .cardpercentagebar3 { border-image: linear-gradient(to bottom, #c10909 3%, #c10909 3%, #0aad0a 3%) 1; } 178 | .cardpercentagebar4 { border-image: linear-gradient(to bottom, #c10909 4%, #c10909 4%, #0aad0a 4%) 1; } 179 | .cardpercentagebar5 { border-image: linear-gradient(to bottom, #c10909 5%, #c10909 5%, #0aad0a 5%) 1; } 180 | .cardpercentagebar6 { border-image: linear-gradient(to bottom, #c10909 6%, #c10909 6%, #0aad0a 6%) 1; } 181 | .cardpercentagebar7 { border-image: linear-gradient(to bottom, #c10909 7%, #c10909 7%, #0aad0a 7%) 1; } 182 | .cardpercentagebar8 { border-image: linear-gradient(to bottom, #c10909 8%, #c10909 8%, #0aad0a 8%) 1; } 183 | .cardpercentagebar9 { border-image: linear-gradient(to bottom, #c10909 9%, #c10909 9%, #0aad0a 9%) 1; } 184 | .cardpercentagebar10 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 10%, #0aad0a 10%) 1; } 185 | .cardpercentagebar11 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 11%, #0aad0a 11%) 1; } 186 | .cardpercentagebar12 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 12%, #0aad0a 12%) 1; } 187 | .cardpercentagebar13 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 13%, #0aad0a 13%) 1; } 188 | .cardpercentagebar14 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 14%, #0aad0a 14%) 1; } 189 | .cardpercentagebar15 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 15%, #0aad0a 15%) 1; } 190 | .cardpercentagebar16 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 16%, #0aad0a 16%) 1; } 191 | .cardpercentagebar17 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 17%, #0aad0a 17%) 1; } 192 | .cardpercentagebar18 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 18%, #0aad0a 18%) 1; } 193 | .cardpercentagebar19 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 19%, #0aad0a 19%) 1; } 194 | .cardpercentagebar20 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 20%, #0aad0a 20%) 1; } 195 | .cardpercentagebar21 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 21%, #0aad0a 21%) 1; } 196 | .cardpercentagebar22 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 22%, #0aad0a 22%) 1; } 197 | .cardpercentagebar23 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 23%, #0aad0a 23%) 1; } 198 | .cardpercentagebar24 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 24%, #0aad0a 24%) 1; } 199 | .cardpercentagebar25 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 25%, #0aad0a 25%) 1; } 200 | .cardpercentagebar26 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 26%, #0aad0a 26%) 1; } 201 | .cardpercentagebar27 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 27%, #0aad0a 27%) 1; } 202 | .cardpercentagebar28 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 28%, #0aad0a 28%) 1; } 203 | .cardpercentagebar29 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 29%, #0aad0a 29%) 1; } 204 | .cardpercentagebar30 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 30%, #0aad0a 30%) 1; } 205 | .cardpercentagebar31 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 31%, #0aad0a 31%) 1; } 206 | .cardpercentagebar32 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 32%, #0aad0a 32%) 1; } 207 | .cardpercentagebar33 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 33%, #0aad0a 33%) 1; } 208 | .cardpercentagebar34 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 34%, #0aad0a 34%) 1; } 209 | .cardpercentagebar35 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 35%, #0aad0a 35%) 1; } 210 | .cardpercentagebar36 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 36%, #0aad0a 36%) 1; } 211 | .cardpercentagebar37 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 37%, #0aad0a 37%) 1; } 212 | .cardpercentagebar38 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 38%, #0aad0a 38%) 1; } 213 | .cardpercentagebar39 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 39%, #0aad0a 39%) 1; } 214 | .cardpercentagebar40 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 40%, #0aad0a 40%) 1; } 215 | .cardpercentagebar41 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 41%, #0aad0a 41%) 1; } 216 | .cardpercentagebar42 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 42%, #0aad0a 42%) 1; } 217 | .cardpercentagebar43 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 43%, #0aad0a 43%) 1; } 218 | .cardpercentagebar44 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 44%, #0aad0a 44%) 1; } 219 | .cardpercentagebar45 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 45%, #0aad0a 45%) 1; } 220 | .cardpercentagebar46 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 46%, #0aad0a 46%) 1; } 221 | .cardpercentagebar47 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 47%, #0aad0a 47%) 1; } 222 | .cardpercentagebar48 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 48%, #0aad0a 48%) 1; } 223 | .cardpercentagebar49 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 49%, #0aad0a 49%) 1; } 224 | .cardpercentagebar50 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 50%, #0aad0a 50%) 1; } 225 | .cardpercentagebar51 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 51%, #0aad0a 51%) 1; } 226 | .cardpercentagebar52 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 52%, #0aad0a 52%) 1; } 227 | .cardpercentagebar53 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 53%, #0aad0a 53%) 1; } 228 | .cardpercentagebar54 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 54%, #0aad0a 54%) 1; } 229 | .cardpercentagebar55 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 55%, #0aad0a 55%) 1; } 230 | .cardpercentagebar56 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 56%, #0aad0a 56%) 1; } 231 | .cardpercentagebar57 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 57%, #0aad0a 57%) 1; } 232 | .cardpercentagebar58 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 58%, #0aad0a 58%) 1; } 233 | .cardpercentagebar59 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 59%, #0aad0a 59%) 1; } 234 | .cardpercentagebar60 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 60%, #0aad0a 60%) 1; } 235 | .cardpercentagebar61 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 61%, #0aad0a 61%) 1; } 236 | .cardpercentagebar62 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 62%, #0aad0a 62%) 1; } 237 | .cardpercentagebar63 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 63%, #0aad0a 63%) 1; } 238 | .cardpercentagebar64 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 64%, #0aad0a 64%) 1; } 239 | .cardpercentagebar65 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 65%, #0aad0a 65%) 1; } 240 | .cardpercentagebar66 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 66%, #0aad0a 66%) 1; } 241 | .cardpercentagebar67 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 67%, #0aad0a 67%) 1; } 242 | .cardpercentagebar68 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 68%, #0aad0a 68%) 1; } 243 | .cardpercentagebar69 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 69%, #0aad0a 69%) 1; } 244 | .cardpercentagebar70 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 70%, #0aad0a 70%) 1; } 245 | .cardpercentagebar71 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 71%, #0aad0a 71%) 1; } 246 | .cardpercentagebar72 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 72%, #0aad0a 72%) 1; } 247 | .cardpercentagebar73 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 73%, #0aad0a 73%) 1; } 248 | .cardpercentagebar74 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 74%, #0aad0a 74%) 1; } 249 | .cardpercentagebar75 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 75%, #0aad0a 75%) 1; } 250 | .cardpercentagebar76 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 76%, #0aad0a 76%) 1; } 251 | .cardpercentagebar77 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 77%, #0aad0a 77%) 1; } 252 | .cardpercentagebar78 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 78%, #0aad0a 78%) 1; } 253 | .cardpercentagebar79 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 79%, #0aad0a 79%) 1; } 254 | .cardpercentagebar80 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 80%, #0aad0a 80%) 1; } 255 | .cardpercentagebar81 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 81%, #0aad0a 81%) 1; } 256 | .cardpercentagebar82 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 82%, #0aad0a 82%) 1; } 257 | .cardpercentagebar83 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 83%, #0aad0a 83%) 1; } 258 | .cardpercentagebar84 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 84%, #0aad0a 84%) 1; } 259 | .cardpercentagebar85 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 85%, #0aad0a 85%) 1; } 260 | .cardpercentagebar86 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 86%, #0aad0a 86%) 1; } 261 | .cardpercentagebar87 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 87%, #0aad0a 87%) 1; } 262 | .cardpercentagebar88 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 88%, #0aad0a 88%) 1; } 263 | .cardpercentagebar89 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 89%, #0aad0a 89%) 1; } 264 | .cardpercentagebar90 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 90%, #0aad0a 90%) 1; } 265 | .cardpercentagebar91 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 91%, #0aad0a 91%) 1; } 266 | .cardpercentagebar92 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 92%, #0aad0a 92%) 1; } 267 | .cardpercentagebar93 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 93%, #0aad0a 93%) 1; } 268 | .cardpercentagebar94 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 94%, #0aad0a 94%) 1; } 269 | .cardpercentagebar95 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 95%, #0aad0a 95%) 1; } 270 | .cardpercentagebar96 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 96%, #0aad0a 96%) 1; } 271 | .cardpercentagebar97 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 97%, #0aad0a 97%) 1; } 272 | .cardpercentagebar98 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 98%, #0aad0a 98%) 1; } 273 | .cardpercentagebar99 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 99%, #0aad0a 99%) 1; } 274 | .cardpercentagebar100 { border-image: linear-gradient(to bottom, #c10909 0%, #c10909 100%, #0aad0a 100%) 1; } 275 | 276 | .covered0 { width: 0px; } 277 | .covered1 { width: 1px; } 278 | .covered2 { width: 2px; } 279 | .covered3 { width: 3px; } 280 | .covered4 { width: 4px; } 281 | .covered5 { width: 5px; } 282 | .covered6 { width: 6px; } 283 | .covered7 { width: 7px; } 284 | .covered8 { width: 8px; } 285 | .covered9 { width: 9px; } 286 | .covered10 { width: 10px; } 287 | .covered11 { width: 11px; } 288 | .covered12 { width: 12px; } 289 | .covered13 { width: 13px; } 290 | .covered14 { width: 14px; } 291 | .covered15 { width: 15px; } 292 | .covered16 { width: 16px; } 293 | .covered17 { width: 17px; } 294 | .covered18 { width: 18px; } 295 | .covered19 { width: 19px; } 296 | .covered20 { width: 20px; } 297 | .covered21 { width: 21px; } 298 | .covered22 { width: 22px; } 299 | .covered23 { width: 23px; } 300 | .covered24 { width: 24px; } 301 | .covered25 { width: 25px; } 302 | .covered26 { width: 26px; } 303 | .covered27 { width: 27px; } 304 | .covered28 { width: 28px; } 305 | .covered29 { width: 29px; } 306 | .covered30 { width: 30px; } 307 | .covered31 { width: 31px; } 308 | .covered32 { width: 32px; } 309 | .covered33 { width: 33px; } 310 | .covered34 { width: 34px; } 311 | .covered35 { width: 35px; } 312 | .covered36 { width: 36px; } 313 | .covered37 { width: 37px; } 314 | .covered38 { width: 38px; } 315 | .covered39 { width: 39px; } 316 | .covered40 { width: 40px; } 317 | .covered41 { width: 41px; } 318 | .covered42 { width: 42px; } 319 | .covered43 { width: 43px; } 320 | .covered44 { width: 44px; } 321 | .covered45 { width: 45px; } 322 | .covered46 { width: 46px; } 323 | .covered47 { width: 47px; } 324 | .covered48 { width: 48px; } 325 | .covered49 { width: 49px; } 326 | .covered50 { width: 50px; } 327 | .covered51 { width: 51px; } 328 | .covered52 { width: 52px; } 329 | .covered53 { width: 53px; } 330 | .covered54 { width: 54px; } 331 | .covered55 { width: 55px; } 332 | .covered56 { width: 56px; } 333 | .covered57 { width: 57px; } 334 | .covered58 { width: 58px; } 335 | .covered59 { width: 59px; } 336 | .covered60 { width: 60px; } 337 | .covered61 { width: 61px; } 338 | .covered62 { width: 62px; } 339 | .covered63 { width: 63px; } 340 | .covered64 { width: 64px; } 341 | .covered65 { width: 65px; } 342 | .covered66 { width: 66px; } 343 | .covered67 { width: 67px; } 344 | .covered68 { width: 68px; } 345 | .covered69 { width: 69px; } 346 | .covered70 { width: 70px; } 347 | .covered71 { width: 71px; } 348 | .covered72 { width: 72px; } 349 | .covered73 { width: 73px; } 350 | .covered74 { width: 74px; } 351 | .covered75 { width: 75px; } 352 | .covered76 { width: 76px; } 353 | .covered77 { width: 77px; } 354 | .covered78 { width: 78px; } 355 | .covered79 { width: 79px; } 356 | .covered80 { width: 80px; } 357 | .covered81 { width: 81px; } 358 | .covered82 { width: 82px; } 359 | .covered83 { width: 83px; } 360 | .covered84 { width: 84px; } 361 | .covered85 { width: 85px; } 362 | .covered86 { width: 86px; } 363 | .covered87 { width: 87px; } 364 | .covered88 { width: 88px; } 365 | .covered89 { width: 89px; } 366 | .covered90 { width: 90px; } 367 | .covered91 { width: 91px; } 368 | .covered92 { width: 92px; } 369 | .covered93 { width: 93px; } 370 | .covered94 { width: 94px; } 371 | .covered95 { width: 95px; } 372 | .covered96 { width: 96px; } 373 | .covered97 { width: 97px; } 374 | .covered98 { width: 98px; } 375 | .covered99 { width: 99px; } 376 | .covered100 { width: 100px; } 377 | 378 | @media print { 379 | html, body { background-color: #fff; } 380 | .container { max-width: 100%; width: 100%; padding: 0; } 381 | .overview colgroup col:first-child { width: 300px; } 382 | } 383 | 384 | .icon-up-dir_active { 385 | background-image: url(icon_up-dir.svg), url(); 386 | background-repeat: no-repeat; 387 | background-size: contain; 388 | padding-left: 15px; 389 | height: 0.9em; 390 | display: inline-block; 391 | position: relative; 392 | top: 3px; 393 | } 394 | .icon-down-dir_active { 395 | background-image: url(icon_up-dir_active.svg), url(); 396 | background-repeat: no-repeat; 397 | background-size: contain; 398 | padding-left: 15px; 399 | height: 0.9em; 400 | display: inline-block; 401 | position: relative; 402 | top: 3px; 403 | } 404 | .icon-down-dir { 405 | background-image: url(icon_down-dir_active.svg), url(); 406 | background-repeat: no-repeat; 407 | background-size: contain; 408 | padding-left: 15px; 409 | height: 0.9em; 410 | display: inline-block; 411 | position: relative; 412 | top: 3px; 413 | } 414 | .icon-info-circled { 415 | background-image: url(icon_info-circled.svg), url(); 416 | background-repeat: no-repeat; 417 | background-size: contain; 418 | padding-left: 15px; 419 | height: 0.9em; 420 | display: inline-block; 421 | } 422 | .icon-plus { 423 | background-image: url(icon_plus.svg), url(); 424 | background-repeat: no-repeat; 425 | background-size: contain; 426 | padding-left: 15px; 427 | height: 0.9em; 428 | display: inline-block; 429 | position: relative; 430 | top: 3px; 431 | } 432 | .icon-minus { 433 | background-image: url(icon_minus.svg), url(); 434 | background-repeat: no-repeat; 435 | background-size: contain; 436 | padding-left: 15px; 437 | height: 0.9em; 438 | display: inline-block; 439 | position: relative; 440 | top: 3px; 441 | } 442 | .icon-wrench { 443 | background-image: url(icon_wrench.svg), url(); 444 | background-repeat: no-repeat; 445 | background-size: contain; 446 | padding-left: 20px; 447 | height: 0.9em; 448 | display: inline-block; 449 | } 450 | .icon-fork { 451 | background-image: url(icon_fork.svg), url(); 452 | background-repeat: no-repeat; 453 | background-size: contain; 454 | padding-left: 20px; 455 | height: 0.9em; 456 | display: inline-block; 457 | } 458 | .icon-cube { 459 | background-image: url(icon_cube.svg), url(); 460 | background-repeat: no-repeat; 461 | background-size: contain; 462 | padding-left: 20px; 463 | height: 0.9em; 464 | display: inline-block; 465 | } 466 | .icon-search-plus { 467 | background-image: url(icon_search-plus.svg), url(); 468 | background-repeat: no-repeat; 469 | background-size: contain; 470 | padding-left: 20px; 471 | height: 0.9em; 472 | display: inline-block; 473 | } 474 | .icon-search-minus { 475 | background-image: url(icon_search-minus.svg), url(); 476 | background-repeat: no-repeat; 477 | background-size: contain; 478 | padding-left: 20px; 479 | height: 0.9em; 480 | display: inline-block; 481 | } 482 | .icon-star { 483 | background-image: url(icon_star.svg), url(); 484 | background-repeat: no-repeat; 485 | background-size: contain; 486 | padding-left: 20px; 487 | height: 0.9em; 488 | display: inline-block; 489 | } 490 | .icon-sponsor { 491 | background-image: url(icon_sponsor.svg), url(); 492 | background-repeat: no-repeat; 493 | background-size: contain; 494 | padding-left: 20px; 495 | height: 0.9em; 496 | display: inline-block; 497 | } 498 | 499 | 500 | 501 | @media (prefers-color-scheme: dark) { 502 | @media screen { 503 | html { 504 | background-color: #333; 505 | color: #fff; 506 | } 507 | 508 | body { 509 | color: #fff; 510 | } 511 | 512 | h1 { 513 | background-color: #555453; 514 | color: #fff; 515 | } 516 | 517 | .container { 518 | background-color: #333; 519 | box-shadow: 0 0 60px #0c0c0c; 520 | } 521 | 522 | .containerrightfixed { 523 | background-color: #3D3C3C; 524 | border-left: 1px solid #515050; 525 | } 526 | 527 | .containerrightfixed h1 { 528 | background-color: #484747; 529 | } 530 | 531 | .card-group .card { 532 | background-color: #333; 533 | background: radial-gradient(circle, #444 0%, #333 100%); 534 | border: 1px solid #545454; 535 | color: #fff; 536 | } 537 | 538 | .card-group .card table tr { 539 | border-bottom: 1px solid #545454; 540 | } 541 | 542 | .card-group .card table tr:hover { 543 | background-color: #2E2D2C; 544 | } 545 | 546 | .overview tr:hover { 547 | background-color: #2E2D2C; 548 | } 549 | 550 | .overview th { 551 | background-color: #444; 552 | border: 1px solid #3B3A39; 553 | } 554 | 555 | .overview tr.namespace th { 556 | background-color: #444; 557 | } 558 | 559 | .overview thead th { 560 | background-color: #444; 561 | } 562 | 563 | .overview th a { 564 | color: #fff; 565 | color: rgba(255, 255, 255, 0.95); 566 | } 567 | 568 | .overview th a:hover { 569 | color: #0078d4; 570 | } 571 | 572 | .overview td { 573 | border: 1px solid #3B3A39; 574 | } 575 | 576 | .overview .coverage td { 577 | border: none; 578 | } 579 | 580 | .overview tr.header th { 581 | background-color: #444; 582 | } 583 | 584 | .overview tr.header th:nth-child(2n+1) { 585 | background-color: #3a3a3a; 586 | } 587 | 588 | .overview tr.header th:first-child { 589 | border-left: 1px solid #333; 590 | border-top: 1px solid #333; 591 | background-color: #333; 592 | } 593 | 594 | .stripped tr:nth-child(2n+1) { 595 | background-color: #3c3c3c; 596 | } 597 | 598 | input, select { 599 | background-color: #333; 600 | color: #fff; 601 | border: 1px solid #A19F9D; 602 | } 603 | 604 | a { 605 | color: #fff; 606 | color: rgba(255, 255, 255, 0.95); 607 | } 608 | 609 | a:hover { 610 | color: #0078d4; 611 | } 612 | 613 | h1 a.back { 614 | background-color: #4a4846; 615 | } 616 | 617 | h1 a.button { 618 | color: #fff; 619 | background-color: #565656; 620 | border-color: #c1c1c1; 621 | } 622 | 623 | h1 a.button:hover { 624 | background-color: #8d8d8d; 625 | } 626 | 627 | .gray { 628 | background-color: #484747; 629 | } 630 | 631 | .lightgray { 632 | color: #ebebeb; 633 | } 634 | 635 | .lightgraybg { 636 | background-color: #474747; 637 | } 638 | 639 | .lightgreen { 640 | background-color: #406540; 641 | } 642 | 643 | .lightorange { 644 | background-color: #ab7f36; 645 | } 646 | 647 | .lightred { 648 | background-color: #954848; 649 | } 650 | 651 | .ct-label { 652 | color: #fff !important; 653 | } 654 | 655 | .ct-grid { 656 | stroke: #fff !important; 657 | } 658 | 659 | .ct-chart .ct-series.ct-series-a .ct-line, .ct-chart .ct-series.ct-series-a .ct-point { 660 | stroke: #0078D4 !important; 661 | } 662 | 663 | .ct-chart .ct-series.ct-series-b .ct-line, .ct-chart .ct-series.ct-series-b .ct-point { 664 | stroke: #6dc428 !important; 665 | } 666 | 667 | .ct-chart .ct-series.ct-series-c .ct-line, .ct-chart .ct-series.ct-series-c .ct-point { 668 | stroke: #e58f1d !important; 669 | } 670 | 671 | .linecoverage { 672 | background-color: #0078D4; 673 | } 674 | 675 | .branchcoverage { 676 | background-color: #6dc428; 677 | } 678 | .codeelementcoverage { 679 | background-color: #e58f1d; 680 | } 681 | 682 | .tinylinecoveragechart, .tinybranchcoveragechart, .tinymethodcoveragechart { 683 | background-color: #333; 684 | } 685 | 686 | .tinybranchcoveragechart .ct-series.ct-series-a .ct-line { 687 | stroke: #6dc428 !important; 688 | } 689 | 690 | .tinymethodcoveragechart .ct-series.ct-series-a .ct-line { 691 | stroke: #e58f1d !important; 692 | } 693 | 694 | .icon-down-dir { 695 | background-image: url(icon_down-dir_active_dark.svg), url(); 696 | } 697 | 698 | .icon-info-circled { 699 | background-image: url(icon_info-circled_dark.svg), url(); 700 | } 701 | 702 | .icon-plus { 703 | background-image: url(icon_plus_dark.svg), url(); 704 | } 705 | 706 | .icon-minus { 707 | background-image: url(icon_minus_dark.svg), url(); 708 | } 709 | 710 | .icon-wrench { 711 | background-image: url(icon_wrench_dark.svg), url(); 712 | } 713 | 714 | .icon-fork { 715 | background-image: url(icon_fork_dark.svg), url(); 716 | } 717 | 718 | .icon-cube { 719 | background-image: url(icon_cube_dark.svg), url(); 720 | } 721 | 722 | .icon-search-plus { 723 | background-image: url(icon_search-plus_dark.svg), url(); 724 | } 725 | 726 | .icon-search-minus { 727 | background-image: url(icon_search-minus_dark.svg), url(); 728 | } 729 | 730 | .icon-star { 731 | background-image: url(icon_star_dark.svg), url(); 732 | } 733 | } 734 | } 735 | 736 | .ct-double-octave:after,.ct-golden-section:after,.ct-major-eleventh:after,.ct-major-second:after,.ct-major-seventh:after,.ct-major-sixth:after,.ct-major-tenth:after,.ct-major-third:after,.ct-major-twelfth:after,.ct-minor-second:after,.ct-minor-seventh:after,.ct-minor-sixth:after,.ct-minor-third:after,.ct-octave:after,.ct-perfect-fifth:after,.ct-perfect-fourth:after,.ct-square:after{content:"";clear:both}.ct-label{fill:rgba(0,0,0,.4);color:rgba(0,0,0,.4);font-size:.75rem;line-height:1}.ct-chart-bar .ct-label,.ct-chart-line .ct-label{display:block;display:-webkit-box;display:-moz-box;display:-ms-flexbox;display:-webkit-flex;display:flex}.ct-chart-donut .ct-label,.ct-chart-pie .ct-label{dominant-baseline:central}.ct-label.ct-horizontal.ct-start{-webkit-box-align:flex-end;-webkit-align-items:flex-end;-ms-flex-align:flex-end;align-items:flex-end;-webkit-box-pack:flex-start;-webkit-justify-content:flex-start;-ms-flex-pack:flex-start;justify-content:flex-start;text-align:left;text-anchor:start}.ct-label.ct-horizontal.ct-end{-webkit-box-align:flex-start;-webkit-align-items:flex-start;-ms-flex-align:flex-start;align-items:flex-start;-webkit-box-pack:flex-start;-webkit-justify-content:flex-start;-ms-flex-pack:flex-start;justify-content:flex-start;text-align:left;text-anchor:start}.ct-label.ct-vertical.ct-start{-webkit-box-align:flex-end;-webkit-align-items:flex-end;-ms-flex-align:flex-end;align-items:flex-end;-webkit-box-pack:flex-end;-webkit-justify-content:flex-end;-ms-flex-pack:flex-end;justify-content:flex-end;text-align:right;text-anchor:end}.ct-label.ct-vertical.ct-end{-webkit-box-align:flex-end;-webkit-align-items:flex-end;-ms-flex-align:flex-end;align-items:flex-end;-webkit-box-pack:flex-start;-webkit-justify-content:flex-start;-ms-flex-pack:flex-start;justify-content:flex-start;text-align:left;text-anchor:start}.ct-chart-bar .ct-label.ct-horizontal.ct-start{-webkit-box-align:flex-end;-webkit-align-items:flex-end;-ms-flex-align:flex-end;align-items:flex-end;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;text-align:center;text-anchor:start}.ct-chart-bar .ct-label.ct-horizontal.ct-end{-webkit-box-align:flex-start;-webkit-align-items:flex-start;-ms-flex-align:flex-start;align-items:flex-start;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;text-align:center;text-anchor:start}.ct-chart-bar.ct-horizontal-bars .ct-label.ct-horizontal.ct-start{-webkit-box-align:flex-end;-webkit-align-items:flex-end;-ms-flex-align:flex-end;align-items:flex-end;-webkit-box-pack:flex-start;-webkit-justify-content:flex-start;-ms-flex-pack:flex-start;justify-content:flex-start;text-align:left;text-anchor:start}.ct-chart-bar.ct-horizontal-bars .ct-label.ct-horizontal.ct-end{-webkit-box-align:flex-start;-webkit-align-items:flex-start;-ms-flex-align:flex-start;align-items:flex-start;-webkit-box-pack:flex-start;-webkit-justify-content:flex-start;-ms-flex-pack:flex-start;justify-content:flex-start;text-align:left;text-anchor:start}.ct-chart-bar.ct-horizontal-bars .ct-label.ct-vertical.ct-start{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:flex-end;-webkit-justify-content:flex-end;-ms-flex-pack:flex-end;justify-content:flex-end;text-align:right;text-anchor:end}.ct-chart-bar.ct-horizontal-bars .ct-label.ct-vertical.ct-end{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:flex-start;-webkit-justify-content:flex-start;-ms-flex-pack:flex-start;justify-content:flex-start;text-align:left;text-anchor:end}.ct-grid{stroke:rgba(0,0,0,.2);stroke-width:1px;stroke-dasharray:2px}.ct-grid-background{fill:none}.ct-point{stroke-width:10px;stroke-linecap:round}.ct-line{fill:none;stroke-width:4px}.ct-area{stroke:none;fill-opacity:.1}.ct-bar{fill:none;stroke-width:10px}.ct-slice-donut{fill:none;stroke-width:60px}.ct-series-a .ct-bar,.ct-series-a .ct-line,.ct-series-a .ct-point,.ct-series-a .ct-slice-donut{stroke:#d70206}.ct-series-a .ct-area,.ct-series-a .ct-slice-donut-solid,.ct-series-a .ct-slice-pie{fill:#d70206}.ct-series-b .ct-bar,.ct-series-b .ct-line,.ct-series-b .ct-point,.ct-series-b .ct-slice-donut{stroke:#f05b4f}.ct-series-b .ct-area,.ct-series-b .ct-slice-donut-solid,.ct-series-b .ct-slice-pie{fill:#f05b4f}.ct-series-c .ct-bar,.ct-series-c .ct-line,.ct-series-c .ct-point,.ct-series-c .ct-slice-donut{stroke:#f4c63d}.ct-series-c .ct-area,.ct-series-c .ct-slice-donut-solid,.ct-series-c .ct-slice-pie{fill:#f4c63d}.ct-series-d .ct-bar,.ct-series-d .ct-line,.ct-series-d .ct-point,.ct-series-d .ct-slice-donut{stroke:#d17905}.ct-series-d .ct-area,.ct-series-d .ct-slice-donut-solid,.ct-series-d .ct-slice-pie{fill:#d17905}.ct-series-e .ct-bar,.ct-series-e .ct-line,.ct-series-e .ct-point,.ct-series-e .ct-slice-donut{stroke:#453d3f}.ct-series-e .ct-area,.ct-series-e .ct-slice-donut-solid,.ct-series-e .ct-slice-pie{fill:#453d3f}.ct-series-f .ct-bar,.ct-series-f .ct-line,.ct-series-f .ct-point,.ct-series-f .ct-slice-donut{stroke:#59922b}.ct-series-f .ct-area,.ct-series-f .ct-slice-donut-solid,.ct-series-f .ct-slice-pie{fill:#59922b}.ct-series-g .ct-bar,.ct-series-g .ct-line,.ct-series-g .ct-point,.ct-series-g .ct-slice-donut{stroke:#0544d3}.ct-series-g .ct-area,.ct-series-g .ct-slice-donut-solid,.ct-series-g .ct-slice-pie{fill:#0544d3}.ct-series-h .ct-bar,.ct-series-h .ct-line,.ct-series-h .ct-point,.ct-series-h .ct-slice-donut{stroke:#6b0392}.ct-series-h .ct-area,.ct-series-h .ct-slice-donut-solid,.ct-series-h .ct-slice-pie{fill:#6b0392}.ct-series-i .ct-bar,.ct-series-i .ct-line,.ct-series-i .ct-point,.ct-series-i .ct-slice-donut{stroke:#f05b4f}.ct-series-i .ct-area,.ct-series-i .ct-slice-donut-solid,.ct-series-i .ct-slice-pie{fill:#f05b4f}.ct-series-j .ct-bar,.ct-series-j .ct-line,.ct-series-j .ct-point,.ct-series-j .ct-slice-donut{stroke:#dda458}.ct-series-j .ct-area,.ct-series-j .ct-slice-donut-solid,.ct-series-j .ct-slice-pie{fill:#dda458}.ct-series-k .ct-bar,.ct-series-k .ct-line,.ct-series-k .ct-point,.ct-series-k .ct-slice-donut{stroke:#eacf7d}.ct-series-k .ct-area,.ct-series-k .ct-slice-donut-solid,.ct-series-k .ct-slice-pie{fill:#eacf7d}.ct-series-l .ct-bar,.ct-series-l .ct-line,.ct-series-l .ct-point,.ct-series-l .ct-slice-donut{stroke:#86797d}.ct-series-l .ct-area,.ct-series-l .ct-slice-donut-solid,.ct-series-l .ct-slice-pie{fill:#86797d}.ct-series-m .ct-bar,.ct-series-m .ct-line,.ct-series-m .ct-point,.ct-series-m .ct-slice-donut{stroke:#b2c326}.ct-series-m .ct-area,.ct-series-m .ct-slice-donut-solid,.ct-series-m .ct-slice-pie{fill:#b2c326}.ct-series-n .ct-bar,.ct-series-n .ct-line,.ct-series-n .ct-point,.ct-series-n .ct-slice-donut{stroke:#6188e2}.ct-series-n .ct-area,.ct-series-n .ct-slice-donut-solid,.ct-series-n .ct-slice-pie{fill:#6188e2}.ct-series-o .ct-bar,.ct-series-o .ct-line,.ct-series-o .ct-point,.ct-series-o .ct-slice-donut{stroke:#a748ca}.ct-series-o .ct-area,.ct-series-o .ct-slice-donut-solid,.ct-series-o .ct-slice-pie{fill:#a748ca}.ct-square{display:block;position:relative;width:100%}.ct-square:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:100%}.ct-square:after{display:table}.ct-square>svg{display:block;position:absolute;top:0;left:0}.ct-minor-second{display:block;position:relative;width:100%}.ct-minor-second:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:93.75%}.ct-minor-second:after{display:table}.ct-minor-second>svg{display:block;position:absolute;top:0;left:0}.ct-major-second{display:block;position:relative;width:100%}.ct-major-second:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:88.8888888889%}.ct-major-second:after{display:table}.ct-major-second>svg{display:block;position:absolute;top:0;left:0}.ct-minor-third{display:block;position:relative;width:100%}.ct-minor-third:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:83.3333333333%}.ct-minor-third:after{display:table}.ct-minor-third>svg{display:block;position:absolute;top:0;left:0}.ct-major-third{display:block;position:relative;width:100%}.ct-major-third:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:80%}.ct-major-third:after{display:table}.ct-major-third>svg{display:block;position:absolute;top:0;left:0}.ct-perfect-fourth{display:block;position:relative;width:100%}.ct-perfect-fourth:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:75%}.ct-perfect-fourth:after{display:table}.ct-perfect-fourth>svg{display:block;position:absolute;top:0;left:0}.ct-perfect-fifth{display:block;position:relative;width:100%}.ct-perfect-fifth:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:66.6666666667%}.ct-perfect-fifth:after{display:table}.ct-perfect-fifth>svg{display:block;position:absolute;top:0;left:0}.ct-minor-sixth{display:block;position:relative;width:100%}.ct-minor-sixth:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:62.5%}.ct-minor-sixth:after{display:table}.ct-minor-sixth>svg{display:block;position:absolute;top:0;left:0}.ct-golden-section{display:block;position:relative;width:100%}.ct-golden-section:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:61.804697157%}.ct-golden-section:after{display:table}.ct-golden-section>svg{display:block;position:absolute;top:0;left:0}.ct-major-sixth{display:block;position:relative;width:100%}.ct-major-sixth:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:60%}.ct-major-sixth:after{display:table}.ct-major-sixth>svg{display:block;position:absolute;top:0;left:0}.ct-minor-seventh{display:block;position:relative;width:100%}.ct-minor-seventh:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:56.25%}.ct-minor-seventh:after{display:table}.ct-minor-seventh>svg{display:block;position:absolute;top:0;left:0}.ct-major-seventh{display:block;position:relative;width:100%}.ct-major-seventh:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:53.3333333333%}.ct-major-seventh:after{display:table}.ct-major-seventh>svg{display:block;position:absolute;top:0;left:0}.ct-octave{display:block;position:relative;width:100%}.ct-octave:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:50%}.ct-octave:after{display:table}.ct-octave>svg{display:block;position:absolute;top:0;left:0}.ct-major-tenth{display:block;position:relative;width:100%}.ct-major-tenth:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:40%}.ct-major-tenth:after{display:table}.ct-major-tenth>svg{display:block;position:absolute;top:0;left:0}.ct-major-eleventh{display:block;position:relative;width:100%}.ct-major-eleventh:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:37.5%}.ct-major-eleventh:after{display:table}.ct-major-eleventh>svg{display:block;position:absolute;top:0;left:0}.ct-major-twelfth{display:block;position:relative;width:100%}.ct-major-twelfth:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:33.3333333333%}.ct-major-twelfth:after{display:table}.ct-major-twelfth>svg{display:block;position:absolute;top:0;left:0}.ct-double-octave{display:block;position:relative;width:100%}.ct-double-octave:before{display:block;float:left;content:"";width:0;height:0;padding-bottom:25%}.ct-double-octave:after{display:table}.ct-double-octave>svg{display:block;position:absolute;top:0;left:0} --------------------------------------------------------------------------------