From 52ad4a5ccc6069e0e8b2f0fc4bdc1d78377c8542 Mon Sep 17 00:00:00 2001 From: Ralf Viola Date: Mon, 17 Jun 2024 10:44:33 -0400 Subject: [PATCH] Clean-up code for html conversion --- .../BusinessObjects/TestStepResult.cs | 56 ++----------------- .../{BusinessObjects/HTML.cs => Helpers.cs} | 4 +- 2 files changed, 6 insertions(+), 54 deletions(-) rename SQLiteConnector/{BusinessObjects/HTML.cs => Helpers.cs} (97%) diff --git a/SQLiteConnector/BusinessObjects/TestStepResult.cs b/SQLiteConnector/BusinessObjects/TestStepResult.cs index 3dc01ff..da3d819 100644 --- a/SQLiteConnector/BusinessObjects/TestStepResult.cs +++ b/SQLiteConnector/BusinessObjects/TestStepResult.cs @@ -27,7 +27,7 @@ public class TestStepResult public string TestCaseStepsXML { get; set; } public string TestCaseState { get; set; } public string TestCaseDescription { get; set; } - public string TestCaseDescriptionText { get { return HTML.HtmlDecode(TestCaseDescription); } } + public string TestCaseDescriptionText { get { return SQLiteConnector.Helpers.HtmlDecode(TestCaseDescription); } } public bool HasSharedSteps { get; set; } public string Comment { get; set; } @@ -266,9 +266,9 @@ public enum TypesOfStep { TestStep, SharedStepsRef, TestStepInSharedSteps }; public TypesOfStep TypeOfStep { get; set; } public int SharedStepsId { get; set; } public string Instructions { get; set; } - public string InstructionsText { get { return HtmlDecode(Instructions); } } + public string InstructionsText { get { return SQLiteConnector.Helpers.HtmlDecode(Instructions); } } public string ExpectedResult { get; set; } - public string ExpectedResultText { get { return HtmlDecode(ExpectedResult); } } + public string ExpectedResultText { get { return SQLiteConnector.Helpers.HtmlDecode(ExpectedResult); } } public string Outcome { get; set; } public string Comment { get; set; } public List Parameters { get; set; } @@ -297,55 +297,7 @@ public string GetStepIdentifier() } } - private static string HtmlDecode(string html) - { - if (html == null) - return string.Empty; - string attribute = null; System.Text.StringBuilder result = new System.Text.StringBuilder(); - for (int i = 0; i < html.Length; i++) - { - char c = html[i]; - switch (c) - { - case '<': attribute = ""; break; - case '>': - if (attribute == null) - result.Append('>'); - else - { - if (attribute.StartsWith("br", System.StringComparison.CurrentCultureIgnoreCase)) result.Append('\n'); - if (attribute.StartsWith("p ", System.StringComparison.CurrentCultureIgnoreCase) && result.Length > 0) result.Append('\n'); - } - attribute = null; break; - case '&': - if (attribute == null) - { - if (html.Length >= i + 4 && html.Substring(i, 4) == ">") - { result.Append('>'); i += 4 - 1; } - else if (html.Length >= i + 4 && html.Substring(i, 4) == "<") - { result.Append('<'); i += 4 - 1; } - else if (html.Length >= i + 6 && html.Substring(i, 6) == " ") - { result.Append(' '); i += 6 - 1; } - } - else - attribute += c; - break; - - default: - if (attribute == null) - { - result.Append(c); - } - else - { - attribute += c; - } - break; - } - } - - return result.ToString(); - } + public bool IsPassedOrFailed() { switch (Outcome) diff --git a/SQLiteConnector/BusinessObjects/HTML.cs b/SQLiteConnector/Helpers.cs similarity index 97% rename from SQLiteConnector/BusinessObjects/HTML.cs rename to SQLiteConnector/Helpers.cs index e1a06f1..4206705 100644 --- a/SQLiteConnector/BusinessObjects/HTML.cs +++ b/SQLiteConnector/Helpers.cs @@ -2,9 +2,9 @@ using System.Collections.Generic; using System.Text; -namespace SQLite.BusinessObjects +namespace SQLiteConnector { - internal static class HTML + internal static class Helpers { public static string HtmlDecode(string html) {