public async Task UpdateField_WithoutProperties_ShouldReturnException()
        {
            // Arrange
            var testEntity = new TestEntity
            {
                Id     = Guid.NewGuid(),
                Name   = "Yoda",
                Number = 1
            };

            DbContextOptions <TestDbContext> options = new DbContextOptionsBuilder <TestDbContext>()
                                                       .UseInMemoryDatabase(databaseName: "InMemory_TestDb")
                                                       .Options;

            var dbContext  = new TestDbContext(options);
            var repository = new ReadWriteRepository <TestEntity, Guid>(() => dbContext);

            dbContext.Add(testEntity);
            await dbContext.SaveChangesAsync();

            testEntity.Name = "Mace Windu";

            // Act
            Func <Task> result = async() => await repository.UpdateFieldsAsync(testEntity, null);

            // Assert
            result.Should().Throw <NullReferenceException>();
        }
예제 #2
0
        private ReadWriteRepository CreatePersistenceRepository(string key)
        {
            var persistenceRepository = new ReadWriteRepository("read-write");

            persistenceRepository.RepositoryKey = key;
            return(persistenceRepository);
        }
        public async Task UpdateAsync_ExistingEntity_ShouldUpdateEntity()
        {
            // Arrange
            var testEntity = new TestEntity
            {
                Id     = Guid.NewGuid(),
                Name   = "Luke Skywalker",
                Number = 1
            };

            DbContextOptions <TestDbContext> options = new DbContextOptionsBuilder <TestDbContext>()
                                                       .UseInMemoryDatabase(databaseName: "InMemory_TestDb")
                                                       .Options;

            var dbContext  = new TestDbContext(options);
            var repository = new ReadWriteRepository <TestEntity, Guid>(() => dbContext);

            dbContext.Add(testEntity);
            await dbContext.SaveChangesAsync();

            testEntity.Name   = "Han Solo";
            testEntity.Number = 2;

            // Act
            await repository.UpdateAsync(testEntity);

            TestEntity verifyEntity = await repository.GetByIdAsync(testEntity.Id);

            // Assert
            verifyEntity.Name.Should().Be("Han Solo");
            verifyEntity.Number.Should().Be(2);
        }
예제 #4
0
        public void IsDeleting()
        {
            var obj = Test.Create();

            obj.Update("Test_Is_Write", 11000011);

            var objId = obj.Id;

            var writeRepo = new ReadWriteRepository(GetDbContext());

            writeRepo.Create <Test, Guid>(obj);

            //THIS IS NOT DONE IN PRODUCTION
            writeRepo.Commit();

            var readRepo = new ReadOnlyRepository(GetDbContext());

            var testObj = readRepo.GetById <Test, Guid>(objId);

            Assert.AreEqual(obj.Name, testObj.Name);
            Assert.AreEqual(obj.Value, testObj.Value);

            writeRepo.Delete <Test, Guid>(obj);

            writeRepo.Commit();

            var table = readRepo.Table <Test, Guid>().Where(o => o.Id.Equals(obj.Id)).ToList();

            Assert.AreEqual(table.Count, 0);
        }
        public async Task UpdateFieldsAsync_WithMultipleChangedEntities_ShouldOnlyUpdateSpecifiedEntity()
        {
            // Arrange
            var testEntity1 = new TestEntity
            {
                Id     = Guid.NewGuid(),
                Name   = "Count Dooku",
                Number = 1
            };
            var testEntity2 = new TestEntity
            {
                Id     = Guid.NewGuid(),
                Name   = "Kit Fisto",
                Number = 2
            };

            DbContextOptions <TestDbContext> options = new DbContextOptionsBuilder <TestDbContext>()
                                                       .UseInMemoryDatabase(databaseName: "InMemory_TestDb")
                                                       .Options;

            using (var dbContext = new TestDbContext(options))
            {
                dbContext.Add(testEntity1);
                dbContext.Add(testEntity2);
                await dbContext.SaveChangesAsync();
            }

            // Act
            using (var dbContext = new TestDbContext(options))
            {
                var repository = new ReadWriteRepository <TestEntity, Guid>(() => dbContext);
                testEntity1 = await repository.GetByIdAsync(testEntity1.Id);

                testEntity1.Name   = "Darth Vader";
                testEntity1.Number = 45;
                testEntity2.Name   = "Sheev Palpatine";

                await repository.UpdateFieldsAsync(testEntity1, te => te.Name);
            }

            // Assert
            using (var dbContext = new TestDbContext(options))
            {
                var        repository         = new ReadWriteRepository <TestEntity, Guid>(() => dbContext);
                TestEntity updatedTestEntity1 = await repository.GetByIdAsync(testEntity1.Id);

                TestEntity updatedTestEntity2 = await repository.GetByIdAsync(testEntity2.Id);

                updatedTestEntity1.Name.Should().Be("Darth Vader");
                updatedTestEntity1.Number.Should().Be(1);
                updatedTestEntity2.Name.Should().Be("Kit Fisto");
            }
        }
        public async Task DeleteByIdAsync_UnknownEntity_ShouldThrowException()
        {
            // Arrange
            TestEntity[] entities = _fixture.CreateMany <TestEntity>(2).ToArray();

            var dbContextMock = new DbContextMock <TestDbContext>(_options);

            dbContextMock.CreateDbSetMock(x => x.TestEntities, (x, _) => (x.Id), entities);
            var repository = new ReadWriteRepository <TestEntity, Guid>(() => dbContextMock.Object);

            // Act
            Func <Task> deleteEntity = async() => await repository.DeleteByIdAsync(Guid.NewGuid());

            // Assert
            FluentAssertions.Specialized.ExceptionAssertions <NullReferenceException> result = await deleteEntity.Should().ThrowAsync <NullReferenceException>();
        }
        public async Task AddEntity_ShouldAddEntity()
        {
            // Arrange
            TestEntity entity        = _fixture.Create <TestEntity>();
            var        dbContextMock = new DbContextMock <TestDbContext>(_options);

            dbContextMock.CreateDbSetMock(x => x.TestEntities, (x, _) => (x.Id));

            var repository = new ReadWriteRepository <TestEntity, Guid>(() => dbContextMock.Object);

            // Act
            TestEntity result = await repository.AddAsync(entity);

            // Assert
            result.Id.Should().Be(entity.Id);
            result.Name.Should().Be(entity.Name);
        }
예제 #8
0
        public void IsWritingUpdate()
        {
            var writeRepo = new ReadWriteRepository(GetDbContext());

            var obj = writeRepo.Table <Test, Guid>().First();

            var testId    = obj.Id;
            var valueTest = obj.Value + 1;

            obj.Update(obj.Name, valueTest);

            //THIS IS NOT DONE IN PRODUCTION
            writeRepo.Commit();

            var readRepo = new ReadOnlyRepository(GetDbContext());

            var testObj = readRepo.GetById <Test, Guid>(testId);

            Assert.AreEqual(valueTest, testObj.Value);
        }
        public async Task UpdateFieldsAsync_WithProperties_ShouldOnlyUpdateSpecifiedEntityProperties()
        {
            // Arrange
            var testEntity = new TestEntity
            {
                Id     = Guid.NewGuid(),
                Name   = "Anakin Skywalker",
                Number = 1
            };

            DbContextOptions <TestDbContext> options = new DbContextOptionsBuilder <TestDbContext>()
                                                       .UseInMemoryDatabase(databaseName: "InMemory_TestDb")
                                                       .Options;

            using (var dbContext = new TestDbContext(options))
            {
                dbContext.Add(testEntity);
                await dbContext.SaveChangesAsync();
            }

            testEntity.Name   = "Obi-Wan Kenobi";
            testEntity.Number = 2;

            // Act
            using (var dbContext = new TestDbContext(options))
            {
                var repository = new ReadWriteRepository <TestEntity, Guid>(() => dbContext);

                await repository.UpdateFieldsAsync(testEntity, te => te.Name);
            }

            // Assert
            using (var dbContext = new TestDbContext(options))
            {
                var        repository        = new ReadWriteRepository <TestEntity, Guid>(() => dbContext);
                TestEntity updatedTestEntity = await repository.GetByIdAsync(testEntity.Id);

                updatedTestEntity.Name.Should().Be("Obi-Wan Kenobi");
                updatedTestEntity.Number.Should().Be(1);
            }
        }
        public async Task DeleteByIdAsync_KnownEntity_ShouldDeleteEntity()
        {
            // Arrange
            TestEntity[] entities = _fixture.CreateMany <TestEntity>(2).ToArray();

            var dbContextMock = new DbContextMock <TestDbContext>(_options);

            dbContextMock.CreateDbSetMock(x => x.TestEntities, (x, _) => (x.Id), entities);
            var repository = new ReadWriteRepository <TestEntity, Guid>(() => dbContextMock.Object);

            // Act
            await repository.DeleteByIdAsync(entities[0].Id);

            await repository.CommitAsync();

            TestEntity[] getAll = await repository.GetAllAsync();

            // Assert
            getAll.SingleOrDefault(x => x.Id == entities[0].Id).Should().BeNull();
            getAll.Should().HaveCount(1);
        }
        public async Task DeleteAsync_UnknownEntity_ShouldNotThrowException()
        {
            // Arrange
            TestEntity[] entities      = _fixture.CreateMany <TestEntity>(2).ToArray();
            var          dbContextMock = new DbContextMock <TestDbContext>(_options);

            dbContextMock.CreateDbSetMock(x => x.TestEntities, (x, _) => (x.Id), entities);

            var repository = new ReadWriteRepository <TestEntity, Guid>(() => dbContextMock.Object);

            // Act
            await repository.DeleteAsync(_fixture.Create <TestEntity>());

            await repository.CommitAsync();

            TestEntity[] getAll = await repository.GetAllAsync();

            // Assert
            getAll.Should().ContainEquivalentOf(entities[0]);
            getAll.Should().HaveCount(2);
        }
        public async Task UpdateFieldsAsync_WithProperties_ShouldUpdateEntityProperties()
        {
            // Arrange
            var testEntity = new TestEntity
            {
                Id     = Guid.NewGuid(),
                Name   = "Chewbacca",
                Number = 1
            };

            DbContextOptions <TestDbContext> options = new DbContextOptionsBuilder <TestDbContext>()
                                                       .UseInMemoryDatabase(databaseName: "InMemory_TestDb")
                                                       .Options;

            using (var dbContext = new TestDbContext(options))
            {
                dbContext.Add(testEntity);
                await dbContext.SaveChangesAsync();
            }

            TestEntity updatedTestEntity = null;

            testEntity.Name   = "R2-D2";
            testEntity.Number = 2;

            // Act
            using (var dbContext = new TestDbContext(options))
            {
                var repository = new ReadWriteRepository <TestEntity, Guid>(() => dbContext);
                await repository.UpdateFieldsAsync(testEntity, te => te.Name, te => te.Number);

                // Assert
                updatedTestEntity = await repository.GetByIdAsync(testEntity.Id);
            }

            // Assert
            updatedTestEntity.Name.Should().Be("R2-D2");
            updatedTestEntity.Number.Should().Be(2);
        }
예제 #13
0
        public void IsWritingAdd()
        {
            var obj = Test.Create();

            obj.Update("Test_Is_Write", 11000011);

            var objId = obj.Id;

            var writeRepo = new ReadWriteRepository(GetDbContext());

            writeRepo.Create <Test, Guid>(obj);

            //THIS IS NOT DONE IN PRODUCTION
            writeRepo.Commit();

            var readRepo = new ReadOnlyRepository(GetDbContext());

            var testObj = readRepo.GetById <Test, Guid>(objId);

            Assert.AreEqual(obj.Name, testObj.Name);
            Assert.AreEqual(obj.Value, testObj.Value);
        }
예제 #14
0
        internal static void InitializeDatabase(IApplicationBuilder app, IConfiguration configuration)
        {
            using (var serviceScope = app.ApplicationServices.GetService <IServiceScopeFactory>().CreateScope())
            {
                serviceScope.ServiceProvider.GetRequiredService <PersistedGrantDbContext>().Database.Migrate();
                var identityContext = serviceScope.ServiceProvider.GetRequiredService <ApplicationIdentityDbContext>();
                identityContext.Database.Migrate();

                if (!identityContext.Users.Any())
                {
                    var adminUser = new IdentityUser()
                    {
                        Id                 = Guid.NewGuid().ToString(),
                        Email              = "*****@*****.**",
                        UserName           = "******",
                        NormalizedUserName = "******",
                        EmailConfirmed     = true
                    };


                    var writeRepo = new ReadWriteRepository(GetDbContext(configuration.GetConnectionString("ApplicationDatabase")));

                    if (!writeRepo.Table <CoreUser, Guid>().Any())
                    {
                        var adminUserCore = CoreUser.Create(Guid.Parse(adminUser.Id));
                        adminUserCore.Update(new CoreUserDto()
                        {
                            Access  = AccessEnum.SuperAdmin,
                            Picture = @""
                        });


                        writeRepo.Create <CoreUser, Guid>(adminUserCore);

                        writeRepo.Commit();

                        writeRepo.Dispose();
                    }

                    adminUser.PasswordHash = new PasswordHasher <IdentityUser>().HashPassword(adminUser, "Password1@");

                    identityContext.Users.Add(adminUser);
                    identityContext.SaveChanges();
                }

                var context = serviceScope.ServiceProvider.GetRequiredService <ConfigurationDbContext>();
                context.Database.Migrate();
                if (!context.Clients.Any())
                {
                    foreach (var client in IdentityConfig.GetClients(configuration))
                    {
                        context.Clients.Add(client.ToEntity());
                    }
                    context.SaveChanges();
                }

                if (context.Clients.Any() && context.Clients.CountAsync(new CancellationToken(false)).Result == 1)
                {
                    foreach (var client in IdentityConfig.GetClients(configuration))
                    {
                        if (!client.ClientId.Equals("carbon.app"))
                        {
                            context.Clients.Add(client.ToEntity());
                        }
                    }
                    context.SaveChanges();
                }

                if (!context.IdentityResources.Any())
                {
                    foreach (var resource in IdentityConfig.GetIdentityResources())
                    {
                        context.IdentityResources.Add(resource.ToEntity());
                    }
                    context.SaveChanges();
                }

                if (!context.ApiResources.Any())
                {
                    foreach (var resource in IdentityConfig.GetApiResources(configuration))
                    {
                        context.ApiResources.Add(resource.ToEntity());
                    }
                    context.SaveChanges();
                }
            }
        }