Skip to content

Commit

Permalink
Adds index and query BWC tests for missing engines (#2035)
Browse files Browse the repository at this point in the history
This is done to make sure that KNN80DocsValueConsumer code path is hit

Signed-off-by: Tejas Shah <[email protected]>
  • Loading branch information
shatejas authored Sep 11, 2024
1 parent 0c79147 commit e320026
Show file tree
Hide file tree
Showing 3 changed files with 84 additions and 16 deletions.
15 changes: 15 additions & 0 deletions qa/restart-upgrade/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ testClusters {
}
}

def versionsBelow2_3 = ["1.", "2.0.", "2.1.", "2.2."]
// Task to run BWC tests against the old cluster
task testAgainstOldCluster(type: StandaloneRestIntegTestTask) {
dependsOn "zipBwcPlugin"
Expand Down Expand Up @@ -89,6 +90,13 @@ testClusters {
}
}

if (versionsBelow2_3.any {knn_bwc_version.startsWith(it) }) {
filter {
excludeTestsMatching "org.opensearch.knn.bwc.QueryANNIT.testQueryOnLuceneIndex"
excludeTestsMatching "org.opensearch.knn.bwc.IndexingIT.testKNNIndexLuceneForceMerge"
}
}

nonInputProperties.systemProperty('tests.rest.cluster', "${-> testClusters."${baseName}".allHttpSocketURI.join(",")}")
nonInputProperties.systemProperty('tests.clustername', "${-> testClusters."${baseName}".getName()}")
systemProperty 'tests.security.manager', 'false'
Expand Down Expand Up @@ -155,6 +163,13 @@ testClusters {
}
}

if (versionsBelow2_3.any {knn_bwc_version.startsWith(it) }) {
filter {
excludeTestsMatching "org.opensearch.knn.bwc.QueryANNIT.testQueryOnLuceneIndex"
excludeTestsMatching "org.opensearch.knn.bwc.IndexingIT.testKNNIndexLuceneForceMerge"
}
}

nonInputProperties.systemProperty('tests.rest.cluster', "${-> testClusters."${baseName}".allHttpSocketURI.join(",")}")
nonInputProperties.systemProperty('tests.clustername', "${-> testClusters."${baseName}".getName()}")
systemProperty 'tests.security.manager', 'false'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import static org.opensearch.knn.common.KNNConstants.FAISS_NAME;
import static org.opensearch.knn.common.KNNConstants.KNN_ENGINE;
import static org.opensearch.knn.common.KNNConstants.KNN_METHOD;
import static org.opensearch.knn.common.KNNConstants.LUCENE_NAME;
import static org.opensearch.knn.common.KNNConstants.METHOD_HNSW;
import static org.opensearch.knn.common.KNNConstants.METHOD_PARAMETER_EF_CONSTRUCTION;
import static org.opensearch.knn.common.KNNConstants.METHOD_PARAMETER_EF_SEARCH;
Expand Down Expand Up @@ -51,7 +52,7 @@ public void testKNNIndexDefaultLegacyFieldMapping() throws Exception {
createKnnIndex(testIndex, getKNNDefaultIndexSettings(), createKnnIndexMapping(TEST_FIELD, DIMENSIONS));
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, DOC_ID, NUM_DOCS);
} else {
validateKNNIndexingOnUpgrade();
validateKNNIndexingOnUpgrade(NUM_DOCS);
}
}

Expand All @@ -65,8 +66,37 @@ public void testKNNIndexDefaultLegacyFieldMappingForceMerge() throws Exception {
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, DOC_ID, 100);
// Flush to ensure that index is not re-indexed when node comes back up
flush(testIndex, true);
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, 100, K);
} else {
forceMergeKnnIndex(testIndex);
validateKNNIndexingOnUpgrade(100);
}
}

public void testKNNIndexFaissForceMerge() throws Exception {
waitForClusterHealthGreen(NODES_BWC_CLUSTER);

if (isRunningAgainstOldCluster()) {
createKnnIndex(testIndex, getKNNDefaultIndexSettings(), createKnnIndexMapping(TEST_FIELD, DIMENSIONS, METHOD_HNSW, FAISS_NAME));
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, DOC_ID, 100);
// Flush to ensure that index is not re-indexed when node comes back up
flush(testIndex, true);
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, 100, K);
} else {
validateKNNIndexingOnUpgrade(100);
}
}

public void testKNNIndexLuceneForceMerge() throws Exception {
waitForClusterHealthGreen(NODES_BWC_CLUSTER);

if (isRunningAgainstOldCluster()) {
createKnnIndex(testIndex, getKNNDefaultIndexSettings(), createKnnIndexMapping(TEST_FIELD, DIMENSIONS, METHOD_HNSW, LUCENE_NAME));
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, DOC_ID, 100);
// Flush to ensure that index is not re-indexed when node comes back up
flush(testIndex, true);
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, 100, K);
} else {
validateKNNIndexingOnUpgrade(100);
}
}

Expand Down Expand Up @@ -115,7 +145,7 @@ public void testKNNIndexCustomLegacyFieldMapping() throws Exception {
);
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, DOC_ID, NUM_DOCS);
} else {
validateKNNIndexingOnUpgrade();
validateKNNIndexingOnUpgrade(NUM_DOCS);
}
}

Expand All @@ -126,7 +156,7 @@ public void testKNNIndexDefaultMethodFieldMapping() throws Exception {
createKnnIndex(testIndex, getKNNDefaultIndexSettings(), createKNNIndexMethodFieldMapping(TEST_FIELD, DIMENSIONS));
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, DOC_ID, NUM_DOCS);
} else {
validateKNNIndexingOnUpgrade();
validateKNNIndexingOnUpgrade(NUM_DOCS);
}
}

Expand All @@ -150,7 +180,7 @@ public void testKNNIndexCustomMethodFieldMapping() throws Exception {
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, DOC_ID, NUM_DOCS);
} else {
validateCustomMethodFieldMappingAfterUpgrade();
validateKNNIndexingOnUpgrade();
validateKNNIndexingOnUpgrade(NUM_DOCS);
}
}

Expand Down Expand Up @@ -240,11 +270,11 @@ public void testNoParametersOnUpgrade() throws Exception {
}

// KNN indexing tests when the cluster is upgraded to latest version
public void validateKNNIndexingOnUpgrade() throws Exception {
QUERY_COUNT = NUM_DOCS;
public void validateKNNIndexingOnUpgrade(int numOfDocs) throws Exception {
QUERY_COUNT = numOfDocs;
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, QUERY_COUNT, K);
cleanUpCache();
DOC_ID = NUM_DOCS;
DOC_ID = numOfDocs;
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, DOC_ID, NUM_DOCS);
QUERY_COUNT = QUERY_COUNT + NUM_DOCS;
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, QUERY_COUNT, K);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,21 +1,20 @@
/*
* Copyright OpenSearch Contributors
* SPDX-License-Identifier: Apache-2.0
*
* The OpenSearch Contributors require contributions made to
* this file be licensed under the Apache-2.0 license or a
* compatible open source license.
*
* Modifications Copyright OpenSearch Contributors. See
* GitHub history for details.
*/

package org.opensearch.knn.bwc;

import java.util.Map;

import static org.opensearch.knn.common.KNNConstants.FAISS_NAME;
import static org.opensearch.knn.common.KNNConstants.LUCENE_NAME;
import static org.opensearch.knn.common.KNNConstants.METHOD_PARAMETER_EF_SEARCH;
import static org.opensearch.knn.common.KNNConstants.NMSLIB_NAME;

/**
* Use case: Test queries on indexes created on older versions
*/
public class QueryANNIT extends AbstractRestartUpgradeTestCase {

private static final String TEST_FIELD = "test-field";
Expand All @@ -25,7 +24,7 @@ public class QueryANNIT extends AbstractRestartUpgradeTestCase {
private static final int NUM_DOCS = 10;
private static final String ALGORITHM = "hnsw";

public void testQueryANN() throws Exception {
public void testQueryOnFaissIndex() throws Exception {
if (isRunningAgainstOldCluster()) {
createKnnIndex(testIndex, getKNNDefaultIndexSettings(), createKnnIndexMapping(TEST_FIELD, DIMENSIONS, ALGORITHM, FAISS_NAME));
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, 0, NUM_DOCS);
Expand All @@ -36,4 +35,28 @@ public void testQueryANN() throws Exception {
deleteKNNIndex(testIndex);
}
}

public void testQueryOnNmslibIndex() throws Exception {
if (isRunningAgainstOldCluster()) {
createKnnIndex(testIndex, getKNNDefaultIndexSettings(), createKnnIndexMapping(TEST_FIELD, DIMENSIONS, ALGORITHM, NMSLIB_NAME));
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, 0, NUM_DOCS);
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, NUM_DOCS, K);
} else {
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, NUM_DOCS, K);
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, NUM_DOCS, K, Map.of(METHOD_PARAMETER_EF_SEARCH, EF_SEARCH));
deleteKNNIndex(testIndex);
}
}

public void testQueryOnLuceneIndex() throws Exception {
if (isRunningAgainstOldCluster()) {
createKnnIndex(testIndex, getKNNDefaultIndexSettings(), createKnnIndexMapping(TEST_FIELD, DIMENSIONS, ALGORITHM, LUCENE_NAME));
addKNNDocs(testIndex, TEST_FIELD, DIMENSIONS, 0, NUM_DOCS);
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, NUM_DOCS, K);
} else {
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, NUM_DOCS, K);
validateKNNSearch(testIndex, TEST_FIELD, DIMENSIONS, NUM_DOCS, K, Map.of(METHOD_PARAMETER_EF_SEARCH, EF_SEARCH));
deleteKNNIndex(testIndex);
}
}
}

0 comments on commit e320026

Please sign in to comment.