public void Save_ValidGraph_Text() { var expectedText = @"1 1 0 0 -1 0 1 1 0 1 0 -1 0 0 -1 0" + Environment.NewLine; var storage = new IncidenceMatrixFormatStorage(); var graphMock = new Mock <IGraph>(); var v1 = Mock.Of <IVertex>(v => v.Index == 1 && v.Name == "1" && v.Title == "1" && v.X == 1 && v.Y == 11 && v.Color == VertexColor.White); var v2 = Mock.Of <IVertex>(v => v.Index == 2 && v.Name == "vertex2" && v.Title == "v2" && v.X == 2 && v.Y == 22 && v.Color == VertexColor.White); var v3 = Mock.Of <IVertex>(v => v.Index == 3 && v.Name == "3" && v.Title == "v3" && v.X == 3 && v.Y == 33 && v.Color == VertexColor.Red); var v4 = Mock.Of <IVertex>(v => v.Index == 4 && v.Name == "4" && v.Title == "4" && v.X == 4 && v.Y == 44 && v.Color == VertexColor.Green); var e1 = Mock.Of <IEdge>(e => e.Source == v1 && e.Target == v2 && e.IsDirected == true); var e2 = Mock.Of <IEdge>(e => e.Source == v1 && e.Target == v3); var e3 = Mock.Of <IEdge>(e => e.Source == v2 && e.Target == v4 && e.IsDirected == true); var e4 = Mock.Of <IEdge>(e => e.Source == v2 && e.Target == v3 && e.IsDirected == true); graphMock.Setup(g => g.Vertices).Returns(new IVertex[] { v1, v2, v3, v4 }); graphMock.Setup(g => g.Edges).Returns(new IEdge[] { e1, e2, e3, e4 }); var sb = new StringBuilder(); using (var sw = new System.IO.StringWriter(sb)) { storage.Save(sw, graphMock.Object); } Assert.AreEqual(expectedText, sb.ToString()); }
public void Open_ValidText_Graph() { var text = @"1 1 0 0 -1 0 1 1 0 1 0 -1 0 0 -1 0"; var storage = new IncidenceMatrixFormatStorage(); var graphMock = new Mock <IGraph>(); graphMock.Setup(g => g.AddVertex(It.IsAny <int>())).Returns <int>(index => Mock.Of <IVertex>(v => v.Index == index)); using (var sr = new System.IO.StringReader(text)) { storage.Open(sr, graphMock.Object); } graphMock.Verify(g => g.AddVertex(1), Times.Exactly(2)); graphMock.Verify(g => g.AddVertex(2), Times.Exactly(3)); graphMock.Verify(g => g.AddVertex(3), Times.Exactly(2)); graphMock.Verify(g => g.AddVertex(4), Times.Exactly(1)); graphMock.Verify(g => g.AddEdge(It.Is <IVertex>(v => v.Index == 1), It.Is <IVertex>(v => v.Index == 2), true, true), Times.Once); graphMock.Verify(g => g.AddEdge(It.Is <IVertex>(v => v.Index == 1), It.Is <IVertex>(v => v.Index == 3), false, true), Times.Once); graphMock.Verify(g => g.AddEdge(It.Is <IVertex>(v => v.Index == 2), It.Is <IVertex>(v => v.Index == 4), true, true), Times.Once); graphMock.Verify(g => g.AddEdge(It.Is <IVertex>(v => v.Index == 2), It.Is <IVertex>(v => v.Index == 3), true, true), Times.Once); }