Uploaded image for project: 'Ignite'
  1. Ignite
  2. IGNITE-23681

Disallow IgniteCache#removeAll inside transaction

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Resolved
    • Major
    • Resolution: Fixed
    • None
    • 2.18
    • None
    • Forbid a non-transactional IgniteCache#removeAll() inside a transaction
    • Release Notes Required

    Description

      `IgniteCache#removeAll` invocation are not transactional.
      But, currently, Ignite allow to invoke `removeAll` inside transaction.
      This lead to unexpected behavior and hides business logic errors.

      We must disallow IgniteCache#removeAll call inside transaction.

      /** */
      @Test
      public void testClearInTransction() {
          IgniteCache<Object, Object> cache = client.createCache(new CacheConfiguration<>("my-cache").setAtomicityMode(CacheAtomicityMode.TRANSACTIONAL));
          cache.put(1, 1);
          try (Transaction tx = client.transactions().txStart(TransactionConcurrency.PESSIMISTIC, TransactionIsolation.READ_COMMITTED)) {
              cache.put(2, 2);
              cache.removeAll();
              tx.commit();
          }
          assertFalse(cache.containsKey(1));
          assertTrue(cache.containsKey(2));
      }
      

      Attachments

        Issue Links

          Activity

            People

              julia_bakulina Julia Bakulina
              julia_bakulina Julia Bakulina
              Maksim Timonin Maksim Timonin
              Votes:
              0 Vote for this issue
              Watchers:
              3 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved:

                Time Tracking

                  Estimated:
                  Original Estimate - Not Specified
                  Not Specified
                  Remaining:
                  Remaining Estimate - 0h
                  0h
                  Logged:
                  Time Spent - 3h
                  3h