[IronPython] InvalidProgramException testing hosting under NUnit
Paul Turbett
sls at iinet.net.au
Fri Apr 4 04:35:54 CEST 2008
Hi
Was there ever a solution to this problem? I'm getting the same thing,
though not with NUnit. To port my IP interface from 1.1 to 2.0 (beta 1),
I created a separate test application, which worked fine. However I'm
merging the code into my "real" application, but I'm not able to create
a ScriptEngine.
_runtime = ScriptRuntime.Create();
string[] languages = _runtime.GetRegisteredLanguageIdentifiers(); //
finds 18 languages, including "py"
_engine = _runtime.GetEngine("py"); // <--- throws an exception
Microsoft.Scripting.Runtime.InvalidImplementationException was unhandled
Message="Type 'IronPython.Runtime.PythonContext' doesn't provide a
suitable public constructor or its implementation is faulty."
Source="Microsoft.Scripting"
StackTrace:
at
Microsoft.Scripting.Utils.ReflectionUtils.CreateInstance[T](Type
actualType, Object[] args)
at
Microsoft.Scripting.Runtime.ScriptDomainManager.LanguageRegistration.LoadLanguageContext(ScriptDomainManager
manager)
at
Microsoft.Scripting.Runtime.ScriptDomainManager.TryGetLanguageContext(String
languageId, LanguageContext& languageContext)
at Microsoft.Scripting.Hosting.ScriptRuntime.TryGetEngine(String
languageId, ScriptEngine& engine)
at Microsoft.Scripting.Hosting.ScriptRuntime.GetEngine(String
languageId)
at Utilities.OSEPython..ctor(FileStream log) in
C:\Projects\Utils\PythonEngine.cs:line 121
at Utilities.PythonFactory.Create(Boolean log) in
C:\Projects\Utils\PythonEngine.cs:line 70
...
Not sure if it's important, but the application uses a few assemblies,
and the IP wrapper classes are in a separate assembly to where they are
used.
Thanks, Paul
Fernando Correia wrote:
> 2008/3/12, Dino Viehland <dinov at exchange.microsoft.com>:
>
>> There's an inner exception here (probably from Importer.cs in MakeImportSite) but there isn't much info on it. Could you run it under a debugger and get that original stack trace? It's not clear to me why we would blow up there.
>>
>
>
> Thanks for your help.
>
> Sorry for some text in Portuguese below. I hope it doesn't get in the way.
>
> The exception occurs within class ReflectionUtils, method CreateInstance<T>.
>
> Line 127 is:
> return (T)Activator.CreateInstance(actualType, args);
>
> This in turns ends up calling the constructor public
> PythonContext(ScriptDomainManager/*!*/ manager) in class
> PythonContext.
>
> Line 120 is:
> _importer = new Importer(this);
>
> A step into this line will cause the exception.
>
> The stack trace of the innermost exception
> ([System.InvalidProgramException] = {"Common Language Runtime detectou
> um programa inválido."}) is:
>
> em Microsoft.Scripting.RuntimeHelpers.CreateSimpleCallSite[T0,T1,T2,T3,T4,R]()
> em IronPython.Runtime.Importer.MakeImportSite() na
> C:\Temp\IronPython v2.0 Alpha
> 8\IronPython-2.0A8-Src\IronPython-2.0A8\Src\IronPython\Runtime\Importer.cs:linha
> 74
> em IronPython.Runtime.Importer..cctor() na C:\Temp\IronPython v2.0
> Alpha 8\IronPython-2.0A8-Src\IronPython-2.0A8\Src\IronPython\Runtime\Importer.cs:linha
> 49
>
> The stack trace of the outermost exception (base
> {System.ApplicationException} = {"Uma exceção foi acionada pelo
> destino de uma chamada."}) is:
>
> em System.RuntimeMethodHandle._InvokeConstructor(Object[] args,
> SignatureStruct& signature, IntPtr declaringType)
> em System.RuntimeMethodHandle.InvokeConstructor(Object[] args,
> SignatureStruct signature, RuntimeTypeHandle declaringType)
> em System.Reflection.RuntimeConstructorInfo.Invoke(BindingFlags
> invokeAttr, Binder binder, Object[] parameters, CultureInfo culture)
> em System.RuntimeType.CreateInstanceImpl(BindingFlags bindingAttr,
> Binder binder, Object[] args, CultureInfo culture, Object[]
> activationAttributes)
> em System.Activator.CreateInstance(Type type, BindingFlags
> bindingAttr, Binder binder, Object[] args, CultureInfo culture,
> Object[] activationAttributes)
> em System.Activator.CreateInstance(Type type, Object[] args)
> em Microsoft.Scripting.Utils.ReflectionUtils.CreateInstance[T](Type
> actualType, Object[] args) na C:\Temp\IronPython v2.0 Alpha
> 8\IronPython-2.0A8-Src\IronPython-2.0A8\Src\Microsoft.Scripting\Utils\ReflectionUtils.cs:linha
> 127
> _______________________________________________
> Users mailing list
> Users at lists.ironpython.com
> http://lists.ironpython.com/listinfo.cgi/users-ironpython.com
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.python.org/pipermail/ironpython-users/attachments/20080404/29784ed7/attachment.html>
More information about the Ironpython-users
mailing list