Exemple #1
0
 public UnitOfWork(
     CharactersContext charactersContext,
     IDomainEventsDispatcher domainEventsDispatcher)
 {
     _charactersContext      = charactersContext;
     _domainEventsDispatcher = domainEventsDispatcher;
 }
Exemple #2
0
 private static void MigrateDatabase(CharactersContext context)
 {
     if (context == null)
     {
         throw new ArgumentNullException(nameof(context), "Database dependency could not be resolved");
     }
     context.Database.Migrate();
 }
Exemple #3
0
        public void QueryingCollectionHandler_ReturnsAllCharactersFromFacade()
        {
            var facade =
                new CharactersContext(new DbContextOptionsBuilder().UseSqlServer(_connectionString).Options);
            var characters = facade.Query();

            Assert.NotNull(characters);
            Assert.NotEmpty(characters);
            var handler = new CharactersQueryHandler(facade);
            var result  = handler.Handle(new CharactersQuery(), new CancellationToken()).GetAwaiter().GetResult();

            Assert.NotNull(result);
            Assert.NotNull(result.Data);
            Assert.True(result.IsSuccessful);
            Assert.Equal(characters.Count, result.Data.Count);
        }
Exemple #4
0
        public void SubsequentQueryReturnsTheSameValues()
        {
            var facade =
                new CharactersContext(new DbContextOptionsBuilder().UseSqlServer(_connectionString).Options);
            var characterIds = facade.Query().Select(x => x.Id).ToList();

            Assert.NotNull(characterIds);
            Assert.NotEmpty(characterIds);
            var handler = new CharacterQueryHandler(facade);

            foreach (var id in characterIds)
            {
                var result1 = handler.Handle(new CharacterQuery(id), new CancellationToken()).GetAwaiter().GetResult();
                var result2 = handler.Handle(new CharacterQuery(id), new CancellationToken()).GetAwaiter().GetResult();
                Assert.NotSame(result1, result2);
                Assert.True(result1.IsSuccessful);
                Assert.True(result2.IsSuccessful);

                Assert.Equal(result1.Data.Id, result2.Data.Id);
                Assert.Equal(result1.Data.Name, result2.Data.Name);
                Assert.Equal(result1.Data.Episodes.Count, result2.Data.Episodes.Count);
                Assert.Equal(result1.Data.Friends.Count, result2.Data.Friends.Count);

                var res1episodes = result1.Data.Episodes.OrderBy(x => x.Value).ToList();
                var res2episodes = result2.Data.Episodes.OrderBy(x => x.Value).ToList();
                for (int i = 0; i < res1episodes.Count; i++)
                {
                    Assert.Equal(res1episodes[i], res2episodes[i]);
                }

                var res1friends = result1.Data.Friends.OrderBy(x => x.Id).ToList();
                var res2friends = result2.Data.Friends.OrderBy(x => x.Id).ToList();
                for (int i = 0; i < res1friends.Count; i++)
                {
                    Assert.Equal(res1friends[i].Id, res2friends[i].Id);
                    Assert.Equal(res1friends[i].Name, res2friends[i].Name);
                }
            }
        }
Exemple #5
0
        public void QueryingSingleHandler_ReturnsSpecificCharacterFromFacade()
        {
            var facade =
                new CharactersContext(new DbContextOptionsBuilder().UseSqlServer(_connectionString).Options);
            var characterIds = facade.Query().Select(x => x.Id).ToList();

            Assert.NotNull(characterIds);
            Assert.NotEmpty(characterIds);
            var handler = new CharacterQueryHandler(facade);
            var results = new List <CharacterQueryResponse>();

            foreach (var id in characterIds)
            {
                results.Add(handler.Handle(new CharacterQuery(id), new CancellationToken()).GetAwaiter().GetResult());
            }

            Assert.NotNull(results);
            Assert.NotEmpty(results);
            foreach (var result in results)
            {
                Assert.True(result.IsSuccessful);
                Assert.Contains(result.Id, characterIds);
            }
        }
 public PlannerController(CharactersContext context, DndDatabase dndDb)
 {
     _db    = context;
     _dndDb = dndDb;
 }
Exemple #7
0
 public CharactersController(CharactersContext context)
 {
     _context = context;
 }
 public CharacterLocationRepository(CharactersContext context)
 {
     _context = context ?? throw new ArgumentNullException(nameof(context));
 }