* NPoco - 2.x (builds) * NPoco - v3.1 (does not build) * NPoco - builds * NPoco - configure database factory (tests fail) * Pick fix from 7.4 * NPoco - stock v3.1 - sort-of working * NPoco - fix merge * Fix Newtonsoft.Json in web.Template.Debug.config * NPoco - fix SELECT * * NPoco - fixing repositories * NPoco - fix EntityRepository * NPoco - fix EntityRepository * NPoco - cosmetic * NPoco - use 3.1.0-u001 from github/zpqrtbnk/NPoco * Fixes build, NPoco needed to be referenced in the cms and UmbracoExamine projects * Fixes lots of tests * fixes more tests * NPoco - bugfixing * Bugfix CacheHelper in tests * Bugfix connection mocking in tests * NPoco - inject database in Sql.Select<> * NPoco - discovery retry policy only once * Enable C# 6 for Umbraco.Core * NPoco - introduce UmbracoSql, cleanup * NPoco - more cleanup and fixing * NPoco - fix UserRepository * Optimize InGroupsOf * Implement UmbracoDatabase.FetchByGroups * NPoco - fix Select * NPoco - simplify GetPagedResultsByQuery * Cherry-pick DisableBrowserCacheAttribute fix from 7.4 * Upgrade NPoco to use Sql<TContext> * U4-8257 - cleanup relators * 4-8257 - cleanup more relators * Upgrade NPoco with more OOTB version * fixes a couple tests, changes double check lock to Lazy<T>
265 lines
8.8 KiB
C#
265 lines
8.8 KiB
C#
using System;
|
|
using System.Data.SqlServerCe;
|
|
using System.Linq;
|
|
using Moq;
|
|
using NUnit.Framework;
|
|
using Umbraco.Core;
|
|
using Umbraco.Core.Cache;
|
|
using Umbraco.Core.Logging;
|
|
using Umbraco.Core.Models;
|
|
|
|
using Umbraco.Core.Persistence.Querying;
|
|
using Umbraco.Core.Persistence.Repositories;
|
|
using Umbraco.Core.Persistence.UnitOfWork;
|
|
using Umbraco.Tests.TestHelpers;
|
|
|
|
namespace Umbraco.Tests.Persistence.Repositories
|
|
{
|
|
[DatabaseTestBehavior(DatabaseBehavior.NewDbFileAndSchemaPerTest)]
|
|
[TestFixture]
|
|
public class ServerRegistrationRepositoryTest : BaseDatabaseFactoryTest
|
|
{
|
|
private ICacheProvider _staticCache;
|
|
|
|
[SetUp]
|
|
public override void Initialize()
|
|
{
|
|
base.Initialize();
|
|
|
|
_staticCache = new StaticCacheProvider();
|
|
CreateTestData();
|
|
}
|
|
|
|
private ServerRegistrationRepository CreateRepository(IDatabaseUnitOfWork unitOfWork)
|
|
{
|
|
return new ServerRegistrationRepository(unitOfWork, _staticCache, Logger, SqlSyntax, MappingResolver);
|
|
}
|
|
|
|
[Test]
|
|
public void Cannot_Add_Duplicate_Server_Identities()
|
|
{
|
|
// Arrange
|
|
var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
var unitOfWork = provider.GetUnitOfWork();
|
|
|
|
// Act
|
|
using (var repository = CreateRepository(unitOfWork))
|
|
{
|
|
var server = new ServerRegistration("http://shazwazza.com", "COMPUTER1", DateTime.Now);
|
|
repository.AddOrUpdate(server);
|
|
|
|
Assert.Throws<SqlCeException>(unitOfWork.Commit);
|
|
}
|
|
|
|
}
|
|
|
|
[Test]
|
|
public void Cannot_Update_To_Duplicate_Server_Identities()
|
|
{
|
|
// Arrange
|
|
var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
var unitOfWork = provider.GetUnitOfWork();
|
|
|
|
// Act
|
|
using (var repository = CreateRepository(unitOfWork))
|
|
{
|
|
var server = repository.Get(1);
|
|
server.ServerIdentity = "COMPUTER2";
|
|
repository.AddOrUpdate(server);
|
|
Assert.Throws<SqlCeException>(unitOfWork.Commit);
|
|
}
|
|
|
|
}
|
|
|
|
[Test]
|
|
public void Can_Instantiate_Repository()
|
|
{
|
|
// Arrange
|
|
var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
var unitOfWork = provider.GetUnitOfWork();
|
|
|
|
// Act
|
|
using (var repository = CreateRepository(unitOfWork))
|
|
{
|
|
// Assert
|
|
Assert.That(repository, Is.Not.Null);
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void Can_Perform_Get_On_Repository()
|
|
{
|
|
// Arrange
|
|
var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
var unitOfWork = provider.GetUnitOfWork();
|
|
using (var repository = CreateRepository(unitOfWork))
|
|
{
|
|
// Act
|
|
var server = repository.Get(1);
|
|
|
|
// Assert
|
|
Assert.That(server, Is.Not.Null);
|
|
Assert.That(server.HasIdentity, Is.True);
|
|
Assert.That(server.ServerAddress, Is.EqualTo("http://localhost"));
|
|
}
|
|
|
|
|
|
}
|
|
|
|
[Test]
|
|
public void Can_Perform_GetAll_On_Repository()
|
|
{
|
|
// Arrange
|
|
var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
var unitOfWork = provider.GetUnitOfWork();
|
|
using (var repository = CreateRepository(unitOfWork))
|
|
{
|
|
// Act
|
|
var servers = repository.GetAll();
|
|
|
|
// Assert
|
|
Assert.That(servers.Count(), Is.EqualTo(3));
|
|
}
|
|
|
|
}
|
|
|
|
// queries are not supported due to in-memory caching
|
|
|
|
//[Test]
|
|
//public void Can_Perform_GetByQuery_On_Repository()
|
|
//{
|
|
// // Arrange
|
|
// var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
// var unitOfWork = provider.GetUnitOfWork();
|
|
// using (var repository = CreateRepository(unitOfWork))
|
|
// {
|
|
// // Act
|
|
// var query = Query<IServerRegistration>.Builder.Where(x => x.ServerIdentity.ToUpper() == "COMPUTER3");
|
|
// var result = repository.GetByQuery(query);
|
|
|
|
// // Assert
|
|
// Assert.AreEqual(1, result.Count());
|
|
// }
|
|
//}
|
|
|
|
//[Test]
|
|
//public void Can_Perform_Count_On_Repository()
|
|
//{
|
|
// // Arrange
|
|
// var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
// var unitOfWork = provider.GetUnitOfWork();
|
|
// using (var repository = CreateRepository(unitOfWork))
|
|
// {
|
|
// // Act
|
|
// var query = Query<IServerRegistration>.Builder.Where(x => x.ServerAddress.StartsWith("http://"));
|
|
// int count = repository.Count(query);
|
|
|
|
// // Assert
|
|
// Assert.That(count, Is.EqualTo(2));
|
|
// }
|
|
//}
|
|
|
|
[Test]
|
|
public void Can_Perform_Add_On_Repository()
|
|
{
|
|
// Arrange
|
|
var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
var unitOfWork = provider.GetUnitOfWork();
|
|
using (var repository = CreateRepository(unitOfWork))
|
|
{
|
|
// Act
|
|
var server = new ServerRegistration("http://shazwazza.com", "COMPUTER4", DateTime.Now);
|
|
repository.AddOrUpdate(server);
|
|
unitOfWork.Commit();
|
|
|
|
// Assert
|
|
Assert.That(server.HasIdentity, Is.True);
|
|
Assert.That(server.Id, Is.EqualTo(4));//With 3 existing entries the Id should be 4
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void Can_Perform_Update_On_Repository()
|
|
{
|
|
// Arrange
|
|
var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
var unitOfWork = provider.GetUnitOfWork();
|
|
using (var repository = CreateRepository(unitOfWork))
|
|
{
|
|
// Act
|
|
var server = repository.Get(2);
|
|
server.ServerAddress = "https://umbraco.com";
|
|
server.IsActive = true;
|
|
|
|
repository.AddOrUpdate(server);
|
|
unitOfWork.Commit();
|
|
|
|
var serverUpdated = repository.Get(2);
|
|
|
|
// Assert
|
|
Assert.That(serverUpdated, Is.Not.Null);
|
|
Assert.That(serverUpdated.ServerAddress, Is.EqualTo("https://umbraco.com"));
|
|
Assert.That(serverUpdated.IsActive, Is.EqualTo(true));
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void Can_Perform_Delete_On_Repository()
|
|
{
|
|
// Arrange
|
|
var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
var unitOfWork = provider.GetUnitOfWork();
|
|
using (var repository = CreateRepository(unitOfWork))
|
|
{
|
|
// Act
|
|
var server = repository.Get(3);
|
|
Assert.IsNotNull(server);
|
|
repository.Delete(server);
|
|
unitOfWork.Commit();
|
|
|
|
var exists = repository.Exists(3);
|
|
|
|
// Assert
|
|
Assert.That(exists, Is.False);
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void Can_Perform_Exists_On_Repository()
|
|
{
|
|
// Arrange
|
|
var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
var unitOfWork = provider.GetUnitOfWork();
|
|
using (var repository = CreateRepository(unitOfWork))
|
|
{
|
|
// Act
|
|
var exists = repository.Exists(3);
|
|
var doesntExist = repository.Exists(10);
|
|
|
|
// Assert
|
|
Assert.That(exists, Is.True);
|
|
Assert.That(doesntExist, Is.False);
|
|
}
|
|
}
|
|
|
|
[TearDown]
|
|
public override void TearDown()
|
|
{
|
|
base.TearDown();
|
|
}
|
|
|
|
public void CreateTestData()
|
|
{
|
|
var provider = new NPocoUnitOfWorkProvider(Logger);
|
|
using (var unitOfWork = provider.GetUnitOfWork())
|
|
using (var repository = CreateRepository(unitOfWork))
|
|
{
|
|
repository.AddOrUpdate(new ServerRegistration("http://localhost", "COMPUTER1", DateTime.Now) { IsActive = true });
|
|
repository.AddOrUpdate(new ServerRegistration("http://www.mydomain.com", "COMPUTER2", DateTime.Now));
|
|
repository.AddOrUpdate(new ServerRegistration("https://www.another.domain.com", "Computer3", DateTime.Now));
|
|
unitOfWork.Commit();
|
|
}
|
|
|
|
}
|
|
}
|
|
} |