Removing obsolete eventbus interface, firing shell activated/terminated events in isolated scope, fixing tests

--HG--
branch : dev
This commit is contained in:
Louis DeJardin
2010-05-28 16:24:57 -07:00
parent 52ef9f3c8c
commit 596729a2ce
11 changed files with 113 additions and 55 deletions

View File

@@ -52,6 +52,7 @@
<ErrorReport>prompt</ErrorReport> <ErrorReport>prompt</ErrorReport>
<WarningLevel>4</WarningLevel> <WarningLevel>4</WarningLevel>
<CodeAnalysisRuleSet>AllRules.ruleset</CodeAnalysisRuleSet> <CodeAnalysisRuleSet>AllRules.ruleset</CodeAnalysisRuleSet>
<PlatformTarget>x86</PlatformTarget>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<Reference Include="Autofac, Version=2.1.13.813, Culture=neutral, PublicKeyToken=17863af14b0044da, processorArchitecture=MSIL"> <Reference Include="Autofac, Version=2.1.13.813, Culture=neutral, PublicKeyToken=17863af14b0044da, processorArchitecture=MSIL">

View File

@@ -52,6 +52,7 @@
<ErrorReport>prompt</ErrorReport> <ErrorReport>prompt</ErrorReport>
<WarningLevel>4</WarningLevel> <WarningLevel>4</WarningLevel>
<CodeAnalysisRuleSet>AllRules.ruleset</CodeAnalysisRuleSet> <CodeAnalysisRuleSet>AllRules.ruleset</CodeAnalysisRuleSet>
<PlatformTarget>x86</PlatformTarget>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<Reference Include="Autofac, Version=2.1.13.813, Culture=neutral, PublicKeyToken=17863af14b0044da, processorArchitecture=MSIL"> <Reference Include="Autofac, Version=2.1.13.813, Culture=neutral, PublicKeyToken=17863af14b0044da, processorArchitecture=MSIL">

View File

@@ -3,6 +3,7 @@ using System.Collections.Generic;
using System.Linq; using System.Linq;
using Autofac; using Autofac;
using NUnit.Framework; using NUnit.Framework;
using Orchard.Core.Settings.State;
using Orchard.Core.Settings.Topology; using Orchard.Core.Settings.Topology;
using Orchard.Core.Settings.Topology.Records; using Orchard.Core.Settings.Topology.Records;
using Orchard.Environment.State; using Orchard.Environment.State;
@@ -14,7 +15,8 @@ namespace Orchard.Tests.Modules.Settings.Topology {
[TestFixture] [TestFixture]
public class ShellDescriptorManagerTests : DatabaseEnabledTestsBase { public class ShellDescriptorManagerTests : DatabaseEnabledTestsBase {
public override void Register(ContainerBuilder builder) { public override void Register(ContainerBuilder builder) {
builder.RegisterType<ShellDescriptorManager>().As<IShellDescriptorManager>(); builder.RegisterType<ShellDescriptorManager>().As<IShellDescriptorManager>().SingleInstance();
builder.RegisterType<ShellStateManager>().As<IShellStateManager>().SingleInstance();
builder.RegisterType<StubEventBus>().As<IEventBus>().SingleInstance(); builder.RegisterType<StubEventBus>().As<IEventBus>().SingleInstance();
builder.RegisterSource(new EventsRegistrationSource()); builder.RegisterSource(new EventsRegistrationSource());
} }

View File

@@ -72,6 +72,9 @@ namespace Orchard.Tests.Environment {
_container.Mock<IShellDescriptorManager>() _container.Mock<IShellDescriptorManager>()
.Setup(cp => cp.GetShellDescriptor()).Returns(default(ShellDescriptor)); .Setup(cp => cp.GetShellDescriptor()).Returns(default(ShellDescriptor));
_container.Mock<IOrchardShellEvents>()
.Setup(e=>e.Activated());
var temp = Path.GetTempFileName(); var temp = Path.GetTempFileName();
File.Delete(temp); File.Delete(temp);
Directory.CreateDirectory(temp); Directory.CreateDirectory(temp);

View File

@@ -9,15 +9,12 @@ namespace Orchard.Tests.Events {
public class EventTests { public class EventTests {
private IContainer _container; private IContainer _container;
private IEventBus _eventBus; private IEventBus _eventBus;
private StubEventBusHandler _eventBusHandler;
private StubEventHandler _eventHandler; private StubEventHandler _eventHandler;
[SetUp] [SetUp]
public void Init() { public void Init() {
var builder = new ContainerBuilder(); var builder = new ContainerBuilder();
_eventBusHandler = new StubEventBusHandler();
_eventHandler = new StubEventHandler(); _eventHandler = new StubEventHandler();
builder.RegisterInstance(_eventBusHandler).As<IEventBusHandler>();
builder.RegisterInstance(_eventHandler).As<IEventHandler>(); builder.RegisterInstance(_eventHandler).As<IEventHandler>();
builder.RegisterType<DefaultOrchardEventBus>().As<IEventBus>(); builder.RegisterType<DefaultOrchardEventBus>().As<IEventBus>();
_container = builder.Build(); _container = builder.Build();
@@ -181,23 +178,5 @@ namespace Orchard.Tests.Events {
} }
} }
[Test]
public void EventsAreCorrectlyDispatchedToHandlers_Obsolete() {
Assert.That(_eventBusHandler.LastMessageName, Is.Null);
_eventBus.Notify_Obsolete("Notification", new Dictionary<string, string>());
Assert.That(_eventBusHandler.LastMessageName, Is.EqualTo("Notification"));
}
public class StubEventBusHandler : IEventBusHandler {
public string LastMessageName { get; set; }
#region Implementation of IEventBusHandler
public void Process(string messageName, IDictionary<string, string> eventData) {
LastMessageName = messageName;
}
#endregion
}
} }
} }

View File

@@ -21,7 +21,7 @@ namespace Orchard.Core.Settings.State {
public ShellState GetShellState() { public ShellState GetShellState() {
var stateRecord = _shellStateRepository.Get(x => true) ?? new ShellStateRecord(); var stateRecord = _shellStateRepository.Get(x => true) ?? new ShellStateRecord();
var descriptor = _shellDescriptorManager.GetShellDescriptor(); var descriptor = _shellDescriptorManager.GetShellDescriptor();
var extraFeatures = descriptor.Features var extraFeatures = descriptor == null ? Enumerable.Empty<string>() : descriptor.Features
.Select(r => r.Name) .Select(r => r.Name)
.Except(stateRecord.Features.Select(r => r.Name)); .Except(stateRecord.Features.Select(r => r.Name));

View File

@@ -1,5 +1,9 @@
using System; using System;
using System.Collections;
using System.Data;
using NHibernate; using NHibernate;
using NHibernate.SqlCommand;
using NHibernate.Type;
using Orchard.Logging; using Orchard.Logging;
namespace Orchard.Data { namespace Orchard.Data {
@@ -29,10 +33,85 @@ namespace Orchard.Data {
_transactionManager.Demand(); _transactionManager.Demand();
Logger.Information("Openning database session"); Logger.Information("Openning database session");
_session = sessionFactory.OpenSession(); _session = sessionFactory.OpenSession(new SessionInterceptor(this));
} }
return _session; return _session;
} }
class SessionInterceptor : IInterceptor {
private readonly SessionLocator _sessionLocator;
private ISession _session;
public SessionInterceptor(SessionLocator sessionLocator) {
_sessionLocator = sessionLocator;
}
bool IInterceptor.OnLoad(object entity, object id, object[] state, string[] propertyNames, IType[] types) {
return true;
}
bool IInterceptor.OnFlushDirty(object entity, object id, object[] currentState, object[] previousState, string[] propertyNames, IType[] types) {
return true;
}
bool IInterceptor.OnSave(object entity, object id, object[] state, string[] propertyNames, IType[] types) {
return true;
}
void IInterceptor.OnDelete(object entity, object id, object[] state, string[] propertyNames, IType[] types) {
}
void IInterceptor.OnCollectionRecreate(object collection, object key) {
}
void IInterceptor.OnCollectionRemove(object collection, object key) {
}
void IInterceptor.OnCollectionUpdate(object collection, object key) {
}
void IInterceptor.PreFlush(ICollection entities) {
}
void IInterceptor.PostFlush(ICollection entities) {
}
bool? IInterceptor.IsTransient(object entity) {
return null;
}
int[] IInterceptor.FindDirty(object entity, object id, object[] currentState, object[] previousState, string[] propertyNames, IType[] types) {
return null;
}
object IInterceptor.Instantiate(string entityName, EntityMode entityMode, object id) {
return null;
}
string IInterceptor.GetEntityName(object entity) {
return null;
}
object IInterceptor.GetEntity(string entityName, object id) {
return null;
}
void IInterceptor.AfterTransactionBegin(ITransaction tx) {
}
void IInterceptor.BeforeTransactionCompletion(ITransaction tx) {
}
void IInterceptor.AfterTransactionCompletion(ITransaction tx) {
}
SqlString IInterceptor.OnPrepareStatement(SqlString sql) {
return sql;
}
void IInterceptor.SetSession(ISession session) {
_session = session;
}
}
} }
} }

View File

@@ -4,6 +4,7 @@ using System.Threading;
using System.Web.Mvc; using System.Web.Mvc;
using Autofac; using Autofac;
using System.Collections.Generic; using System.Collections.Generic;
using Autofac.Features.OwnedInstances;
using Orchard.Environment.Configuration; using Orchard.Environment.Configuration;
using Orchard.Environment.Extensions; using Orchard.Environment.Extensions;
using Orchard.Environment.ShellBuilders; using Orchard.Environment.ShellBuilders;
@@ -98,8 +99,6 @@ namespace Orchard.Environment {
private void ActivateShell(ShellContext context) { private void ActivateShell(ShellContext context) {
context.Shell.Activate(); context.Shell.Activate();
_runningShellTable.Add(context.Settings); _runningShellTable.Add(context.Settings);
//refactor:lifecycle
//HackSimulateExtensionActivation(context.LifetimeScope);
} }
ShellContext CreateSetupContext() { ShellContext CreateSetupContext() {
@@ -121,31 +120,26 @@ namespace Orchard.Environment {
BuildCurrent(); BuildCurrent();
} }
// the exit gate is temporary, until better control strategy is in place
private readonly ManualResetEvent _exitGate = new ManualResetEvent(true);
protected virtual void EndRequest() { protected virtual void EndRequest() {
if (_processingEngine.AreTasksPending()) { if (_processingEngine.AreTasksPending()) {
_exitGate.Reset();
ThreadPool.QueueUserWorkItem(state => { ThreadPool.QueueUserWorkItem(state => {
while (_processingEngine.AreTasksPending()) { while (_processingEngine.AreTasksPending()) {
_processingEngine.ExecuteNextTask(); _processingEngine.ExecuteNextTask();
if (!_processingEngine.AreTasksPending()) {
_exitGate.Set();
}
} }
}); });
} }
_exitGate.WaitOne(250);
} }
//refactor:lifecycle
//private void HackSimulateExtensionActivation(ILifetimeScope shellContainer) {
// var containerProvider = new FiniteContainerProvider(shellContainer);
// try {
// var requestContainer = containerProvider.RequestLifetime;
// var hackInstallationGenerator = requestContainer.Resolve<IHackInstallationGenerator>();
// hackInstallationGenerator.GenerateActivateEvents();
// }
// finally {
// containerProvider.EndRequestLifetime();
// }
//}
void IShellSettingsManagerEventHandler.Saved(ShellSettings settings) { void IShellSettingsManagerEventHandler.Saved(ShellSettings settings) {
_current = null; _current = null;
} }

View File

@@ -1,7 +1,9 @@
using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.IO; using System.IO;
using System.Linq; using System.Linq;
using System.Web.Mvc; using System.Web.Mvc;
using Autofac.Features.OwnedInstances;
using Orchard.Environment.Extensions.Models; using Orchard.Environment.Extensions.Models;
using Orchard.Logging; using Orchard.Logging;
using Orchard.Mvc.ModelBinders; using Orchard.Mvc.ModelBinders;
@@ -9,21 +11,21 @@ using Orchard.Mvc.Routes;
namespace Orchard.Environment { namespace Orchard.Environment {
public class DefaultOrchardShell : IOrchardShell { public class DefaultOrchardShell : IOrchardShell {
private readonly Func<Owned<IOrchardShellEvents>> _eventsFactory;
private readonly IEnumerable<IRouteProvider> _routeProviders; private readonly IEnumerable<IRouteProvider> _routeProviders;
private readonly IRoutePublisher _routePublisher; private readonly IRoutePublisher _routePublisher;
private readonly IEnumerable<IModelBinderProvider> _modelBinderProviders; private readonly IEnumerable<IModelBinderProvider> _modelBinderProviders;
private readonly IModelBinderPublisher _modelBinderPublisher; private readonly IModelBinderPublisher _modelBinderPublisher;
private readonly ViewEngineCollection _viewEngines; private readonly ViewEngineCollection _viewEngines;
private readonly IOrchardShellEvents _events;
public DefaultOrchardShell( public DefaultOrchardShell(
IOrchardShellEvents events, Func<Owned<IOrchardShellEvents>> eventsFactory,
IEnumerable<IRouteProvider> routeProviders, IEnumerable<IRouteProvider> routeProviders,
IRoutePublisher routePublisher, IRoutePublisher routePublisher,
IEnumerable<IModelBinderProvider> modelBinderProviders, IEnumerable<IModelBinderProvider> modelBinderProviders,
IModelBinderPublisher modelBinderPublisher, IModelBinderPublisher modelBinderPublisher,
ViewEngineCollection viewEngines) { ViewEngineCollection viewEngines) {
_events = events; _eventsFactory = eventsFactory;
_routeProviders = routeProviders; _routeProviders = routeProviders;
_routePublisher = routePublisher; _routePublisher = routePublisher;
_modelBinderProviders = modelBinderProviders; _modelBinderProviders = modelBinderProviders;
@@ -41,11 +43,15 @@ namespace Orchard.Environment {
AddOrchardLocationsFormats(); AddOrchardLocationsFormats();
_events.Activated(); using (var events = _eventsFactory()) {
events.Value.Activated();
}
} }
public void Terminate() { public void Terminate() {
_events.Terminating(); using (var events = _eventsFactory()) {
events.Value.Terminating();
}
} }
/// <summary> /// <summary>

View File

@@ -7,11 +7,9 @@ using Orchard.Logging;
namespace Orchard.Events { namespace Orchard.Events {
public class DefaultOrchardEventBus : IEventBus { public class DefaultOrchardEventBus : IEventBus {
private readonly Func<IEnumerable<IEventBusHandler>> _handlers;
private readonly Func<IEnumerable<IEventHandler>> _eventHandlers; private readonly Func<IEnumerable<IEventHandler>> _eventHandlers;
public DefaultOrchardEventBus(Func<IEnumerable<IEventBusHandler>> handlers, Func<IEnumerable<IEventHandler>> eventHandlers) { public DefaultOrchardEventBus(Func<IEnumerable<IEventHandler>> eventHandlers) {
_handlers = handlers;
_eventHandlers = eventHandlers; _eventHandlers = eventHandlers;
Logger = NullLogger.Instance; Logger = NullLogger.Instance;
T = NullLocalizer.Instance; T = NullLocalizer.Instance;
@@ -22,10 +20,6 @@ namespace Orchard.Events {
#region Implementation of IEventBus #region Implementation of IEventBus
public void Notify_Obsolete(string messageName, IDictionary<string, string> eventData) {
_handlers().Invoke(handler => handler.Process(messageName, eventData), Logger);
}
public void Notify(string messageName, Dictionary<string, object> eventData) { public void Notify(string messageName, Dictionary<string, object> eventData) {
string[] parameters = messageName.Split('.'); string[] parameters = messageName.Split('.');
if (parameters.Length != 2) { if (parameters.Length != 2) {
@@ -41,7 +35,7 @@ namespace Orchard.Events {
} }
catch(Exception ex) { catch(Exception ex) {
Logger.Error(ex, "{2} thrown from {0} by {1}", Logger.Error(ex, "{2} thrown from {0} by {1}",
interfaceName + "." +methodName, messageName,
eventHandler.GetType().FullName, eventHandler.GetType().FullName,
ex.GetType().Name); ex.GetType().Name);
} }

View File

@@ -2,7 +2,6 @@
namespace Orchard.Events { namespace Orchard.Events {
public interface IEventBus : IDependency { public interface IEventBus : IDependency {
void Notify_Obsolete(string messageName, IDictionary<string, string> eventData);
void Notify(string messageName, Dictionary<string, object> eventData); void Notify(string messageName, Dictionary<string, object> eventData);
} }
} }