/* * Licensed to Elasticsearch under one or more contributor * license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright * ownership. Elasticsearch 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.elasticsearch.routing; import org.elasticsearch.action.admin.indices.alias.IndicesAliasesRequest.AliasActions; import org.elasticsearch.action.support.IndicesOptions; import org.elasticsearch.cluster.ClusterState; import org.elasticsearch.cluster.metadata.IndexNameExpressionResolver; import org.elasticsearch.common.Priority; import org.elasticsearch.test.ESIntegTestCase; import java.util.HashMap; import java.util.Map; import java.util.Set; import java.util.concurrent.ExecutionException; import static org.elasticsearch.common.util.set.Sets.newHashSet; import static org.elasticsearch.index.query.QueryBuilders.matchQuery; import static org.elasticsearch.index.query.QueryBuilders.queryStringQuery; import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertHitCount; import static org.hamcrest.Matchers.equalTo; import static org.hamcrest.Matchers.nullValue; public class AliasResolveRoutingIT extends ESIntegTestCase { // see https://github.com/elastic/elasticsearch/issues/13278 public void testSearchClosedWildcardIndex() throws ExecutionException, InterruptedException { createIndex("test-0"); createIndex("test-1"); ensureGreen(); client().admin().indices().prepareAliases().addAlias("test-0", "alias-0").addAlias("test-1", "alias-1").get(); client().admin().indices().prepareClose("test-1").get(); indexRandom(true, client().prepareIndex("test-0", "type1", "1").setSource("field1", "the quick brown fox jumps"), client().prepareIndex("test-0", "type1", "2").setSource("field1", "quick brown"), client().prepareIndex("test-0", "type1", "3").setSource("field1", "quick")); refresh("test-*"); assertHitCount(client().prepareSearch().setIndices("alias-*").setIndicesOptions(IndicesOptions.lenientExpandOpen()).setQuery(queryStringQuery("quick")).get(), 3L); } public void testResolveIndexRouting() throws Exception { createIndex("test1"); createIndex("test2"); client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setWaitForGreenStatus().execute().actionGet(); client().admin().indices().prepareAliases() .addAliasAction(AliasActions.add().index("test1").alias("alias")) .addAliasAction(AliasActions.add().index("test1").alias("alias10").routing("0")) .addAliasAction(AliasActions.add().index("test1").alias("alias110").searchRouting("1,0")) .addAliasAction(AliasActions.add().index("test1").alias("alias12").routing("2")) .addAliasAction(AliasActions.add().index("test2").alias("alias20").routing("0")) .addAliasAction(AliasActions.add().index("test2").alias("alias21").routing("1")) .addAliasAction(AliasActions.add().index("test1").alias("alias0").routing("0")) .addAliasAction(AliasActions.add().index("test2").alias("alias0").routing("0")).get(); assertThat(clusterService().state().metaData().resolveIndexRouting(null, null, "test1"), nullValue()); assertThat(clusterService().state().metaData().resolveIndexRouting(null, null, "alias"), nullValue()); assertThat(clusterService().state().metaData().resolveIndexRouting(null, null, "test1"), nullValue()); assertThat(clusterService().state().metaData().resolveIndexRouting(null, null, "alias10"), equalTo("0")); assertThat(clusterService().state().metaData().resolveIndexRouting(null, null, "alias20"), equalTo("0")); assertThat(clusterService().state().metaData().resolveIndexRouting(null, null, "alias21"), equalTo("1")); assertThat(clusterService().state().metaData().resolveIndexRouting(null, "3", "test1"), equalTo("3")); assertThat(clusterService().state().metaData().resolveIndexRouting(null, "0", "alias10"), equalTo("0")); // Force the alias routing and ignore the parent. assertThat(clusterService().state().metaData().resolveIndexRouting("1", null, "alias10"), equalTo("0")); try { clusterService().state().metaData().resolveIndexRouting(null, "1", "alias10"); fail("should fail"); } catch (IllegalArgumentException e) { // all is well, we can't have two mappings, one provided, and one in the alias } try { clusterService().state().metaData().resolveIndexRouting(null, null, "alias0"); fail("should fail"); } catch (IllegalArgumentException ex) { // Expected } } public void testResolveSearchRouting() throws Exception { createIndex("test1"); createIndex("test2"); client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setWaitForGreenStatus().execute().actionGet(); client().admin().indices().prepareAliases() .addAliasAction(AliasActions.add().index("test1").alias("alias")) .addAliasAction(AliasActions.add().index("test1").alias("alias10").routing("0")) .addAliasAction(AliasActions.add().index("test2").alias("alias20").routing("0")) .addAliasAction(AliasActions.add().index("test2").alias("alias21").routing("1")) .addAliasAction(AliasActions.add().index("test1").alias("alias0").routing("0")) .addAliasAction(AliasActions.add().index("test2").alias("alias0").routing("0")).get(); ClusterState state = clusterService().state(); IndexNameExpressionResolver indexNameExpressionResolver = internalCluster().getInstance(IndexNameExpressionResolver.class); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, null, "alias"), nullValue()); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, "0,1", "alias"), equalTo(newMap("test1", newSet("0", "1")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, null, "alias10"), equalTo(newMap("test1", newSet("0")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, null, "alias10"), equalTo(newMap("test1", newSet("0")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, "0", "alias10"), equalTo(newMap("test1", newSet("0")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, "1", "alias10"), nullValue()); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, null, "alias0"), equalTo(newMap("test1", newSet("0"), "test2", newSet("0")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, null, new String[]{"alias10", "alias20"}), equalTo(newMap("test1", newSet("0"), "test2", newSet("0")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, null, new String[]{"alias10", "alias21"}), equalTo(newMap("test1", newSet("0"), "test2", newSet("1")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, null, new String[]{"alias20", "alias21"}), equalTo(newMap("test2", newSet("0", "1")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, null, new String[]{"test1", "alias10"}), nullValue()); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, null, new String[]{"alias10", "test1"}), nullValue()); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, "0", new String[]{"alias10", "alias20"}), equalTo(newMap("test1", newSet("0"), "test2", newSet("0")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, "0,1", new String[]{"alias10", "alias20"}), equalTo(newMap("test1", newSet("0"), "test2", newSet("0")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, "1", new String[]{"alias10", "alias20"}), nullValue()); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, "0", new String[]{"alias10", "alias21"}), equalTo(newMap("test1", newSet("0")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, "1", new String[]{"alias10", "alias21"}), equalTo(newMap("test2", newSet("1")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, "0,1,2", new String[]{"alias10", "alias21"}), equalTo(newMap("test1", newSet("0"), "test2", newSet("1")))); assertThat(indexNameExpressionResolver.resolveSearchRouting(state, "0,1,2", new String[]{"test1", "alias10", "alias21"}), equalTo(newMap("test1", newSet("0", "1", "2"), "test2", newSet("1")))); } private <T> Set<T> newSet(T... elements) { return newHashSet(elements); } private <K, V> Map<K, V> newMap(K key, V value) { Map<K, V> r = new HashMap<>(); r.put(key, value); return r; } private <K, V> Map<K, V> newMap(K key1, V value1, K key2, V value2) { Map<K, V> r = new HashMap<>(); r.put(key1, value1); r.put(key2, value2); return r; } }