Last active
June 9, 2019 14:14
-
-
Save NikiforovAll/7a6ff3003b8dbd66a340cebbb2857484 to your computer and use it in GitHub Desktop.
MementoImpl
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| using System; | |
| using System.Collections.Generic; | |
| namespace Memento { | |
| public class Caretaker : Stack<Memento> { } | |
| } | |
| namespace Memento { | |
| public class Memento { | |
| public (string Id, int balance) State { get; private set; } | |
| //probably better to use read-only state | |
| internal Memento () {} | |
| public Memento SetState ((string Id, int balance) state) { | |
| State = state; | |
| return this; | |
| } | |
| } | |
| } | |
| namespace Memento { | |
| public class Originator { | |
| public (string Id, int balance) State { get; set; } | |
| public Originator (string Id) { | |
| State = (Id, 0); | |
| } | |
| public Originator () { | |
| } | |
| public Memento CreateMemento () { | |
| return new Memento () | |
| .SetState (State); | |
| } | |
| public void SetMemento (Memento memento) { | |
| this.State = memento.State; | |
| } | |
| } | |
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| using System; | |
| using System.Collections.Generic; | |
| using Memento; | |
| public class Program { | |
| public static void Main () { | |
| (string, int) [] states = { | |
| ("1", 0), | |
| ("2", 10), | |
| ("3", 20), | |
| }; | |
| Originator originator = new Originator (); | |
| var caretaker = new Caretaker (); | |
| originator.State = states[0]; | |
| caretaker.Push (originator.CreateMemento ()); | |
| originator.State = states[1]; | |
| caretaker.Push (originator.CreateMemento ()); | |
| originator.State = states[2]; | |
| originator.SetMemento (caretaker.Pop ()); | |
| Assert.Equal (states[1], originator.State); | |
| originator.SetMemento (caretaker.Pop ()); | |
| Assert.Equal (states[0], originator.State); | |
| //Assert.Empty (caretaker); | |
| TestRunner.Print (); | |
| } | |
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| using System; | |
| using System.Collections.Generic; | |
| using System.Linq; | |
| using System.Runtime.CompilerServices; | |
| public static class Assert { | |
| public static void Equal<T> (T a, T b, [CallerMemberName] string callerName = "", [CallerLineNumber] int callerLine = 0) { | |
| if (!a.Equals (b)) { | |
| // throw new Exception ($"{a} doesn't equal to {b}"); | |
| TestRunner.AddResult ( | |
| new TestRunResult () { | |
| CallerName = callerName, | |
| CallerLine = callerLine.ToString (), | |
| Success = false, | |
| Assertion = "Equal<T>", | |
| ErrorMessage = $"{a} doesn't equal to {b}" | |
| }); | |
| } else { | |
| TestRunner.AddResult ( | |
| new TestRunResult () { | |
| CallerName = callerName, | |
| CallerLine = callerLine.ToString (), | |
| Success = true, | |
| Assertion = "Single<T>" | |
| }); | |
| } | |
| } | |
| public static void Equal<T> (IEnumerable<T> a, | |
| IEnumerable<T> b, [CallerMemberName] string callerName = "", [CallerLineNumber] int callerLine = 0) { | |
| if (a.Count () != b.Count ()) { | |
| TestRunner.AddResult ( | |
| new TestRunResult () { | |
| CallerName = callerName, | |
| CallerLine = callerLine.ToString (), | |
| Success = false, | |
| Assertion = "Equal<T>", | |
| ErrorMessage = $"a.{a.Count()} != b.{b.Count()}" | |
| }); | |
| } else if (!a.SequenceEqual (b)) { | |
| TestRunner.AddResult ( | |
| new TestRunResult () { | |
| CallerName = callerName, | |
| CallerLine = callerLine.ToString (), | |
| Success = false, | |
| Assertion = "SequenceEqual<T>", | |
| ErrorMessage = $"Different sequences" | |
| }); | |
| } else { | |
| TestRunner.AddResult ( | |
| new TestRunResult () { | |
| CallerName = callerName, | |
| CallerLine = callerLine.ToString (), | |
| Success = true, | |
| Assertion = "Equal<T>" | |
| }); | |
| } | |
| } | |
| public static void Single<T> (IEnumerable<T> collection, [CallerMemberName] string callerName = "", [CallerLineNumber] int callerLine = 0) { | |
| if (collection.Count () != 1) { | |
| // throw new Exception ("Collection doesn't contain 1 element"); | |
| TestRunner.AddResult ( | |
| new TestRunResult () { | |
| CallerName = callerName, | |
| CallerLine = callerLine.ToString (), | |
| Success = false, | |
| Assertion = "Single<T>", | |
| ErrorMessage = "Collection doesn't contain 1 element" | |
| }); | |
| } | |
| TestRunner.AddResult ( | |
| new TestRunResult () { | |
| CallerName = callerName, | |
| CallerLine = callerLine.ToString (), | |
| Success = true, | |
| Assertion = "Single<T>" | |
| }); | |
| } | |
| public static void Contains<T> (T token1, T token2, [CallerMemberName] string callerName = "", [CallerLineNumber] int callerLine = 0) { | |
| if (typeof (T) == typeof (System.String)) { | |
| if (!((token2 as string)).Contains (token1 as string)) { | |
| // throw new Exception ($"{token2} doesn't contain {token1}"); | |
| TestRunner.AddResult ( | |
| new TestRunResult () { | |
| CallerName = callerName, | |
| CallerLine = callerLine.ToString (), | |
| Success = false, | |
| Assertion = "Contains<T>", | |
| ErrorMessage = $"{token2} doesn't contain {token1}" | |
| }); | |
| } else { | |
| TestRunner.AddResult ( | |
| new TestRunResult () { | |
| CallerName = callerName, | |
| CallerLine = callerLine.ToString (), | |
| Success = true, | |
| Assertion = "Contains<T>" | |
| }); | |
| } | |
| } else { | |
| throw new Exception ("It is not possible to use .Contains() method"); | |
| } | |
| } | |
| public static void All<T> (IEnumerable<T> collection, Func<T, bool> predicate, [CallerMemberName] string callerName = "", [CallerLineNumber] int callerLine = 0) { | |
| bool res = collection.All (predicate); | |
| var tr = new TestRunResult () { | |
| CallerName = callerName, | |
| CallerLine = callerLine.ToString (), | |
| Success = res, | |
| Assertion = "All<T>" | |
| }; | |
| TestRunner.AddResult (tr); | |
| if(!res) { | |
| tr.ErrorMessage = "Condition is not met for all members"; | |
| } | |
| } | |
| } | |
| public static class TestRunner { | |
| public static List<TestRunResult> Results { get; } = new List<TestRunResult> (); | |
| public static void AddResult (TestRunResult res) { | |
| Results.Add (res); | |
| } | |
| public static void Print () { | |
| System.Console.WriteLine ("TestRunner.Print"); | |
| System.Console.WriteLine ("============================================"); | |
| foreach (var log in Results) { | |
| System.Console.WriteLine (log); | |
| } | |
| System.Console.WriteLine ("============================================"); | |
| } | |
| } | |
| public class TestRunResult { | |
| public string CallerName { get; set; } | |
| public string CallerLine { get; set; } | |
| public string Assertion { get; set; } | |
| public bool Success { get; set; } | |
| public string ErrorMessage { get; set; } | |
| public override string ToString () { | |
| return $"Assertion: {Assertion, 15}; MethodName: {CallerName, 10}; Line: {CallerLine, 3}; " + (Success? $"Success: {Success}": $"ErrorMessage: {ErrorMessage}"); | |
| } | |
| } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment