nunit-core team mailing list archive
-
nunit-core team
-
Mailing list archive
-
Message #01229
[Bug 662937] [NEW] "Assembly Not Loaded" error, unhandled TypeLoadException
Public bug reported:
NUnit version 2.5.7.10213, GUI runner
Visual Studio 2010 Pro, no plugins
In a Visual Studio solution with 3 projects, NUnit sometimes crashes in
the background while source code changes are being made. The attached
zip is a trimmed down SampleApp solution that you can use to reproduce
the issue.
Steps to reproduce:
o VS2010 -> Load SampleApp solution.
o NUnit -> Load SampleApp.nunit.
o NUnit -> Run all tests to ensure they pass.
o VS2010 -> Do the following steps to cause NUnit to crash with an
unhandled exception.
o SampleApp project -> Actuator.cs -> change Actuate method signature
from:
void Actuate();
to:
void Actuate(int timesToActuate);
o F6 to build. This results in one build error as expected.
o SampleApp project -> Client.cs -> change statement in Actuate method
from:
actuator.Actuate();
to:
actuator.Actuate(timesToActuate);
o F6 to build. This results in another build error, and NUnit
crashes.
+ NUnit crash message:
Title: "Assembly Not Loaded"
Message: "System.TypeLoadException : Method 'Actuate' in type
'SampleApp.Mocks.MockActuator' from assembly
'SampleApp.Mocks, Version=1.0.0.0, Culture=neutral,
PublicKeyToken=null' does not have an implementation.
For further information, use the Exception Details menu item."
+ NUnit Exception Details shows this additional info:
System.TypeLoadException...
Server stack trace:
at System.Reflection.RuntimeAssembly.GetExportedTypes(RuntimeAssembly assembly, ObjectHandleOnStack retTypes)
at System.Reflection.RuntimeAssembly.GetExportedTypes()
at NUnit.Core.CoreExtensions.InstallAdhocExtensions(Assembly assembly)
at NUnit.Core.Builders.TestAssemblyBuilder.Load(String path)
at NUnit.Core.Builders.TestAssemblyBuilder.Build(String assemblyName, Boolean autoSuites)
at NUnit.Core.Builders.TestAssemblyBuilder.Build(String assemblyName, String testName, Boolean autoSuites)
at NUnit.Core.TestSuiteBuilder.Build(TestPackage package)
at NUnit.Core.SimpleTestRunner.Load(TestPackage package)
at NUnit.Core.ProxyTestRunner.Load(TestPackage package)
at NUnit.Core.ProxyTestRunner.Load(TestPackage package)
at NUnit.Core.RemoteTestRunner.Load(TestPackage package)
at System.Runtime.Remoting.Messaging.StackBuilderSink._PrivateProcessMessage(IntPtr md, Object[] args, Object server, Int32 methodPtr, Boolean fExecuteInContext, Object[]& outArgs)
at System.Runtime.Remoting.Messaging.StackBuilderSink.SyncProcessMessage(IMessage msg, Int32 methodPtr, Boolean fExecuteInContext)
Exception rethrown at [0]:
at System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg)
at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type)
at NUnit.Core.TestRunner.Load(TestPackage package)
at NUnit.Util.TestDomain.Load(TestPackage package)
at NUnit.Core.ProxyTestRunner.Load(TestPackage package)
at NUnit.Util.RemoteTestAgent.AgentRunner.Load(TestPackage package)
at System.Runtime.Remoting.Messaging.StackBuilderSink._PrivateProcessMessage(IntPtr md, Object[] args, Object server, Int32 methodPtr, Boolean fExecuteInContext, Object[]& outArgs)
at System.Runtime.Remoting.Messaging.StackBuilderSink.SyncProcessMessage(IMessage msg, Int32 methodPtr, Boolean fExecuteInContext)
Exception rethrown at [1]:
at System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg)
at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type)
at NUnit.Core.TestRunner.Load(TestPackage package)
at NUnit.Core.ProxyTestRunner.Load(TestPackage package)
at NUnit.Util.ProcessRunner.Load(TestPackage package)
at NUnit.Util.TestLoader.ReloadTest(RuntimeFramework framework)
o NUnit -> at this point opening the File menu or closing NUnit displays:
"Unhandled exception has occurred in your application. If you click
Continue, the application will ignore this error and attempt to continue.
If you click Quit, the application will close immediately.
No connection could be made because the target machine actively
refused it 127.0.0.1:49900."
o Running NUnit again without fixing the source code gets the same errors.
o Changing Client.cs first and then Actuator.cs gets the same errors.
+ In all these cases MockActuatorTests.cs and MockActuator.cs are left
unchanged. They must be changed also (or first) in order to resolve
or avoid the issue.
Let me know if I can provide additional information.
Regards
Joel
** Affects: nunitv2
Importance: Undecided
Status: New
--
"Assembly Not Loaded" error, unhandled TypeLoadException
https://bugs.launchpad.net/bugs/662937
You received this bug notification because you are a member of NUnit
Developers, which is subscribed to NUnit V2.
Status in NUnit V2 Test Framework: New
Bug description:
NUnit version 2.5.7.10213, GUI runner
Visual Studio 2010 Pro, no plugins
In a Visual Studio solution with 3 projects, NUnit sometimes crashes in the background while source code changes are being made. The attached zip is a trimmed down SampleApp solution that you can use to reproduce the issue.
Steps to reproduce:
o VS2010 -> Load SampleApp solution.
o NUnit -> Load SampleApp.nunit.
o NUnit -> Run all tests to ensure they pass.
o VS2010 -> Do the following steps to cause NUnit to crash with an
unhandled exception.
o SampleApp project -> Actuator.cs -> change Actuate method signature
from:
void Actuate();
to:
void Actuate(int timesToActuate);
o F6 to build. This results in one build error as expected.
o SampleApp project -> Client.cs -> change statement in Actuate method
from:
actuator.Actuate();
to:
actuator.Actuate(timesToActuate);
o F6 to build. This results in another build error, and NUnit crashes.
+ NUnit crash message:
Title: "Assembly Not Loaded"
Message: "System.TypeLoadException : Method 'Actuate' in type
'SampleApp.Mocks.MockActuator' from assembly
'SampleApp.Mocks, Version=1.0.0.0, Culture=neutral,
PublicKeyToken=null' does not have an implementation.
For further information, use the Exception Details menu item."
+ NUnit Exception Details shows this additional info:
System.TypeLoadException...
Server stack trace:
at System.Reflection.RuntimeAssembly.GetExportedTypes(RuntimeAssembly assembly, ObjectHandleOnStack retTypes)
at System.Reflection.RuntimeAssembly.GetExportedTypes()
at NUnit.Core.CoreExtensions.InstallAdhocExtensions(Assembly assembly)
at NUnit.Core.Builders.TestAssemblyBuilder.Load(String path)
at NUnit.Core.Builders.TestAssemblyBuilder.Build(String assemblyName, Boolean autoSuites)
at NUnit.Core.Builders.TestAssemblyBuilder.Build(String assemblyName, String testName, Boolean autoSuites)
at NUnit.Core.TestSuiteBuilder.Build(TestPackage package)
at NUnit.Core.SimpleTestRunner.Load(TestPackage package)
at NUnit.Core.ProxyTestRunner.Load(TestPackage package)
at NUnit.Core.ProxyTestRunner.Load(TestPackage package)
at NUnit.Core.RemoteTestRunner.Load(TestPackage package)
at System.Runtime.Remoting.Messaging.StackBuilderSink._PrivateProcessMessage(IntPtr md, Object[] args, Object server, Int32 methodPtr, Boolean fExecuteInContext, Object[]& outArgs)
at System.Runtime.Remoting.Messaging.StackBuilderSink.SyncProcessMessage(IMessage msg, Int32 methodPtr, Boolean fExecuteInContext)
Exception rethrown at [0]:
at System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg)
at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type)
at NUnit.Core.TestRunner.Load(TestPackage package)
at NUnit.Util.TestDomain.Load(TestPackage package)
at NUnit.Core.ProxyTestRunner.Load(TestPackage package)
at NUnit.Util.RemoteTestAgent.AgentRunner.Load(TestPackage package)
at System.Runtime.Remoting.Messaging.StackBuilderSink._PrivateProcessMessage(IntPtr md, Object[] args, Object server, Int32 methodPtr, Boolean fExecuteInContext, Object[]& outArgs)
at System.Runtime.Remoting.Messaging.StackBuilderSink.SyncProcessMessage(IMessage msg, Int32 methodPtr, Boolean fExecuteInContext)
Exception rethrown at [1]:
at System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg)
at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type)
at NUnit.Core.TestRunner.Load(TestPackage package)
at NUnit.Core.ProxyTestRunner.Load(TestPackage package)
at NUnit.Util.ProcessRunner.Load(TestPackage package)
at NUnit.Util.TestLoader.ReloadTest(RuntimeFramework framework)
o NUnit -> at this point opening the File menu or closing NUnit displays:
"Unhandled exception has occurred in your application. If you click
Continue, the application will ignore this error and attempt to continue.
If you click Quit, the application will close immediately.
No connection could be made because the target machine actively
refused it 127.0.0.1:49900."
o Running NUnit again without fixing the source code gets the same errors.
o Changing Client.cs first and then Actuator.cs gets the same errors.
+ In all these cases MockActuatorTests.cs and MockActuator.cs are left
unchanged. They must be changed also (or first) in order to resolve
or avoid the issue.
Let me know if I can provide additional information.
Regards
Joel
Follow ups
References