Some Eclipse Foundation services are deprecated, or will be soon. Please ensure you've read this important communication.

Bug 537510

Summary: Random application crash while drawing images on canvas
Product: [RT] RAP Reporter: Victor Kirhenshtein <victor>
Component: RWTAssignee: Project Inbox <rap-inbox>
Status: RESOLVED FIXED QA Contact:
Severity: major    
Priority: P3    
Version: 3.5   
Target Milestone: 3.6 M1   
Hardware: All   
OS: All   
See Also: https://git.eclipse.org/r/126885
https://git.eclipse.org/c/rap/org.eclipse.rap.git/commit/?id=53cb41d999603e4c0a35ec467e3d38d7222c64ed
Whiteboard:

Description Victor Kirhenshtein CLA 2018-07-30 13:38:29 EDT
After upgrading existing application to RAP 3.5 from 3.4 JavaScript part start to crash randomly with errors like this:

Error: Error: Operation "call" on target "w92.gc" of type "rwt.widgets.GC" failed:
A drawing is already suspended
Properties: 
operations = drawImage,rwt-resources/generated/303d1f9d.png,-253,-144,drawImage,rwt-resources/generated/6bb2d7cf.png,3,-144,drawImage,rwt-resources/generated/473dd95b.png,259,-144,drawImage,rwt-resources/generated/664cdb9b.png,515,-144,drawImage,rwt-resources/generated/5c19f470.png,771,-144,drawImage,rwt-resources/generated/9aa51654.png,1027,-144,drawImage,rwt-resources/generated/cc32e56e.png,1283,-144,drawImage,rwt-resources/generated/debee418.png,-253,112,drawImage,rwt-resources/generated/bc2433d6.png,3,112,drawImage,rwt-resources/generated/31adbb8e.png,259,112,drawImage,rwt-resources/generated/6f1b9f2f.png,515,112,drawImage,rwt-resources/generated/1da3f06c.png,771,112,drawImage,rwt-resources/generated/f1acef77.png,1027,112,drawImage,rwt-resources/generated/133e0aa0.png,1283,112,drawImage,rwt-resources/generated/53935a55.png,-253,368,drawImage,rwt-resources/generated/2e85d6dc.png,3,368,drawImage,rwt-resources/generated/88de5191.png,259,368,drawImage,rwt-resources/generated/6aef5ad4.png,515,368,drawImage,rwt-resources/generated/447c7c0d.png,771,368,drawImage,rwt-resources/generated/d31ac331.png,1027,368,drawImage,rwt-resources/generated/690df331.png,1283,368,drawImage,rwt-resources/generated/72717754.png,-253,624,drawImage,rwt-resources/generated/e1112ba2.png,3,624,drawImage,rwt-resources/generated/bcfdcb31.png,259,624,drawImage,rwt-resources/generated/c60725c3.png,515,624,drawImage,rwt-resources/generated/ab331e81.png,771,624,drawImage,rwt-resources/generated/86d5af69.png,1027,624,drawImage,rwt-resources/generated/42e2ecc2.png,1283,624,drawImage,rwt-resources/generated/8ca6bf20.png,-253,880,drawImage,rwt-resources/generated/139dfa07.png,3,880,drawImage,rwt-resources/generated/38671242.png,259,880,drawImage,rwt-resources/generated/a001aaaa.png,515,880,drawImage,rwt-resources/generated/c73bba9d.png,771,880,drawImage,rwt-resources/generated/1fcc0b2d.png,1027,880,drawImage,rwt-resources/generated/f525f1a9.png,1283,880,fillStyle,0,0,0,255,globalAlpha,0.5,beginPath,moveTo,1321,15,lineTo,1321,27,quadraticCurveTo,1321,32,1326,32,lineTo,1516,32,quadraticCurveTo,1521,32,1521,27,lineTo,1521,15,quadraticCurveTo,1521,10,1516,10,lineTo,1326,10,quadraticCurveTo,1321,10,1321,15,fill,globalAlpha,1,strokeStyle,255,255,255,255,strokeText,N 51° 05' 47.843" E 16° 44' 35.391",false,true,true,1326,14,font,Segoe UI,Liberation Sans,Verdana,Lucida Sans,Arial,Helvetica,sans-serif,15,true,false,globalAlpha,0.5,beginPath,moveTo,10,15,lineTo,10,68,quadraticCurveTo,10,73,15,73,lineTo,85,73,quadraticCurveTo,90,73,90,68,lineTo,90,15,quadraticCurveTo,90,10,85,10,lineTo,15,10,quadraticCurveTo,10,10,10,15,fill,globalAlpha,1,strokeText,6,false,true,true,46,15,drawImage,rwt-resources/generated/aac0c98b.png,15,36,drawImage,rwt-resources/generated/e43974a7.png,52,36


  Script: {"head":{},"operations":[["set","w31",{"bounds":[0,0,1920,20]}],["call","w92.gc","init",{"x":0,"y":0,"width":1531,"height":943,"font":[["Segoe UI","Liberation Sans","Verdana","Lucida Sans","Arial","Helvetica","sans-serif"],12,false,false],"fillStyle":[255,255,255,255],"strokeStyle":[74,74,74,255]}],["call","w92.gc","draw",{"operations":[["drawImage","rwt-resources/generated/303d1f9d.png",-253,-144],["drawImage","rwt-resources/generated/6bb2d7cf.png",3,-144],["drawImage","rwt-resources/generated/473dd95b.png",259,-144],["drawImage","rwt-resources/generated/664cdb9b.png",515,-144],["drawImage","rwt-resources/generated/5c19f470.png",771,-144],["drawImage","rwt-resources/generated/9aa51654.png",1027,-144],["drawImage","rwt-resources/generated/cc32e56e.png",1283,-144],["drawImage","rwt-resources/generated/debee418.png",-253,112],["drawImage","rwt-resources/generated/bc2433d6.png",3,112],["drawImage","rwt-resources/generated/31adbb8e.png",259,112],["drawImage","rwt-resources/generated/6f1b9f2f.png",515,112],["drawImage","rwt-resources/generated/1da3f06c.png",771,112],["drawImage","rwt-resources/generated/f1acef77.png",1027,112],["drawImage","rwt-resources/generated/133e0aa0.png",1283,112],["drawImage","rwt-resources/generated/53935a55.png",-253,368],["drawImage","rwt-resources/generated/2e85d6dc.png",3,368],["drawImage","rwt-resources/generated/88de5191.png",259,368],["drawImage","rwt-resources/generated/6aef5ad4.png",515,368],["drawImage","rwt-resources/generated/447c7c0d.png",771,368],["drawImage","rwt-resources/generated/d31ac331.png",1027,368],["drawImage","rwt-resources/generated/690df331.png",1283,368],["drawImage","rwt-resources/generated/72717754.png",-253,624],["drawImage","rwt-resources/generated/e1112ba2.png",3,624],["drawImage","rwt-resources/generated/bcfdcb31.png",259,624],["drawImage","rwt-resources/generated/c60725c3.png",515,624],["drawImage","rwt-resources/generated/ab331e81.png",771,624],["drawImage","rwt-resources/generated/86d5af69.png",1027,624],["drawImage","rwt-resources/generated/42e2ecc2.png",1283,624],["drawImage","rwt-resources/generated/8ca6bf20.png",-253,880],["drawImage","rwt-resources/generated/139dfa07.png",3,880],["drawImage","rwt-resources/generated/38671242.png",259,880],["drawImage","rwt-resources/generated/a001aaaa.png",515,880],["drawImage","rwt-resources/generated/c73bba9d.png",771,880],["drawImage","rwt-resources/generated/1fcc0b2d.png",1027,880],["drawImage","rwt-resources/generated/f525f1a9.png",1283,880],["fillStyle",[0,0,0,255]],["globalAlpha",0.5],["beginPath"],["moveTo",1321,15],["lineTo",1321,27],["quadraticCurveTo",1321,32,1326,32],["lineTo",1516,32],["quadraticCurveTo",1521,32,1521,27],["lineTo",1521,15],["quadraticCurveTo",1521,10,1516,10],["lineTo",1326,10],["quadraticCurveTo",1321,10,1321,15],["fill"],["globalAlpha",1],["strokeStyle",[255,255,255,255]],["strokeText","N 51° 05' 47.843\" E 16° 44' 35.391\"",false,true,true,1326,14],["font",[["Segoe UI","Liberation Sans","Verdana","Lucida Sans","Arial","Helvetica","sans-serif"],15,true,false]],["globalAlpha",0.5],["beginPath"],["moveTo",10,15],["lineTo",10,68],["quadraticCurveTo",10,73,15,73],["lineTo",85,73],["quadraticCurveTo",90,73,90,68],["lineTo",90,15],["quadraticCurveTo",90,10,85,10],["lineTo",15,10],["quadraticCurveTo",10,10,10,15],["fill"],["globalAlpha",1],["strokeText","6",false,true,true,46,15],["drawImage","rwt-resources/generated/aac0c98b.png",15,36],["drawImage","rwt-resources/generated/e43974a7.png",52,36]]}]]}
  Stack: Error: Operation "call" on target "w92.gc" of type "rwt.widgets.GC" failed:
A drawing is already suspended
Properties: 
operations = drawImage,rwt-resources/generated/303d1f9d.png,-253,-144,drawImage,rwt-resources/generated/6bb2d7cf.png,3,-144,drawImage,rwt-resources/generated/473dd95b.png,259,-144,drawImage,rwt-resources/generated/664cdb9b.png,515,-144,drawImage,rwt-resources/generated/5c19f470.png,771,-144,drawImage,rwt-resources/generated/9aa51654.png,1027,-144,drawImage,rwt-resources/generated/cc32e56e.png,1283,-144,drawImage,rwt-resources/generated/debee418.png,-253,112,drawImage,rwt-resources/generated/bc2433d6.png,3,112,drawImage,rwt-resources/generated/31adbb8e.png,259,112,drawImage,rwt-resources/generated/6f1b9f2f.png,515,112,drawImage,rwt-resources/generated/1da3f06c.png,771,112,drawImage,rwt-resources/generated/f1acef77.png,1027,112,drawImage,rwt-resources/generated/133e0aa0.png,1283,112,drawImage,rwt-resources/generated/53935a55.png,-253,368,drawImage,rwt-resources/generated/2e85d6dc.png,3,368,drawImage,rwt-resources/generated/88de5191.png,259,368,drawImage,rwt-resources/generated/6aef5ad4.png,515,368,drawImage,rwt-resources/generated/447c7c0d.png,771,368,drawImage,rwt-resources/generated/d31ac331.png,1027,368,drawImage,rwt-resources/generated/690df331.png,1283,368,drawImage,rwt-resources/generated/72717754.png,-253,624,drawImage,rwt-resources/generated/e1112ba2.png,3,624,drawImage,rwt-resources/generated/bcfdcb31.png,259,624,drawImage,rwt-resources/generated/c60725c3.png,515,624,drawImage,rwt-resources/generated/ab331e81.png,771,624,drawImage,rwt-resources/generated/86d5af69.png,1027,624,drawImage,rwt-resources/generated/42e2ecc2.png,1283,624,drawImage,rwt-resources/generated/8ca6bf20.png,-253,880,drawImage,rwt-resources/generated/139dfa07.png,3,880,drawImage,rwt-resources/generated/38671242.png,259,880,drawImage,rwt-resources/generated/a001aaaa.png,515,880,drawImage,rwt-resources/generated/c73bba9d.png,771,880,drawImage,rwt-resources/generated/1fcc0b2d.png,1027,880,drawImage,rwt-resources/generated/f525f1a9.png,1283,880,fillStyle,0,0,0,255,globalAlpha,0.5,beginPath,moveTo,1321,15,lineTo,1321,27,quadraticCurveTo,1321,32,1326,32,lineTo,1516,32,quadraticCurveTo,1521,32,1521,27,lineTo,1521,15,quadraticCurveTo,1521,10,1516,10,lineTo,1326,10,quadraticCurveTo,1321,10,1321,15,fill,globalAlpha,1,strokeStyle,255,255,255,255,strokeText,N 51° 05' 47.843" E 16° 44' 35.391",false,true,true,1326,14,font,Segoe UI,Liberation Sans,Verdana,Lucida Sans,Arial,Helvetica,sans-serif,15,true,false,globalAlpha,0.5,beginPath,moveTo,10,15,lineTo,10,68,quadraticCurveTo,10,73,15,73,lineTo,85,73,quadraticCurveTo,90,73,90,68,lineTo,90,15,quadraticCurveTo,90,10,85,10,lineTo,15,10,quadraticCurveTo,10,10,10,15,fill,globalAlpha,1,strokeText,6,false,true,true,46,15,drawImage,rwt-resources/generated/aac0c98b.png,15,36,drawImage,rwt-resources/generated/e43974a7.png,52,36

    at Object._processError (http://127.0.0.1:10080/rwt-resources/350/rap-client.js:62649:11)
    at Object.processOperationArray (http://127.0.0.1:10080/rwt-resources/350/rap-client.js:62488:12)
    at Object.processMessage (http://127.0.0.1:10080/rwt-resources/350/rap-client.js:62440:12)
    at Object._handleSuccess (http://127.0.0.1:10080/rwt-resources/350/rap-client.js:63118:19)
    at rwt.remote.Request._success (http://127.0.0.1:10080/rwt-resources/350/rap-client.js:31567:41)
    at rwt.remote.Request._onReadyStateChange (http://127.0.0.1:10080/rwt-resources/350/rap-client.js:31604:16)
    at XMLHttpRequest. (http://127.0.0.1:10080/rwt-resources/350/rap-client.js:624:17)
  Debug: on
  Request: {"head":{"requestCounter":163},"operations":[["set","w1",{"cursorLocation":[1294,463]}]]}
Comment 1 Ivan Furnadjiev CLA 2018-08-01 06:21:48 EDT
In RAP 3.5 we introduce a change (https://git.eclipse.org/r/#/c/121339/) to fix the order of drawing images. It seems that this change cause your problem. Is it possible for you to create a simple entry point to reproduce the crash?
Comment 2 Eclipse Genie CLA 2018-08-01 06:59:33 EDT
New Gerrit change created: https://git.eclipse.org/r/126885
Comment 3 Ivan Furnadjiev CLA 2018-08-01 07:00:22 EDT
Victor, please give the above change a try. Does it fix your issue?
Comment 4 Victor Kirhenshtein CLA 2018-08-01 07:20:44 EDT
Looks like this change fixed the crash. View that was causing almost immediate crash works stable now.
Comment 5 Ivan Furnadjiev CLA 2018-08-01 07:58:51 EDT
Perfect!