[jira] [Created] (IGNITE-7166) SQL join with partition and replicated caches fails if number of partitions is too low.

classic Classic list List threaded Threaded
1 message Options
Reply | Threaded
Open this post in threaded view
|

[jira] [Created] (IGNITE-7166) SQL join with partition and replicated caches fails if number of partitions is too low.

Anton Vinogradov (Jira)
Alexei Scherbakov created IGNITE-7166:
-----------------------------------------

             Summary: SQL join with partition and replicated caches fails if number of partitions is too low.
                 Key: IGNITE-7166
                 URL: https://issues.apache.org/jira/browse/IGNITE-7166
             Project: Ignite
          Issue Type: Bug
    Affects Versions: 2.3
            Reporter: Alexei Scherbakov
             Fix For: 2.4


Reproducer:

{noformat}
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.apache.ignite.internal.processors.cache.distributed.replicated;

import java.util.List;
import org.apache.ignite.Ignite;
import org.apache.ignite.cache.affinity.rendezvous.RendezvousAffinityFunction;
import org.apache.ignite.cache.query.FieldsQueryCursor;
import org.apache.ignite.cache.query.SqlFieldsQuery;
import org.apache.ignite.cache.query.annotations.QuerySqlField;
import org.apache.ignite.configuration.CacheConfiguration;
import org.apache.ignite.configuration.IgniteConfiguration;
import org.apache.ignite.testframework.junits.common.GridCommonAbstractTest;

import static org.apache.ignite.cache.CacheAtomicityMode.TRANSACTIONAL;
import static org.apache.ignite.cache.CacheMode.PARTITIONED;
import static org.apache.ignite.cache.CacheMode.REPLICATED;
import static org.apache.ignite.cache.CacheWriteSynchronizationMode.FULL_SYNC;

/**
 * Tests non collocated join with replicated cache.
 */
public class IgniteCacheReplicatedJoinSelfTest extends GridCommonAbstractTest {
    /** */
    public static final String REP_CACHE_NAME = "repCache";

    /** */
    public static final String PART_CACHE_NAME = "partCache";

    /** */
    public static final int REP_CNT = 3;

    /** */
    public static final int PART_CNT = 10_000;

    /** {@inheritDoc} */
    @Override protected IgniteConfiguration getConfiguration(String igniteInstanceName) throws Exception {
        final IgniteConfiguration cfg = super.getConfiguration(igniteInstanceName);

        cfg.setClientMode("client".equals(igniteInstanceName));

        final CacheConfiguration ccfg1 = new CacheConfiguration(PART_CACHE_NAME);
        ccfg1.setCacheMode(PARTITIONED);
        ccfg1.setAtomicityMode(TRANSACTIONAL);
        ccfg1.setWriteSynchronizationMode(FULL_SYNC);
        ccfg1.setIndexedTypes(Integer.class, PartValue.class);

        final CacheConfiguration ccfg2 = new CacheConfiguration(REP_CACHE_NAME);
        ccfg2.setAffinity(new RendezvousAffinityFunction(false, REP_CNT));
        ccfg2.setCacheMode(REPLICATED);
        ccfg2.setAtomicityMode(TRANSACTIONAL);
        ccfg2.setWriteSynchronizationMode(FULL_SYNC);
        ccfg2.setIndexedTypes(Integer.class, RepValue.class);

        cfg.setCacheConfiguration(ccfg1, ccfg2);

        return cfg;
    }

    /**
     *
     * @throws Exception
     */
    public void testJoinNonCollocated() throws Exception {
        startGridsMultiThreaded(3);

        final Ignite client = startGrid("client");

        for (int i = 0; i < REP_CNT; i++)
            client.cache(REP_CACHE_NAME).put(i, new RepValue(i, "rep" + i));

        for (int i = 0; i < PART_CNT; i++)
            client.cache(PART_CACHE_NAME).put(i, new PartValue(i, "part" + i, ((i + 1) % REP_CNT)));

        final FieldsQueryCursor<List<?>> qry = client.cache(PART_CACHE_NAME).
            query(new SqlFieldsQuery("select PartValue._VAL, r._VAL from PartValue, \"repCache\".RepValue as r where PartValue.repId=r.id"));

        final List<List<?>> all = qry.getAll();

        assertEquals(10_000, all.size());

        for (List<?> objects : all) {
            final PartValue pv = (PartValue)objects.get(0);
            final RepValue rv = (RepValue)objects.get(1);

            assertNotNull(rv);

            assertEquals(rv.getId(), pv.getRepId());
        }
    }

    /** */
    public static class PartValue {
        /** Id. */
        @QuerySqlField
        private int id;

        /** Name. */
        @QuerySqlField
        private String name;

        /** Rep id. */
        @QuerySqlField
        private int repId;

        /**
         * @param id Id.
         * @param name Name.
         * @param repId Rep id.
         */
        public PartValue(int id, String name, int repId) {
            this.id = id;
            this.name = name;
            this.repId = repId;
        }

        /** */
        public int getId() {
            return id;
        }

        /** */
        public void setId(int id) {
            this.id = id;
        }

        /** */
        public String getName() {
            return name;
        }

        /** */
        public void setName(String name) {
            this.name = name;
        }

        /** */
        public int getRepId() {
            return repId;
        }

        /** */
        public void setRepId(int repId) {
            this.repId = repId;
        }
    }

    /** */
    public static class RepValue {
        /** Id. */
        @QuerySqlField
        private int id;

        /** Name. */
        @QuerySqlField
        private String name;

        /**
         * @param id Id.
         * @param name Name.
         */
        public RepValue(int id, String name) {
            this.id = id;
            this.name = name;
        }

        /** */
        public int getId() {
            return id;
        }

        /** */
        public void setId(int id) {
            this.id = id;
        }

        /** */
        public String getName() {
            return name;
        }

        /** */
        public void setName(String name) {
            this.name = name;
        }
    }
}
{noformat}



--
This message was sent by Atlassian JIRA
(v6.4.14#64029)