FSchumacher opened a new pull request, #5870:
URL: https://github.com/apache/jmeter/pull/5870

   ## Description
   
   Place code, that acts on live AWT components into the AWT thread.
   
   Simplify code, that used recursion to set input parameters. Saw this one, 
while looking at the code, that was potentially in the wrong thread.
   
   ## Motivation and Context
   
   Try to overcome a deadlock in test suite
       
   When running locally, I observed the following deadlock:
       
       "AWT-EventQueue-1" #23 prio=6 os_prio=0 tid=0x00007f3de9bf6800 
nid=0x722b2 waiting for monitor entry [0x00007f3dcb4ee000]
          java.lang.Thread.State: BLOCKED (on object monitor)
               at 
java.awt.Component$AccessibleAWTComponent.getLocationOnScreen(Component.java:9494)
               - waiting to lock <0x00000000e0653ef0> (a 
java.awt.Component$AWTTreeLock)
               at 
javax.swing.JComponent$AccessibleJComponent.getLocationOnScreen(JComponent.java:3663)
               at 
javax.swing.text.JTextComponent$AccessibleJTextComponent.<init>(JTextComponent.java:2516)
               at 
javax.swing.JEditorPane$AccessibleJEditorPane.<init>(JEditorPane.java:1644)
               at 
javax.swing.JEditorPane$JEditorPaneAccessibleHypertextSupport.<init>(JEditorPane.java:1971)
               at 
javax.swing.JEditorPane$AccessibleJEditorPaneHTML.getAccessibleText(JEditorPane.java:1703)
               at 
org.GNOME.Accessibility.AtkObject.lambda$getTFlagFromObj$0(AtkObject.java:70)
               at 
org.GNOME.Accessibility.AtkObject$$Lambda$317/331870887.call(Unknown Source)
               at org.GNOME.Accessibility.AtkUtil.invokeInSwing(AtkUtil.java:58)
               at 
org.GNOME.Accessibility.AtkObject.getTFlagFromObj(AtkObject.java:55)
               at org.GNOME.Accessibility.AtkWrapper.boundsChanged(Native 
Method)
               at 
org.GNOME.Accessibility.AtkWrapper$3.componentResized(AtkWrapper.java:235)
               at 
java.awt.AWTEventMulticaster.componentResized(AWTEventMulticaster.java:159)
               at java.awt.Component.processComponentEvent(Component.java:6365)
               at java.awt.Component.processEvent(Component.java:6319)
               at java.awt.Container.processEvent(Container.java:2239)
               at java.awt.Component.dispatchEventImpl(Component.java:4889)
               at java.awt.Container.dispatchEventImpl(Container.java:2297)
               at java.awt.Component.dispatchEvent(Component.java:4711)
               at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:760)
               at java.awt.EventQueue.access$500(EventQueue.java:97)
               at java.awt.EventQueue$3.run(EventQueue.java:709)
               at java.awt.EventQueue$3.run(EventQueue.java:703)
               at java.security.AccessController.doPrivileged(Native Method)
               at 
java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:74)
               at 
java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:84)
               at java.awt.EventQueue$4.run(EventQueue.java:733)
               at java.awt.EventQueue$4.run(EventQueue.java:731)
               at java.security.AccessController.doPrivileged(Native Method)
               at 
java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:74)
               at java.awt.EventQueue.dispatchEvent(EventQueue.java:730)
               at 
org.GNOME.Accessibility.AtkWrapper$6.dispatchEvent(AtkWrapper.java:717)
               at 
java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:205)
               at 
java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:116)
               at 
java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:105)
               at 
java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101)
               at 
java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93)
               at java.awt.EventDispatchThread.run(EventDispatchThread.java:82)
       
       "Test worker" #1 prio=5 os_prio=0 tid=0x00007f3de8012000 nid=0x7228f 
waiting on condition [0x00007f3def695000]
          java.lang.Thread.State: WAITING (parking)
               at sun.misc.Unsafe.park(Native Method)
               - parking to wait for  <0x00000000f80386a8> (a 
java.util.concurrent.FutureTask)
               at 
java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
               at java.util.concurrent.FutureTask.awaitDone(FutureTask.java:429)
               at java.util.concurrent.FutureTask.get(FutureTask.java:191)
               at org.GNOME.Accessibility.AtkUtil.invokeInSwing(AtkUtil.java:68)
               at org.GNOME.Accessibility.AtkObject.hashCode(AtkObject.java:234)
               at org.GNOME.Accessibility.AtkWrapper.emitSignal(Native Method)
               at 
org.GNOME.Accessibility.AtkWrapper$5.propertyChange(AtkWrapper.java:557)
               at 
java.beans.PropertyChangeSupport.fire(PropertyChangeSupport.java:335)
               at 
java.beans.PropertyChangeSupport.firePropertyChange(PropertyChangeSupport.java:327)
               at 
java.beans.PropertyChangeSupport.firePropertyChange(PropertyChangeSupport.java:263)
               at 
javax.accessibility.AccessibleContext.firePropertyChange(AccessibleContext.java:768)
               at 
javax.swing.JScrollPane$AccessibleJScrollPane.stateChanged(JScrollPane.java:1506)
               at javax.swing.JViewport.fireStateChanged(JViewport.java:1369)
               at javax.swing.JViewport.reshape(JViewport.java:839)
               at java.awt.Component.setBounds(Component.java:2261)
               at java.awt.Component.setBounds(Component.java:2405)
               at 
javax.swing.ScrollPaneLayout.layoutContainer(ScrollPaneLayout.java:890)
               at java.awt.Container.layout(Container.java:1513)
               at java.awt.Container.doLayout(Container.java:1502)
               at java.awt.Container.validateTree(Container.java:1698)
               at java.awt.Container.validateTree(Container.java:1707)
               at java.awt.Container.validateTree(Container.java:1707)
               at java.awt.Container.validateTree(Container.java:1707)
               at java.awt.Container.validateTree(Container.java:1707)
               at java.awt.Container.validate(Container.java:1633)
               - locked <0x00000000e0653ef0> (a java.awt.Component$AWTTreeLock)
               at 
org.apache.jorphan.gui.ComponentUtil.centerComponentInWindow(ComponentUtil.java:67)
               at 
org.apache.jorphan.gui.ComponentUtil.centerComponentInWindow(ComponentUtil.java:54)
               at 
org.apache.jmeter.gui.action.SelectTemplatesDialog.init(SelectTemplatesDialog.java:263)
               at 
org.apache.jmeter.gui.action.SelectTemplatesDialog.<init>(SelectTemplatesDialog.java:105)
               at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native 
Method)
               at 
sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
               at 
sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
               at 
java.lang.reflect.Constructor.newInstance(Constructor.java:423)
               at 
org.apache.jmeter.junit.JMeterTest.instantiateClass(JMeterTest.java:512)
               at 
org.apache.jmeter.junit.JMeterTest.getObjects(JMeterTest.java:474)
               at 
org.apache.jmeter.junit.JMeterTest.suiteSerializableElements(JMeterTest.java:407)
               at org.apache.jmeter.junit.JMeterTest.suite(JMeterTest.java:149)
               at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
               at 
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
               at 
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
               at java.lang.reflect.Method.invoke(Method.java:498)
               at 
org.junit.internal.runners.SuiteMethod.testFromSuiteMethod(SuiteMethod.java:35)
       
   I hope to get rid of this by placing the code to center the newly created 
dialog
   in the AWT thread.
       
   I believe the deadlock happens only in our test code, when the dialog is 
created
   and instantaneously destroyed.
   
   ## How Has This Been Tested?
   
   Ran the tests a few time and looked at the GUI.
   
   ## Types of changes
   - Bug fix (non-breaking change which fixes an issue)
   
   ## Checklist:
   <!--- Go over all the following points, and put an `x` in all the boxes that 
apply. -->
   <!--- If you're unsure about any of these, don't hesitate to ask. We're here 
to help! -->
   - [x] My code follows the [code style][style-guide] of this project.
   
   [style-guide]: https://wiki.apache.org/jmeter/CodeStyleGuidelines
   


-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: dev-unsubscr...@jmeter.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org

Reply via email to