Workspace move in concurrent environment causes inconsistencies
---------------------------------------------------------------
Key: JCR-3292
URL: https://issues.apache.org/jira/browse/JCR-3292
Project: Jackrabbit Content Repository
Issue Type: Bug
Affects Versions: 2.4, 2.2.11
Reporter: Unico Hommes
Attachments: WorkspaceMoveTest.patch
Attached is a test case that shows that using workspace move concurrent with
other write operations causes inconsistencies.
The problem is that unlike session move, workspace move operates on the local
item state directly (session move operates on transient item state). When a
concurrent modification occurs on for instance the source parent of the moved
target the modification that the move operation was trying to do is overwritten
as the changes from the concurrent session are pulled in:
- on thread 1 a workspace.move is initiated on /folder1/node to /folder2/node,
removing the child node entry from /folder1 a.o.t.
- session 2 on thread 2 modifies and saves /folder1, overwriting the changes on
the local item state of /folder1 in session 1
- thread 1, still in the workspace move operation, sends the updates to the
shared item state manager
I don't see any easy fixes for this problem. Probably the design of the
BatchedItemOperation needs to modified quite a bit.
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators:
https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira