Locking: RowAlreadyLockedException: Could not acquire lock

Description

Initial behaviour:
--------------------------------------------------------------
I have the kfz-DB and a window with a table and a formular.
I´m using the EXTRAS-Table.

I enable the lock in the formular.
Then i click on the 5th line in the table and I get the lock
for the record.
--------------------------------------------------------------

Real behaviour:
--------------------------------------------------------------
When I click in a second running program on the same record
an Exception is thrown:

xdev.db.locking.RowAlreadyLockedException: Could not acquire lock xdev.db.locking.HybridVirtualTabelLock$1@3a9d23c0
at xdev.db.locking.HybridVirtualTabelLock$1.write(HybridVirtualTabelLock.java:415)
at xdev.db.Transaction.execute(Transaction.java:89)
at xdev.db.locking.HybridVirtualTabelLock.getLock(HybridVirtualTabelLock.java:435)
at xdev.ui.XdevFormular.initLockingComponent(XdevFormular.java:1006)
at xdev.ui.XdevFormular.setModel(XdevFormular.java:941)
at xdev.ui.DefaultMasterDetailHandler$1.valueChanged(DefaultMasterDetailHandler.java:138)
at xdev.ui.TableSupport$1.valueChanged(TableSupport.java:1056)
at javax.swing.DefaultListSelectionModel.fireValueChanged(DefaultListSelectionModel.java:184)
at javax.swing.DefaultListSelectionModel.fireValueChanged(DefaultListSelectionModel.java:154)
at javax.swing.DefaultListSelectionModel.setValueIsAdjusting(DefaultListSelectionModel.java:685)
at javax.swing.plaf.basic.BasicTableUI$Handler.setValueIsAdjusting(BasicTableUI.java:953)
at javax.swing.plaf.basic.BasicTableUI$Handler.mouseReleased(BasicTableUI.java:1166)
at java.awt.AWTEventMulticaster.mouseReleased(AWTEventMulticaster.java:290)
at java.awt.Component.processMouseEvent(Component.java:6504)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3321)
at java.awt.Component.processEvent(Component.java:6269)
at java.awt.Container.processEvent(Container.java:2229)
at java.awt.Component.dispatchEventImpl(Component.java:4860)
at java.awt.Container.dispatchEventImpl(Container.java:2287)
at java.awt.Component.dispatchEvent(Component.java:4686)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422)
at java.awt.Container.dispatchEventImpl(Container.java:2273)
at java.awt.Window.dispatchEventImpl(Window.java:2713)
at java.awt.Component.dispatchEvent(Component.java:4686)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:707)
at java.awt.EventQueue.access$000(EventQueue.java:101)
at java.awt.EventQueue$3.run(EventQueue.java:666)
at java.awt.EventQueue$3.run(EventQueue.java:664)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87)
at java.awt.EventQueue$4.run(EventQueue.java:680)
at java.awt.EventQueue$4.run(EventQueue.java:678)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:677)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:211)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:128)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:117)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:113)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:105)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:90)

--------------------------------------------------------------

Expected behaviour:
--------------------------------------------------------------
No Exception is thrown. Only the formular is disabled until
the lock of the other is out of date.
--------------------------------------------------------------

Comment:
--------------------------------------------------------------

--------------------------------------------------------------

Environment

None

Activity

Show:
SS
December 19, 2013, 8:34 AM

The problem can not be reproduced with the new locking api.

Holger Lober
August 7, 2013, 11:50 AM
Edited

Start the Window LockingTest 2 Times (attached project).

Fixed

Assignee

JW

Reporter

Holger Lober

Labels

None

Epic/Theme

None

Affects versions

Priority

Major