using System.Linq; using Autofac; using Moq; using NHibernate; using NUnit.Framework; using Orchard.ContentManagement.MetaData; using Orchard.Data; using Orchard.ContentManagement; using Orchard.ContentManagement.Handlers; using Orchard.ContentManagement.Records; using Orchard.DisplayManagement; using Orchard.DisplayManagement.Descriptors; using Orchard.Environment.Extensions; using Orchard.Tests.ContentManagement.Records; using Orchard.Tests.ContentManagement.Models; using Orchard.DisplayManagement.Implementation; using Orchard.Tests.Stubs; namespace Orchard.Tests.ContentManagement { [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(EpsilonRecord), typeof(ContentItemVersionRecord), 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.RegisterType().As().SingleInstance(); builder.RegisterType().As(); builder.RegisterInstance(new Mock().Object); builder.RegisterType().As(); builder.RegisterType().As(); builder.RegisterType().As(); builder.RegisterType().As(); builder.RegisterType().As(); builder.RegisterType().As(); builder.RegisterType().As(); builder.RegisterType().As(); builder.RegisterType().As(); builder.RegisterType().As(); builder.RegisterGeneric(typeof(Repository<>)).As(typeof(IRepository<>)); builder.RegisterType().As(); _session = _sessionFactory.OpenSession(); builder.RegisterInstance(new DefaultContentManagerTests.TestSessionLocator(_session)).As(); _session.Delete(string.Format("from {0}", typeof(GammaRecord).FullName)); _session.Delete(string.Format("from {0}", typeof(DeltaRecord).FullName)); _session.Delete(string.Format("from {0}", typeof(EpsilonRecord).FullName)); _session.Delete(string.Format("from {0}", typeof(ContentItemVersionRecord).FullName)); _session.Delete(string.Format("from {0}", typeof(ContentItemRecord).FullName)); _session.Delete(string.Format("from {0}", typeof(ContentTypeRecord).FullName)); _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(); _session.Clear(); var ascending = _manager.Query("gamma") .OrderBy(x => x.Frap) .List().ToList(); 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")); _session.Clear(); var descending = _manager.Query() .OrderByDescending(x => x.Frap) .List().ToList(); 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)); } [Test] public void QueryShouldJoinVersionedRecords() { AddSampleData(); _manager.Create("gamma", init => { init.Record.Frap = "one"; init.As().Record.Quad = "1"; }); _manager.Create("gamma", init => { init.Record.Frap = "two"; init.As().Record.Quad = "2"; }); _manager.Create("gamma", init => { init.Record.Frap = "three"; init.As().Record.Quad = "3"; }); _manager.Create("gamma", init => { init.Record.Frap = "four"; init.As().Record.Quad = "4"; }); _session.Flush(); _session.Clear(); var results = _manager.Query() .Where(x => x.Quad == "2" || x.Quad == "3") .OrderByDescending(x => x.Quad) .List(); Assert.That(results.Count(), Is.EqualTo(2)); Assert.That(results.First().Record, Has.Property("Quad").EqualTo("3")); Assert.That(results.Last().Record, Has.Property("Quad").EqualTo("2")); } private void AddGammaVersions() { var gamma1 = _manager.Create("gamma", init => { init.As().Record.Frap = "one"; init.As().Record.Quad = "v1"; }); _session.Flush(); _session.Clear(); var gamma2 = _manager.Get(gamma1.Id, VersionOptions.DraftRequired); gamma2.As().Record.Frap = "two"; gamma2.As().Record.Quad = "v2"; _session.Flush(); _session.Clear(); var gamma3 = _manager.Create("gamma", init => { init.As().Record.Frap = "three"; init.As().Record.Quad = "v3"; }); _session.Flush(); _session.Clear(); } [Test] public void QueryShouldOnlyReturnPublishedByDefault() { AddGammaVersions(); var list1 = _manager.Query() .Where(x => x.Quad == "v1") .List(); var list2 = _manager.Query() .Where(x => x.Quad == "v2") .List(); var list3 = _manager.Query() .Where(x => x.Quad == "v3") .List(); var listOne = _manager.Query() .Where(x => x.Frap == "one") .List(); var listTwo = _manager.Query() .Where(x => x.Frap == "two") .List(); var listThree = _manager.Query() .Where(x => x.Frap == "three") .List(); Assert.That(list1.Count(), Is.EqualTo(1)); Assert.That(list2.Count(), Is.EqualTo(0)); Assert.That(list3.Count(), Is.EqualTo(1)); Assert.That(listOne.Count(), Is.EqualTo(0)); Assert.That(listTwo.Count(), Is.EqualTo(1)); Assert.That(listThree.Count(), Is.EqualTo(1)); } [Test] public void QueryForLatestShouldNotReturnEarlierVersions() { AddGammaVersions(); var list1 = _manager.Query(VersionOptions.Latest) .Where(x => x.Quad == "v1") .List(); var list2 = _manager.Query(VersionOptions.Latest) .Where(x => x.Quad == "v2") .List(); var list3 = _manager.Query(VersionOptions.Latest) .Where(x => x.Quad == "v3") .List(); var listOne = _manager.Query(VersionOptions.Latest) .Where(x => x.Frap == "one") .List(); var listTwo = _manager.Query(VersionOptions.Latest) .Where(x => x.Frap == "two") .List(); var listThree = _manager.Query(VersionOptions.Latest) .Where(x => x.Frap == "three") .List(); Assert.That(list1.Count(), Is.EqualTo(0)); Assert.That(list2.Count(), Is.EqualTo(1)); Assert.That(list3.Count(), Is.EqualTo(1)); Assert.That(listOne.Count(), Is.EqualTo(0)); Assert.That(listTwo.Count(), Is.EqualTo(1)); Assert.That(listThree.Count(), Is.EqualTo(1)); } [Test] public void QueryForDraftShouldOnlyReturnLatestThatIsNotPublished() { AddGammaVersions(); var list1 = _manager.Query(VersionOptions.Draft) .Where(x => x.Quad == "v1") .List(); var list2 = _manager.Query(VersionOptions.Draft) .Where(x => x.Quad == "v2") .List(); var list3 = _manager.Query(VersionOptions.Draft) .Where(x => x.Quad == "v3") .List(); var listOne = _manager.Query(VersionOptions.Draft) .Where(x => x.Frap == "one") .List(); var listTwo = _manager.Query(VersionOptions.Draft) .Where(x => x.Frap == "two") .List(); var listThree = _manager.Query(VersionOptions.Draft) .Where(x => x.Frap == "three") .List(); Assert.That(list1.Count(), Is.EqualTo(0)); Assert.That(list2.Count(), Is.EqualTo(1)); Assert.That(list3.Count(), Is.EqualTo(0)); Assert.That(listOne.Count(), Is.EqualTo(0)); Assert.That(listTwo.Count(), Is.EqualTo(1)); Assert.That(listThree.Count(), Is.EqualTo(0)); } [Test] public void QueryForAllShouldReturnMultipleQualifiedVersions() { AddGammaVersions(); var list1 = _manager.Query(VersionOptions.AllVersions) .Where(x => x.Quad == "v1") .List(); var list2 = _manager.Query(VersionOptions.AllVersions) .Where(x => x.Quad == "v2") .List(); var list3 = _manager.Query(VersionOptions.AllVersions) .Where(x => x.Quad == "v3") .List(); var listOne = _manager.Query(VersionOptions.AllVersions) .Where(x => x.Frap == "one") .List(); var listTwo = _manager.Query(VersionOptions.AllVersions) .Where(x => x.Frap == "two") .List(); var listThree = _manager.Query(VersionOptions.AllVersions) .Where(x => x.Frap == "three") .List(); Assert.That(list1.Count(), Is.EqualTo(1)); Assert.That(list2.Count(), Is.EqualTo(1)); Assert.That(list3.Count(), Is.EqualTo(1)); Assert.That(listOne.Count(), Is.EqualTo(0)); Assert.That(listTwo.Count(), Is.EqualTo(2)); Assert.That(listThree.Count(), Is.EqualTo(1)); } } }