我有以下问题。我正在尝试为 Orleans grain 实施单元测试,但在启动时找不到 dataprovider Default。异常发生在构造函数调用上。这是代码:单元测试类
[TestFixture]
public class SdxRemindersTest : TestingSiloHost
{
public SdxRemindersTest ()
: base(new TestingSiloOptions
{
StartPrimary = true,
StartSecondary = false,
SiloConfigFile = new FileInfo("OrleansConfiguration.xml")
}, new TestingClientOptions {ClientConfigFile = new FileInfo("ClientConfiguration.xml")})
{
}
// methods here.........
}
这是我的配置文件 OrleansConfiguration.xml
<?xml version="1.0" encoding="utf-8"?>
<OrleansConfiguration xmlns="urn:orleans">
<Globals>
<StorageProviders>
<Provider Type="NBOOC.Grains.StorageProviders.CustomSqlStorageProvider"
Name="Default"
Database=""
ConnectionString="" />
</StorageProviders>
<StreamProviders>
<Provider Type="Orleans.Providers.Streams.SimpleMessageStream.SimpleMessageStreamProvider" Name="SMSProvider" FireAndForgetDelivery="false"/>
</StreamProviders>
<BootstrapProviders>
<Provider Type="NBOOC.Grains.OrleansApp" Name="OrleansApp" />
</BootstrapProviders>
<SeedNode Address="localhost" Port="22222"/>
<Messaging ResponseTimeout="30s"/>
<ReminderService ReminderServiceType="ReminderTableGrain"/>
</Globals>
<Defaults>
<Networking Address="localhost" Port="22222"/>
<ProxyingGateway Address="localhost" Port="40000" />
<Tracing DefaultTraceLevel="Warning" TraceToConsole="true" TraceToFile="{0}-{1}.log" PropagateActivityId="false" BulkMessageLimit="1000">
<TraceLevelOverride LogPrefix="Application" TraceLevel="Verbose3" />
<LogConsumer>NBOOC.Grains.Utils.LogConsumer,NBOOC.Grains</LogConsumer>
</Tracing>
<Statistics MetricsTableWriteInterval="30s" PerfCounterWriteInterval="30s" LogWriteInterval="300s" WriteLogStatisticsToTable="true" StatisticsCollectionLevel="Info"/>
</Defaults>
</OrleansConfiguration>
我遇到的错误是这样的:
Exc 级别 0:Orleans.Runtime.OrleansException:NBOOC.Grains.StorageProviders.CustomSqlStorageProvider,NBOOC.Grains 名称类型的提供程序默认未加载。请检查您是否已将定义提供程序类的程序集部署到执行文件夹。
在 Orleans.Providers.ProviderLoader`1.ValidateProviders()
在 Orleans.Providers.ProviderLoader
1.LoadProviders(IDictionary
2 配置,IProviderManager providerManager)在 Orleans.Runtime.Storage.StorageProviderManager.LoadStorageProviders(IDictionary`2 配置)
在 Orleans.Runtime.Scheduler.SchedulerExtensions.<>c__DisplayClassa.<b__8>d__c.MoveNext()
如您所见,有一个名称为 Default 且具有完全指定类型的提供程序。在那里指定的类是可访问的,因为所有引用都在那里 - 我已经明确检查过,所有 DLL-s 都放在与单元测试 DLL 相同的文件夹中。我还检查了 Orleans DLL 的所有版本——它们都是相同的 1.0.10.0,所以这不是版本问题。有没有人遇到过这样的事情?任何想法如何解决它?
PS顺便说一句,如果你觉得它有帮助的话。我已经下载了奥尔良的源代码并追踪了发生异常的地方——有一个 ProviderLoader 类,它有一个提供者 Dictionary 的字典,但由于某种原因它是空的。