Hi,
Following the fix of #1707, the issue (or an other one) is still active: there is an infinite loop somewhere that can be created in some situation.
I don't know how to reproduce and it but I know that addbreadcrumb is responsible for this infinite loop.
cf. https://ibb.co/KXcprWY to have more information, the function "standardizer" is called without ending.
It seems to be even worst than the previous version because I used this workaround to prevent browser crashing: initSentry({
dsn: #####,
beforeBreadcrumb(breadcrumb, hint) {
if(get( breadcrumb , "error.data.extra.arguments")) {
breadcrumb.error.data.extra.arguments = [];
}
return breadcrumb;
}
});
This workaround doesn"t work anymore, so I have to get back to the previous version. The problem is that with this workaround It seems impossible to have information about where errors happens in the code (line number etc).
Dorian
in my case this happens if react application in iframe with django grappelli
I have never seen this issue prior to version 4.4.2. My sentry project has a very clear transition to having a circular structor issue once 4.4.2 was released in my app. I'm reverting to 4.4.1 for now
Fixed in 4.5.0, everything is guarded for circular references now. Cheers!
Memory crash remains in 4.5.1 for me.
Now it's falling on safeNormalize
http://joxi.ru/GrqgYe3t4Gb1J2
Original error:
message: "ExpressionChangedAfterItHasBeenCheckedError: Expression has changed after it was checked. Previous value: 'ngIf: [object Object]'. Current value: 'ngIf: true'."
stack: "Error: ExpressionChangedAfterItHasBeenCheckedError: Expression has changed after it was checked. Previous value: 'ngIf: [object Object]'. Current value: 'ngIf: true'.↵ at viewDebugError (http://www.crexi.local:8080/vendor.js:80916:15)↵ at expressionChangedAfterItHasBeenCheckedError (http://www.crexi.local:8080/vendor.js:80904:12)↵ at checkBindingNoChanges (http://www.crexi.local:8080/vendor.js:81006:15)↵ at checkNoChangesNodeInline (http://www.crexi.local:8080/vendor.js:83877:9)↵ at checkNoChangesNode (http://www.crexi.local:8080/vendor.js:83866:9)↵ at debugCheckNoChangesNode (http://www.crexi.local:8080/vendor.js:84470:24)↵ at debugCheckDirectivesFn (http://www.crexi.local:8080/vendor.js:84398:13)↵ at Object.eval [as updateDirectives] (ng:///SignInPageModule/SignInPageComponent.ngfactory.js:86:9)↵ at Object.debugUpdateDirectives [as updateDirectives] (http://www.crexi.local:8080/vendor.js:84387:21)↵ at checkNoChangesView (http://www.crexi.local:8080/vendor.js:83765:14)↵ at callViewAction (http://www.crexi.local:8080/vendor.js:84004:21)↵ at execComponentViewsAction (http://www.crexi.local:8080/vendor.js:83966:13)↵ at checkNoChangesView (http://www.crexi.local:8080/vendor.js:83768:5)↵ at callViewAction (http://www.crexi.local:8080/vendor.js:84004:21)↵ at execEmbeddedViewsAction (http://www.crexi.local:8080/vendor.js:83987:17)↵ at checkNoChangesView (http://www.crexi.local:8080/vendor.js:83766:5)↵ at callViewAction (http://www.crexi.local:8080/vendor.js:84004:21)↵ at execComponentViewsAction (http://www.crexi.local:8080/vendor.js:83966:13)↵ at checkNoChangesView (http://www.crexi.local:8080/vendor.js:83768:5)↵ at callWithDebugContext (http://www.crexi.local:8080/vendor.js:84653:25)↵ at Object.debugCheckNoChangesView [as checkNoChangesView] (http://www.crexi.local:8080/vendor.js:84358:12)↵ at ViewRef_.push../node_modules/@angular/core/fesm5/core.js.ViewRef_.checkNoChanges (http://www.crexi.local:8080/vendor.js:82172:64)↵ at http://www.crexi.local:8080/vendor.js:78597:67↵ at Array.forEach ()↵ at ApplicationRef.push../node_modules/@angular/core/fesm5/core.js.ApplicationRef.tick (http://www.crexi.local:8080/vendor.js:78597:29)↵ at http://www.crexi.local:8080/vendor.js:78486:105↵ at ZoneDelegate.push../node_modules/zone.js/dist/zone.js.ZoneDelegate.invoke (http://www.crexi.local:8080/polyfills.js:8609:26)↵ at Object.onInvoke (http://www.crexi.local:8080/vendor.js:77863:33)↵ at ZoneDelegate.push../node_modules/zone.js/dist/zone.js.ZoneDelegate.invoke (http://www.crexi.local:8080/polyfills.js:8608:32)↵ at Zone.push../node_modules/zone.js/dist/zone.js.Zone.run (http://www.crexi.local:8080/polyfills.js:8359:43)↵ at NgZone.push../node_modules/@angular/core/fesm5/core.js.NgZone.run (http://www.crexi.local:8080/vendor.js:77777:28)↵ at Object.next (http://www.crexi.local:8080/vendor.js:78486:81)↵ at SafeSubscriber.schedulerFn [as _next] (http://www.crexi.local:8080/vendor.js:74078:52)↵ at SafeSubscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.SafeSubscriber.__tryOrUnsub (http://www.crexi.local:8080/vendor.js:231893:16)↵ at SafeSubscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.SafeSubscriber.next (http://www.crexi.local:8080/vendor.js:231831:22)↵ at Subscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.Subscriber._next (http://www.crexi.local:8080/vendor.js:231774:26)↵ at Subscriber.push../node_modules/rxjs/_esm5/internal/Subscriber.js.Subscriber.next (http://www.crexi.local:8080/vendor.js:231751:18)↵ at EventEmitter.push../node_modules/rxjs/_esm5/internal/Subject.js.Subject.next (http://www.crexi.local:8080/vendor.js:231516:25)↵ at EventEmitter.push../node_modules/@angular/core/fesm5/core.js.EventEmitter.emit (http://www.crexi.local:8080/vendor.js:74062:76)↵ at checkStable (http://www.crexi.local:8080/vendor.js:77832:35)↵ at Object.onHasTask (http://www.crexi.local:8080/vendor.js:77876:21)↵ at ZoneDelegate.push../node_modules/zone.js/dist/zone.js.ZoneDelegate.hasTask (http://www.crexi.local:8080/polyfills.js:8662:37)↵ at ZoneDelegate.push../node_modules/zone.js/dist/zone.js.ZoneDelegate._updateTaskCount (http://www.crexi.local:8080/polyfills.js:8682:22)↵ at Zone.push../node_modules/zone.js/dist/zone.js.Zone._updateTaskCount (http://www.crexi.local:8080/polyfills.js:8506:34)↵ at Zone.push../node_modules/zone.js/dist/zone.js.Zone.runTask (http://www.crexi.local:8080/polyfills.js:8426:30)↵ at drainMicroTaskQueue (http://www.crexi.local:8080/polyfills.js:8816:35)"
I get the same error!
It seems that some really large environment extra arguments are causing this.
It was references to Angular classes for me.
Temporarily I have to reformat breadcrumbs to include only message, name and stack.
Sentry.init({
beforeBreadcrumb: (breadcrumb, hint) => {
if (breadcrumb.data && breadcrumb.data.extra && breadcrumb.data.extra.arguments) {
breadcrumb.data.extra.arguments = breadcrumb.data.extra.arguments.map((arg: any) => {
return {
message: arg.message,
name: arg.name,
stack: arg.stack
}
});
}
return breadcrumb;
}
});
I think these issues are related: https://github.com/getsentry/sentry-javascript/issues/1798
See comment: https://github.com/getsentry/sentry-javascript/issues/1798#issuecomment-454415368
4.5.2
has been released, this version should fix the issue. Closing this for now.
Works now, thank you
Issue is reproduced in version 4.6.3
(current version at the moment) in Angular project.
Call stack:
assign (object.js:194)
decycle (object.js:282)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
decycle (object.js:294)
(anonymous) (object.js:311)
safeNormalize (object.js:320)
push../node_modules/@sentry/hub/dist/scope.js.Scope.addBreadcrumb (scope.js:183)
push../node_modules/@sentry/core/dist/baseclient.js.BaseClient.addBreadcrumb (baseclient.js:180)
push../node_modules/@sentry/hub/dist/hub.js.Hub.invokeClient (hub.js:49)
push../node_modules/@sentry/hub/dist/hub.js.Hub.addBreadcrumb (hub.js:224)
push../node_modules/@sentry/browser/dist/index.js.Breadcrumbs.addBreadcrumb (index.js:3998)
(anonymous) (index.js:3715)
View_UserDropdownComponent_6 (UserDropdownComponent.html:25)
push../node_modules/@angular/core/fesm5/core.js.DebugContext_.logError (core.js:22708)
push../node_modules/@angular/core/fesm5/core.js.ErrorHandler.handleError (core.js:14624)
dispatchEvent (core.js:19105)
(anonymous) (core.js:19548)
(anonymous) (platform-browser.js:993)
sentryWrapped (index.js:3219)
push../node_modules/zone.js/dist/zone.js.ZoneDelegate.invokeTask (zone.js:421)
onInvokeTask (core.js:16126)
push../node_modules/zone.js/dist/zone.js.ZoneDelegate.invokeTask (zone.js:420)
push../node_modules/zone.js/dist/zone.js.Zone.runTask (zone.js:188)
push../node_modules/zone.js/dist/zone.js.ZoneTask.invokeTask (zone.js:496)
invokeTask (zone.js:1540)
globalZoneAwareCallback (zone.js:1566)
@HazAT I've checked, the latest workable version is 4.5.3
at the moment
@feorex Angular attaches debug context in their development environment which is enormous object. We found the issue and patched it. Release is processing now. Will ping you (few minutes) once it's up.
@feorex could you please give a 4.6.4
a try and let us know if everything is fixed for you?
@kamilogorek Just tried 4.6.4
, and I can confirm that issue is fixed for my case. Thank you very much for a quick fix!
Most helpful comment
Memory crash remains in 4.5.1 for me.
Now it's falling on safeNormalize
http://joxi.ru/GrqgYe3t4Gb1J2
Original error: