[jboss-jira] [JBoss JIRA] Created: (JBCACHE-1370) Objects retrieved using getObject() in a transaction that rollsback are unusable

Jason T. Greene (JIRA) jira-events at lists.jboss.org
Mon Jun 16 20:39:40 EDT 2008


Objects retrieved using getObject() in a transaction that rollsback are unusable
--------------------------------------------------------------------------------

                 Key: JBCACHE-1370
                 URL: http://jira.jboss.com/jira/browse/JBCACHE-1370
             Project: JBoss Cache
          Issue Type: Bug
      Security Level: Public (Everyone can see)
          Components: Legacy POJO Cache 
    Affects Versions: 1.4.1.SP9, 1.4.1.SP8, 1.4.1.SP7, 1.4.1.SP6, 1.4.1.SP5, 1.4.1.SP4, 1.4.1.SP3, 1.4.1.SP2, 1.4.1.SP1
            Reporter: Jason T. Greene
         Assigned To: Jason T. Greene
             Fix For: 1.4.X


POJO Cache 1.4.x adds interceptor changes during get operations to the undo list. This effectively prevents an object retrieved from a get() from being usable if a rollback occurs during the TX that contains the get. 

For this, and other reasons, get operations should never rollback interceptor additions.

Original report:

In my cluster i have 2 PojoCache (REPL_SYNC,inactive on startup,transcational,replication version 1.4.0.GA). First i create one cache and fill it with data, then i create the second cache and force full state transfer using region activation. On the second cache, after it received the state, in a new transaction, i fecth an object from the cache and modify a map it contains and then rollback the transaction. After the rollback, *all* the objects in the seconds cache are corrupted: all properties values are now null!, (the other cache is not corrupted). Note, when modifing a primitive property and then rollback, the cache is not corrupted. What i found is that in the corrupted objects, the instanceAdvisor appendedInterceptors list is missing the CacheInterceptor.

attached a unit test demonstrating this bug. The test is based on the distribution org.jboss.cache.aop.statetransfer.StateTransferAopTestBase unit test, to run it, add it to the distribution org.jboss.cache.aop.statetransfer tests package and run the tests.


-- 
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: http://jira.jboss.com/jira/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira

        



More information about the jboss-jira mailing list