You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
4 times out of 5 the ADO connection will throw an exception The connection does not support MultipleActiveResultSets
Enable MARS (not that I want to) and the exception changes to
"The transaction operation cannot be performed because there are pending requests working on this transaction"
The query being executed that causes this is from the IContainerService.SetInitialOrder()
var contanerContentItemsQuery = _session.QueryIndex<ContentItemIndex>(x => x.ContentType == contentType && (x.Published || x.Latest));
var containerContentItems = await contanerContentItemsQuery.ListAsync();
Of note, this is not using the Database Content Definition Store. It's using the File Definition Store.
So there is no other queries going to the database, nor is there any _session.Save() occuring.
I think the issue is happening because of async void calls in the DefaultContentDefinitionDisplayManager
Swap the async / await on the typeBuilder.WithPart for a GetAwaiter().GetResult() and the issue is resolved.
Problem is I think the async voids are just heading off into never never land, and not completing before the session is trying to Commit.
That's why I say 4 times out of 5.
If you put it in the debugger (i.e. give it a chance to complete the async database queries), it never fails.
The ContentDefinitionDisplayManager is actually peppered already with .GetAwaiter().GetResult() calls on some of the other methods, and async await void on some of the others.
I guess it's not a heavy usage api, so .GetAwaiter().GetResult() is probably better than breaking the api by turning it async, but there's probably a nicer way to fix it.
Yes, we should use .GetAwaiter().GetResult() when in the lambda of an .AlterSomething() as it is not related to a Func<> returning a Task, but an Action<> parameter that can't be async. Hmm, i already fixed the same kind of issue, should be as it is already done line 97 and 155, but we missed this one line 216 and also another one line 280
Only occurs on SQL Server
Repro
EnableOrder
4 times out of 5 the ADO connection will throw an exception
data:image/s3,"s3://crabby-images/e5ecf/e5ecf1f0d6927e5ff7dd53bcbb5ef6b72de5a7ec" alt="Screenshot 2020-08-16 at 17 28 11"
The connection does not support MultipleActiveResultSets
Enable MARS (not that I want to) and the exception changes to
"The transaction operation cannot be performed because there are pending requests working on this transaction"
The query being executed that causes this is from the
IContainerService.SetInitialOrder()
Of note, this is not using the Database Content Definition Store. It's using the File Definition Store.
So there is no other queries going to the database, nor is there any
_session.Save()
occuring.I think the issue is happening because of async void calls in the
DefaultContentDefinitionDisplayManager
This is the method causing issues
Swap the async / await on the
typeBuilder.WithPart
for aGetAwaiter().GetResult()
and the issue is resolved.Problem is I think the async voids are just heading off into never never land, and not completing before the session is trying to Commit.
That's why I say 4 times out of 5.
If you put it in the debugger (i.e. give it a chance to complete the async database queries), it never fails.
The
ContentDefinitionDisplayManager
is actually peppered already with.GetAwaiter().GetResult()
calls on some of the other methods, and async await void on some of the others.I guess it's not a heavy usage api, so
.GetAwaiter().GetResult()
is probably better than breaking the api by turning it async, but there's probably a nicer way to fix it.Any ideas @jtkech ?
The text was updated successfully, but these errors were encountered: