[
https://issues.apache.org/jira/browse/IGNITE-19279?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17711863#comment-17711863
]
Ignite TC Bot commented on IGNITE-19279:
----------------------------------------
{panel:title=Branch: [pull/10645/head] Base: [master] : No blockers
found!|borderStyle=dashed|borderColor=#ccc|titleBGColor=#D6F7C1}{panel}
{panel:title=Branch: [pull/10645/head] Base: [master] : New Tests
(2)|borderStyle=dashed|borderColor=#ccc|titleBGColor=#D6F7C1}
{color:#00008b}Thin Client: Java{color} [[tests
2|https://ci2.ignite.apache.org/viewLog.html?buildId=7136126]]
* {color:#013220}ClientTestSuite:
InactiveClusterCacheRequestTest.testCacheOperationReturnErrorOnInactiveCluster[partitionAwareness=false]
- PASSED{color}
* {color:#013220}ClientTestSuite:
InactiveClusterCacheRequestTest.testCacheOperationReturnErrorOnInactiveCluster[partitionAwareness=true]
- PASSED{color}
{panel}
[TeamCity *--> Run :: All*
Results|https://ci2.ignite.apache.org/viewLog.html?buildId=7135072&buildTypeId=IgniteTests24Java8_RunAll]
> AssertionError on client request to inactive cluster
> ----------------------------------------------------
>
> Key: IGNITE-19279
> URL: https://issues.apache.org/jira/browse/IGNITE-19279
> Project: Ignite
> Issue Type: Bug
> Reporter: Maksim Timonin
> Assignee: Maksim Timonin
> Priority: Major
> Labels: ise
> Time Spent: 40m
> Remaining Estimate: 0h
>
> AssertionError is raised for thin client cache operations on inactive
> cluster. For a such operation clients try to update affinity info. In
> inactive cluster the topology is not initialized (topVer=-1), and it fails
> while preparing cache partitions assignment:
>
>
> {code:java}
> java.lang.AssertionError: AffinityTopologyVersion [topVer=-1, minorTopVer=0]
> at
> org.apache.ignite.internal.processors.affinity.GridAffinityAssignmentCache.cachedAffinity(GridAffinityAssignmentCache.java:809)
> ~[classes/:?]
> at
> org.apache.ignite.internal.processors.cache.GridCacheAffinityManager.assignment(GridCacheAffinityManager.java:233)
> ~[classes/:?]
> at
> org.apache.ignite.internal.processors.cache.GridCacheAffinityManager.assignment(GridCacheAffinityManager.java:218)
> ~[classes/:?]
> at
> org.apache.ignite.internal.processors.platform.client.cache.ClientCachePartitionsRequest.getCacheAssignment(ClientCachePartitionsRequest.java:170)
> ~[classes/:?]
> at
> org.apache.ignite.internal.processors.platform.client.cache.ClientCachePartitionsRequest.processCache(ClientCachePartitionsRequest.java:144)
> ~[classes/:?]
> at
> org.apache.ignite.internal.processors.platform.client.cache.ClientCachePartitionsRequest.process(ClientCachePartitionsRequest.java:103)
> ~[classes/:?]
> at
> org.apache.ignite.internal.processors.platform.client.ClientRequestHandler.handle(ClientRequestHandler.java:101)
> ~[classes/:?]
> at
> org.apache.ignite.internal.processors.odbc.ClientListenerNioListener.onMessage(ClientListenerNioListener.java:204)
> ~[classes/:?]
> at
> org.apache.ignite.internal.processors.odbc.ClientListenerNioListener.onMessage(ClientListenerNioListener.java:55)
> ~[classes/:?]
> at
> org.apache.ignite.internal.util.nio.GridNioFilterChain$TailFilter.onMessageReceived(GridNioFilterChain.java:279)
> ~[classes/:?]
> at
> org.apache.ignite.internal.util.nio.GridNioFilterAdapter.proceedMessageReceived(GridNioFilterAdapter.java:109)
> ~[classes/:?]
> at
> org.apache.ignite.internal.util.nio.GridNioAsyncNotifyFilter$3.body(GridNioAsyncNotifyFilter.java:97)
> ~[classes/:?]
> at
> org.apache.ignite.internal.util.worker.GridWorker.run(GridWorker.java:125)
> ~[classes/:?]
> at
> org.apache.ignite.internal.util.worker.GridWorkerPool$1.run(GridWorkerPool.java:70)
> ~[classes/:?]
> at
> java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
> ~[?:1.8.0_322]
> at
> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
> ~[?:1.8.0_322]
> at java.lang.Thread.run(Thread.java:750) ~[?:1.8.0_322]
>
> {code}
>
> Reproducer:
>
>
>
> {code:java}
> package org.apache.ignite;
> import org.apache.ignite.client.IgniteClient;
> import org.apache.ignite.cluster.ClusterState;
> import org.apache.ignite.configuration.CacheConfiguration;
> import org.apache.ignite.configuration.ClientConfiguration;
> import org.apache.ignite.configuration.DataRegionConfiguration;
> import org.apache.ignite.configuration.DataStorageConfiguration;
> import org.apache.ignite.configuration.IgniteConfiguration;
> import org.apache.ignite.internal.IgniteEx;
> import org.apache.ignite.internal.client.thin.AbstractThinClientTest;
> import org.apache.ignite.internal.util.typedef.G;
> import org.junit.Test;
> /** */
> public class Reproducer extends AbstractThinClientTest {
> @Override protected IgniteConfiguration getConfiguration(String
> igniteInstanceName) throws Exception
> { IgniteConfiguration cfg = super.getConfiguration(igniteInstanceName);
> cfg.setDataStorageConfiguration(new DataStorageConfiguration()
> .setDefaultDataRegionConfiguration(new
> DataRegionConfiguration().setPersistenceEnabled(true)));
> cfg.setCacheConfiguration(new CacheConfiguration("default")); return cfg; }
> /** */
> @Test
> public void test() throws Exception {
> IgniteEx ign = startGrids(2);
> ign.cluster().state(ClusterState.ACTIVE);
> ClientConfiguration ccfg = getClientConfiguration(G.allGrids().toArray(new
> Ignite[]{}));
> stopAllGrids();
> startGrid(0);
> IgniteClient cln = Ignition.startClient(ccfg);
> cln.cache("default").get(0);
> }
> }
>
>
> {code}
>
--
This message was sent by Atlassian Jira
(v8.20.10#820010)