|           Line data    Source code 
       1             : #region Copyright
       2             : // // -----------------------------------------------------------------------
       3             : // // <copyright company="Chinchilla Software Limited">
       4             : // //   Copyright Chinchilla Software Limited. All rights reserved.
       5             : // // </copyright>
       6             : // // -----------------------------------------------------------------------
       7             : #endregion
       8             : 
       9             : using System;
      10             : using System.Collections.Generic;
      11             : using System.Diagnostics;
      12             : using System.Linq;
      13             : using Chinchilla.Logging;
      14             : using Chinchilla.Logging.Configuration;
      15             : using Chinchilla.StateManagement.Threaded;
      16             : using Cqrs.Azure.BlobStorage.Events;
      17             : using Cqrs.Azure.ServiceBus.Tests.Unit;
      18             : using Cqrs.Configuration;
      19             : using Cqrs.Events;
      20             : using NUnit.Framework;
      21             : using TestClass = NUnit.Framework.TestFixtureAttribute;
      22             : using TestMethod = NUnit.Framework.TestAttribute;
      23             : using TestInitialize = NUnit.Framework.SetUpAttribute;
      24             : using TestCleanup = NUnit.Framework.TearDownAttribute;
      25             : using TestContext = System.Object;
      26             : 
      27             : namespace Cqrs.Azure.BlobStorage.Test.Integration
      28             : {
      29             :         /// <summary>
      30             :         /// A series of tests on the <see cref="BlobStorageEventStore{TAuthenticationToken}"/> class
      31             :         /// </summary>
      32             :         [TestClass]
      33             :         public class BlobStorageEventStoreTests
      34           1 :         {
      35             :                 /// <summary>
      36             :                 /// Tests the <see cref="IEventStore{TAuthenticationToken}.Save"/> method
      37             :                 /// Passing a valid test <see cref="IEvent{TAuthenticationToken}"/>
      38             :                 /// Expecting the test <see cref="IEvent{TAuthenticationToken}"/> is able to be read.
      39             :                 /// </summary>
      40             :                 [TestMethod]
      41           1 :                 public virtual void Save_ValidEvent_EventCanBeRetreived()
      42             :                 {
      43             :                         // Arrange
      44             :                         var correlationIdHelper = new CorrelationIdHelper(new ContextItemCollectionFactory());
      45             :                         correlationIdHelper.SetCorrelationId(Guid.NewGuid());
      46             :                         var logger = new ConsoleLogger(new LoggerSettingsConfigurationSection(), correlationIdHelper);
      47             :                         var eventStore = new BlobStorageEventStore<Guid>(new DefaultEventBuilder<Guid>(), new EventDeserialiser<Guid>(), logger, new BlobStorageEventStoreConnectionStringFactory(new ConfigurationManager(), logger));
      48             : 
      49             :                         var event1 = new TestEvent
      50             :                         {
      51             :                                 Rsn = Guid.NewGuid(),
      52             :                                 Id = Guid.NewGuid(),
      53             :                                 CorrelationId = correlationIdHelper.GetCorrelationId(),
      54             :                                 Frameworks = new List<string> { "Test 1" },
      55             :                                 TimeStamp = DateTimeOffset.UtcNow
      56             :                         };
      57             :                         var event2 = new TestEvent
      58             :                         {
      59             :                                 Rsn = Guid.NewGuid(),
      60             :                                 Id = Guid.NewGuid(),
      61             :                                 CorrelationId = correlationIdHelper.GetCorrelationId(),
      62             :                                 Frameworks = new List<string> { "Test 2" },
      63             :                                 TimeStamp = DateTimeOffset.UtcNow
      64             :                         };
      65             : 
      66             :                         // Act
      67             :                         eventStore.Save<TestEvent>(event1);
      68             :                         eventStore.Save<TestEvent>(event2);
      69             : 
      70             :                         // Assert
      71             :                         var timer = new Stopwatch();
      72             :                         IList<IEvent<Guid>> events = eventStore.Get<TestEvent>(event1.Id).ToList();
      73             :                         timer.Stop();
      74             :                         Console.WriteLine("Load one operation took {0}", timer.Elapsed);
      75             :                         Assert.AreEqual(1, events.Count);
      76             :                         Assert.AreEqual(event1.Id, events.Single().Id);
      77             :                         Assert.AreEqual(event1.Frameworks.Single(), events.Single().Frameworks.Single());
      78             : 
      79             :                         timer.Restart();
      80             :                         events = eventStore.Get<TestEvent>(event2.Id).ToList();
      81             :                         timer.Stop();
      82             :                         Console.WriteLine("Load one operation took {0}", timer.Elapsed);
      83             :                         Assert.AreEqual(1, events.Count);
      84             :                         Assert.AreEqual(event2.Id, events.Single().Id);
      85             :                         Assert.AreEqual(event2.Frameworks.Single(), events.Single().Frameworks.Single());
      86             : 
      87             :                         timer.Restart();
      88             :                         IList<EventData> correlatedEvents = eventStore.Get(event1.CorrelationId).ToList();
      89             :                         timer.Stop();
      90             :                         Console.WriteLine("Load several correlated operation took {0}", timer.Elapsed);
      91             :                         Assert.AreEqual(2, correlatedEvents.Count);
      92             :                 }
      93             :         }
      94             : }
 |