StorageBasedChangeTests.cs 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Collections.ObjectModel;
  4. using System.IO;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. using System.Windows.Media;
  9. using System.Windows.Media.Imaging;
  10. using PixiEditor.Models.DataHolders;
  11. using PixiEditor.Models.Layers;
  12. using PixiEditor.Models.Undo;
  13. using PixiEditorTests.ModelsTests.LayersTests;
  14. using Xunit;
  15. namespace PixiEditorTests.ModelsTests.UndoTests
  16. {
  17. public class StorageBasedChangeTests
  18. {
  19. private const string UndoStoreLocation = "undoStack";
  20. public StorageBasedChangeTests()
  21. {
  22. if (!Directory.Exists(UndoStoreLocation))
  23. {
  24. Directory.CreateDirectory(UndoStoreLocation);
  25. }
  26. }
  27. public Document GenerateTestDocument()
  28. {
  29. Document testDocument = new Document(10, 10);
  30. WriteableBitmap testBitmap = BitmapFactory.New(10, 10);
  31. WriteableBitmap testBitmap2 = BitmapFactory.New(5, 8);
  32. testBitmap.SetPixel(0, 0, Colors.Black);
  33. testBitmap2.SetPixel(4, 4, Colors.Beige);
  34. Random random = new Random();
  35. testDocument.Layers = new ObservableCollection<Layer>()
  36. {
  37. new Layer("Test layer" + random.Next(int.MinValue, int.MaxValue), testBitmap),
  38. new Layer("Test layer 2" + random.Next(int.MinValue, int.MaxValue), testBitmap2) { Offset = new System.Windows.Thickness(2, 3, 0, 0) }
  39. };
  40. return testDocument;
  41. }
  42. [Fact]
  43. public void TestThatConstructorGeneratesUndoLayersProperly()
  44. {
  45. Document testDocument = GenerateTestDocument();
  46. StorageBasedChange change = new StorageBasedChange(testDocument, testDocument.Layers, UndoStoreLocation);
  47. Assert.Equal(testDocument.Layers.Count, change.StoredLayers.Length);
  48. for (int i = 0; i < change.StoredLayers.Length; i++)
  49. {
  50. Layer testLayer = testDocument.Layers[i];
  51. UndoLayer layer = change.StoredLayers[i];
  52. Assert.Equal(testLayer.Name, layer.Name);
  53. Assert.Equal(testLayer.Width, layer.Width);
  54. Assert.Equal(testLayer.Height, layer.Height);
  55. Assert.Equal(testLayer.IsActive, layer.IsActive);
  56. Assert.Equal(testLayer.IsVisible, layer.IsVisible);
  57. Assert.Equal(testLayer.OffsetX, layer.OffsetX);
  58. Assert.Equal(testLayer.OffsetY, layer.OffsetY);
  59. Assert.Equal(testLayer.MaxWidth, layer.MaxWidth);
  60. Assert.Equal(testLayer.MaxHeight, layer.MaxHeight);
  61. Assert.Equal(testLayer.Opacity, layer.Opacity);
  62. }
  63. }
  64. [Fact]
  65. public void TestThatSaveLayersOnDeviceSavesLayers()
  66. {
  67. Document document = GenerateTestDocument();
  68. StorageBasedChange change = new StorageBasedChange(document, document.Layers, UndoStoreLocation);
  69. change.SaveLayersOnDevice();
  70. foreach (var layer in change.StoredLayers)
  71. {
  72. Assert.True(File.Exists(layer.StoredPngLayerName));
  73. File.Delete(layer.StoredPngLayerName);
  74. }
  75. }
  76. [Fact]
  77. public void TestThatLoadLayersFromDeviceLoadsLayers()
  78. {
  79. Document document = GenerateTestDocument();
  80. StorageBasedChange change = new StorageBasedChange(document, document.Layers, UndoStoreLocation);
  81. change.SaveLayersOnDevice();
  82. Layer[] layers = change.LoadLayersFromDevice();
  83. Assert.Equal(document.Layers.Count, layers.Length);
  84. for (int i = 0; i < document.Layers.Count; i++)
  85. {
  86. Layer expected = document.Layers[i];
  87. Layer actual = layers[i];
  88. LayersTestHelper.LayersAreEqual(expected, actual);
  89. }
  90. }
  91. }
  92. }