using System; using System.Collections.Generic; using System.Linq; using System.Text; using Autofac; using Autofac.Builder; using Autofac.Modules; using NHibernate; using NUnit.Framework; using Orchard.Data; using Orchard.ContentManagement; using Orchard.ContentManagement.Handlers; using Orchard.ContentManagement.Records; using Orchard.Tests.Models.Records; using Orchard.Tests.Models.Stubs; namespace Orchard.Tests.Models { [TestFixture] public class ContentQueryTests { private IContainer _container; private IContentManager _manager; private ISessionFactory _sessionFactory; private ISession _session; [TestFixtureSetUp] public void InitFixture() { var databaseFileName = System.IO.Path.GetTempFileName(); _sessionFactory = DataUtility.CreateSessionFactory( databaseFileName, typeof(GammaRecord), typeof(DeltaRecord), typeof(ContentItemRecord), typeof(ContentTypeRecord)); } [TestFixtureTearDown] public void TermFixture() { } [SetUp] public void Init() { var builder = new ContainerBuilder(); builder.RegisterModule(new ImplicitCollectionSupportModule()); builder.RegisterModule(new ContentModule()); builder.Register().As(); builder.Register().As(); builder.Register().As(); builder.Register().As(); builder.Register().As(); builder.Register().As(); builder.Register().As(); builder.RegisterGeneric(typeof(Repository<>)).As(typeof(IRepository<>)); _session = _sessionFactory.OpenSession(); builder.Register(new DefaultModelManagerTests.TestSessionLocator(_session)).As(); _session.Delete("from GammaRecord"); _session.Delete("from DeltaRecord"); _session.Delete("from ContentItemRecord"); _session.Delete("from ContentTypeRecord"); _session.Flush(); _session.Clear(); _container = builder.Build(); _manager = _container.Resolve(); } private void AddSampleData() { _manager.Create("alpha", init => { }); _manager.Create("beta", init => { }); _manager.Create("gamma", init => { init.Record.Frap = "the frap value"; }); _manager.Create("delta", init => { init.Record.Quux = "the quux value"; }); _session.Flush(); } [Test] public void QueryInstanceIsDifferentEachTimeYouCreateOne() { var contentManager1 = _container.Resolve(); var query1a = contentManager1.Query(); var query1b = contentManager1.Query(); var contentManager2 = _container.Resolve(); var query2a = contentManager2.Query(); var query2b = contentManager2.Query(); Assert.That(contentManager1, Is.SameAs(contentManager2)); Assert.That(query1a, Is.SameAs(query1a)); Assert.That(query1a, Is.Not.SameAs(query1b)); Assert.That(query1a, Is.Not.SameAs(query2a)); Assert.That(query1a, Is.Not.SameAs(query2b)); Assert.That(query1b, Is.Not.SameAs(query2a)); Assert.That(query1b, Is.Not.SameAs(query2b)); Assert.That(query2a, Is.Not.SameAs(query2b)); } [Test] public void ContentManagerPropertyIsSet() { var contentManager = _container.Resolve(); var query = contentManager.Query(); Assert.That(query.ContentManager, Is.SameAs(contentManager)); var mockManager = new Moq.Mock().Object; var anotherQuery = _container.Resolve(TypedParameter.From(mockManager)); Assert.That(anotherQuery, Is.Not.SameAs(query)); Assert.That(anotherQuery.ContentManager, Is.SameAs(mockManager)); } [Test] public void AllItemsAreReturnedByDefault() { AddSampleData(); var allItems = _manager.Query().List(); Assert.That(allItems.Count(), Is.EqualTo(4)); Assert.That(allItems.Count(x => x.Has()), Is.EqualTo(1)); Assert.That(allItems.Count(x => x.Has()), Is.EqualTo(1)); Assert.That(allItems.Count(x => x.Has()), Is.EqualTo(1)); Assert.That(allItems.Count(x => x.Has()), Is.EqualTo(1)); } [Test] public void SpecificTypeIsReturnedWhenSpecified() { AddSampleData(); var alphaBeta = _manager.Query().ForType("alpha", "beta").List(); Assert.That(alphaBeta.Count(), Is.EqualTo(2)); Assert.That(alphaBeta.Count(x => x.Has()), Is.EqualTo(1)); Assert.That(alphaBeta.Count(x => x.Has()), Is.EqualTo(1)); Assert.That(alphaBeta.Count(x => x.Has()), Is.EqualTo(0)); Assert.That(alphaBeta.Count(x => x.Has()), Is.EqualTo(0)); var gammaDelta = _manager.Query().ForType("gamma", "delta").List(); Assert.That(gammaDelta.Count(), Is.EqualTo(2)); Assert.That(gammaDelta.Count(x => x.Has()), Is.EqualTo(0)); Assert.That(gammaDelta.Count(x => x.Has()), Is.EqualTo(0)); Assert.That(gammaDelta.Count(x => x.Has()), Is.EqualTo(1)); Assert.That(gammaDelta.Count(x => x.Has()), Is.EqualTo(1)); } [Test] public void WherePredicateRestrictsResults() { AddSampleData(); _manager.Create("gamma", init => { init.Record.Frap = "one"; }); _manager.Create("gamma", init => { init.Record.Frap = "two"; }); _manager.Create("gamma", init => { init.Record.Frap = "three"; }); _manager.Create("gamma", init => { init.Record.Frap = "four"; }); _session.Flush(); var twoOrFour = _manager.Query() .Where(x => x.Frap == "one" || x.Frap == "four") .List(); Assert.That(twoOrFour.Count(), Is.EqualTo(2)); Assert.That(twoOrFour.Count(x => x.Has()), Is.EqualTo(2)); Assert.That(twoOrFour.Count(x => x.Get().Record.Frap == "one"), Is.EqualTo(1)); Assert.That(twoOrFour.Count(x => x.Get().Record.Frap == "four"), Is.EqualTo(1)); } [Test] public void EmptyWherePredicateRequiresRecord() { AddSampleData(); var gammas = _manager.Query().Join().List(); var deltas = _manager.Query().Join().List(); Assert.That(gammas.Count(), Is.EqualTo(1)); Assert.That(deltas.Count(), Is.EqualTo(1)); Assert.That(gammas.AsPart().Single().Record.Frap, Is.EqualTo("the frap value")); Assert.That(deltas.AsPart().Single().Record.Quux, Is.EqualTo("the quux value")); } [Test] public void OrderMaySortOnJoinedRecord() { AddSampleData(); _manager.Create("gamma", init => { init.Record.Frap = "one"; }); _manager.Create("gamma", init => { init.Record.Frap = "two"; }); _manager.Create("gamma", init => { init.Record.Frap = "three"; }); _manager.Create("gamma", init => { init.Record.Frap = "four"; }); _session.Flush(); var ascending = _manager.Query("gamma") .OrderBy(x => x.Frap) .List(); Assert.That(ascending.Count(), Is.EqualTo(5)); Assert.That(ascending.First().Record.Frap, Is.EqualTo("four")); Assert.That(ascending.Last().Record.Frap, Is.EqualTo("two")); var descending = _manager.Query() .OrderByDescending(x => x.Frap) .List(); Assert.That(descending.Count(), Is.EqualTo(5)); Assert.That(descending.First().Record.Frap, Is.EqualTo("two")); Assert.That(descending.Last().Record.Frap, Is.EqualTo("four")); } [Test] public void SkipAndTakeProvidePagination() { AddSampleData(); _manager.Create("gamma", init => { init.Record.Frap = "one"; }); _manager.Create("gamma", init => { init.Record.Frap = "two"; }); _manager.Create("gamma", init => { init.Record.Frap = "three"; }); _manager.Create("gamma", init => { init.Record.Frap = "four"; }); _session.Flush(); var reverseById = _manager.Query() .OrderByDescending(x => x.Id) .List(); var subset = _manager.Query() .OrderByDescending(x => x.Id) .Slice(2, 3); Assert.That(subset.Count(), Is.EqualTo(3)); Assert.That(subset.First().Id, Is.EqualTo(reverseById.Skip(2).First().Id)); Assert.That(subset.Skip(1).First().Id, Is.EqualTo(reverseById.Skip(3).First().Id)); Assert.That(subset.Skip(2).First().Id, Is.EqualTo(reverseById.Skip(4).First().Id)); } } }