Hello,
I might have spoken to soon...
When I call the following code:
Code:
List<UAReadArguments> uaItems = new List<UAReadArguments>();
//Fill uaItems ~110 times
uaItems.Add(new UAReadArguments(endpointDescriptor: new UAEndpointDescriptor(descriptorString: mlcComProperties.Property.Module.MachineConfigurations[mlcComProperties.ModuleSequenceNumber].PLC.UAAddress),
nodeDescriptor: new UANodeDescriptor(expandedNodeIdText: nodeIdText)));
OpcLabs.BaseLib.OperationModel.ValueResult[] uaReadResults = _uaClient.ReadMultipleValues(uaItems.ToArray());
I get a a crash stating: Precondition failed: attributeDataResultArray.Length == readList.Count and with the following stack trace:
Code:
System.ArgumentException: Precondition failed: attributeDataResultArray.Length == readList.Count
at System.Diagnostics.Contracts.__ContractsRuntime.Requires[TException](Boolean condition, String msg, String conditionTxt)
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.EasyUAEngine.BeginReadList(UASmartSession smartSession, List`1 readList, UAAttributeDataResult[] attributeDataResultArray, AsyncCallback userCallback, Object stateObject)
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.EasyUAEngine.Read(ICollection`1 readListDictionary, UAAttributeDataResult[] attributeDataResultArray)
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.EasyUAEngine.ReadAttributes(UAReadArguments[] readArgumentsArray, EasyUAAdaptableParameters adaptableParameters)
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.NetSdkEasyUAClient.<>c__DisplayClass29_0.<ReadMultiple>b__0()
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.NetSdkEasyUAClient.DisposeGuard[TResult](Func`1 func)
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.NetSdkEasyUAClient.DisposeGuardNotNull[TResult](Func`1 func)
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.NetSdkEasyUAClient.ReadMultiple(UAReadArguments[] readArgumentsArray)
at OpcLabs.EasyOpc.UA.ForwardingEasyUAClient.ReadMultiple(UAReadArguments[] readArgumentsArray)
at OpcLabs.EasyOpc.UA.ForwardingEasyUAClient.ReadMultiple(UAReadArguments[] readArgumentsArray)
at OpcLabs.EasyOpc.UA.LicensingEasyUAClient.ReadMultiple(UAReadArguments[] readArgumentsArray)
at OpcLabs.EasyOpc.UA.EasyUAClient.ReadMultiple(UAReadArguments[] readArgumentsArray)
at OpcLabs.EasyOpc.UA.IEasyUAClientExtension.ReadMultipleValues(IEasyUAClient client, UAReadArguments[] readArgumentsArray)
at DGpS.Business.JobOPCManager.GetValuesFromMLC() in D:\Projects\Scada\HMI\Main HMI\DGpS.Business\JobOPCManager.cs:line 315
at GenericUserControls.UserControls.LoadRecipe.GetFromMLC() in D:\Projects\Scada\HMI\Main HMI\GenericUserControls\UserControls\LoadRecipe.cs:line 1523
at GenericUserControls.UserControls.LoadRecipe.LoadRecipe_Load(Object sender, EventArgs e) in D:\Projects\Scada\HMI\Main HMI\GenericUserControls\UserControls\LoadRecipe.cs:line 424
at System.Windows.Forms.UserControl.OnLoad(EventArgs e)
at System.Windows.Forms.UserControl.OnCreateControl()
at System.Windows.Forms.Control.CreateControl(Boolean fIgnoreVisible)
at System.Windows.Forms.Control.CreateControl()
at System.Windows.Forms.Control.ControlCollection.Add(Control value)
at HMI.Modules.Job.MainControl.MakeSelectStart()
at HMI.Modules.Job.MainControl.ShowSelectStart(Object sender, JobWizardEventArgs ea)
at DGpS.Business.Event.EventHandling.RaiseJobWizardEvent(EventHandler`1 eventHandler, Object sender, JobWizardEventArgs ea) in D:\Projects\Scada\HMI\Main HMI\DGpS.Business\Event\EventHandling.cs:line 22
at HMI.Modules.Job.UserControls.JobOverview.gsbNewJob_Click(Object sender, EventArgs e)
at System.Windows.Forms.Control.OnClick(EventArgs e)
at System.Windows.Forms.Button.OnClick(EventArgs e)
at System.Windows.Forms.Button.OnMouseUp(MouseEventArgs mevent)
at GenericUserControls.CustomControls.GreyscaleButton.OnMouseUp(MouseEventArgs e) in D:\Projects\Scada\HMI\Main HMI\GenericUserControls\CustomControls\GrayscaleButton.cs:line 99
at System.Windows.Forms.Control.WmMouseUp(Message& m, MouseButtons button, Int32 clicks)
at System.Windows.Forms.Control.WndProc(Message& m)
at System.Windows.Forms.ButtonBase.WndProc(Message& m)
at System.Windows.Forms.Button.WndProc(Message& m)
at System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
at System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
at System.Windows.Forms.NativeWindow.Callback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)
Just like before, this all worked with version 5.35.
Edit: Running the code with the debugger attached generates a different error:
Code:
'System.Diagnostics.Contracts.__ContractsRuntime.ContractException' occurred in OpcLabs.EasyOpcUA.dll
Additional information: Assertion failed: smartSession.SmartEngine == this
Stacktrace:
Code:
at System.Diagnostics.Contracts.__ContractsRuntime.TriggerFailure(ContractFailureKind kind, String msg, String userMessage, String conditionTxt, Exception inner)
at System.Diagnostics.Contracts.__ContractsRuntime.ReportFailure(ContractFailureKind kind, String msg, String conditionTxt, Exception inner)
at System.Diagnostics.Contracts.__ContractsRuntime.Assert(Boolean condition, String msg, String conditionTxt)
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.EasyUAEngine.ReadAttributes(UAReadArguments[] readArgumentsArray, EasyUAAdaptableParameters adaptableParameters)
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.NetSdkEasyUAClient.<>c__DisplayClass29_0.<ReadMultiple>b__0()
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.NetSdkEasyUAClient.DisposeGuard[TResult](Func`1 func)
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.NetSdkEasyUAClient.DisposeGuardNotNull[TResult](Func`1 func)
at OpcLabs.EasyOpc.UA.Implementations.NetSdk.NetSdkEasyUAClient.ReadMultiple(UAReadArguments[] readArgumentsArray)
at OpcLabs.EasyOpc.UA.ForwardingEasyUAClient.ReadMultiple(UAReadArguments[] readArgumentsArray)
at OpcLabs.EasyOpc.UA.ForwardingEasyUAClient.ReadMultiple(UAReadArguments[] readArgumentsArray)
at OpcLabs.EasyOpc.UA.LicensingEasyUAClient.ReadMultiple(UAReadArguments[] readArgumentsArray)
at OpcLabs.EasyOpc.UA.EasyUAClient.ReadMultiple(UAReadArguments[] readArgumentsArray)
at OpcLabs.EasyOpc.UA.IEasyUAClientExtension.ReadMultipleValues(IEasyUAClient client, UAReadArguments[] readArgumentsArray)
at DGpS.OPC.UAClient.ReadMultipleValues(UAReadArguments[] readArguments) in D:\Projects\Scada\HMI\Main HMI\DGpS.OPC\UAClient.cs:line 124
at DGpS.Business.JobOPCManager.GetValuesFromMLC() in D:\Projects\Scada\HMI\Main HMI\DGpS.Business\JobOPCManager.cs:line 296
at GenericUserControls.UserControls.LoadRecipe.GetFromMLC() in D:\Projects\Scada\HMI\Main HMI\GenericUserControls\UserControls\LoadRecipe.cs:line 1526
at GenericUserControls.UserControls.LoadRecipe.set_FromMLC(Boolean value) in D:\Projects\Scada\HMI\Main HMI\GenericUserControls\UserControls\LoadRecipe.cs:line 97
at GenericUserControls.UserControls.LoadRecipe.LoadRecipe_Load(Object sender, EventArgs e) in D:\Projects\Scada\HMI\Main HMI\GenericUserControls\UserControls\LoadRecipe.cs:line 424
at System.Windows.Forms.UserControl.OnLoad(EventArgs e)
at System.Windows.Forms.UserControl.OnCreateControl()
at System.Windows.Forms.Control.CreateControl(Boolean fIgnoreVisible)
at System.Windows.Forms.Control.CreateControl(Boolean fIgnoreVisible)
at System.Windows.Forms.Control.CreateControl()
at System.Windows.Forms.Control.ControlCollection.Add(Control value)
at HMI.MainFrame.btn_Click(Object sender, EventArgs e) in D:\Projects\Scada\HMI\Main HMI\ThalloLine\HMI\MainFrame.cs:line 217
at System.Windows.Forms.Control.OnClick(EventArgs e)
at System.Windows.Forms.Button.OnClick(EventArgs e)
at System.Windows.Forms.Button.OnMouseUp(MouseEventArgs mevent)
at System.Windows.Forms.Control.WmMouseUp(Message& m, MouseButtons button, Int32 clicks)
at System.Windows.Forms.Control.WndProc(Message& m)
at System.Windows.Forms.ButtonBase.WndProc(Message& m)
at System.Windows.Forms.Button.WndProc(Message& m)
at System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
at System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
at System.Windows.Forms.NativeWindow.DebuggableCallback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)
at System.Windows.Forms.UnsafeNativeMethods.DispatchMessageW(MSG& msg)
at System.Windows.Forms.Application.ComponentManager.System.Windows.Forms.UnsafeNativeMethods.IMsoComponentManager.FPushMessageLoop(IntPtr dwComponentID, Int32 reason, Int32 pvLoopData)
at System.Windows.Forms.Application.ThreadContext.RunMessageLoopInner(Int32 reason, ApplicationContext context)
at System.Windows.Forms.Application.ThreadContext.RunMessageLoop(Int32 reason, ApplicationContext context)
at Microsoft.VisualBasic.ApplicationServices.WindowsFormsApplicationBase.OnRun()
at Microsoft.VisualBasic.ApplicationServices.WindowsFormsApplicationBase.DoApplicationModel()
at Microsoft.VisualBasic.ApplicationServices.WindowsFormsApplicationBase.Run(String[] commandLine)
at HMI.Program.Main() in D:\Projects\Scada\HMI\Main HMI\ThalloLine\HMI\Program.cs:line 27
at System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
at System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
at System.Threading.ThreadHelper.ThreadStart_Context(Object state)
at System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
at System.Threading.ThreadHelper.ThreadStart()
Best regards,
Erik