I’ve simplified my actual code to the following:
public class AbstractExample : AbstractExampleBase<ExampleViewModel>
{
public override void Execute(Guid entityId)
{
Debug.WriteLine("Executed!");
}
}
public abstract class AbstractExampleBase<T> : IExecutor where T : IExampleViewModel
{
public abstract void Execute(Guid entityId);
}
public interface IExecutor
{
void Execute(Guid entityId);
}
public interface IExampleViewModel
{
Guid EntityId { get; set; }
}
public class ExampleViewModel : IExampleViewModel
{
public Guid EntityId { get; set; }
}
Then I try to enqueue the job:
var abstractExample = new AbstractExample();
BackgroundJob.Enqueue(() => abstractExample.Execute(Guid.NewGuid()));
The dashboard shows my job as:
using ;
AbstractExampleBase abstractExampleBase = Activate<AbstractExampleBase<ExampleViewModel>>();
abstractExampleBase.Execute(
FromJson<Guid>("\"699e0a1a-b3db-449c-bc9f-8e20da052a28\""));
The job errors and ninject throws an ActivationException with the message:
Ninject.ActivationException: Error activating AbstractExampleBase{ExampleViewModel}
No matching bindings are available, and the type is not self-bindable.
It seems to me that the problem is the serialized version of the job is trying to activate the base class, which is abstract, instead of instantiating the instance’s actual class, which is not abstract.
Is there a way I can get it to instantiate the appropriate class, rather than the (abstract) base class?