Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Updated Testcases for MLEngine.java #1536

Closed
wants to merge 4 commits into from
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.ExpectedException;
import org.mockito.Mock;
import org.mockito.MockedStatic;
import org.mockito.Mockito;
import org.opensearch.core.common.io.stream.StreamOutput;
Expand Down Expand Up @@ -41,6 +42,7 @@
import java.util.UUID;

import static org.junit.Assert.assertEquals;
import static org.mockito.Mockito.when;
import static org.opensearch.ml.engine.helper.LinearRegressionHelper.constructLinearRegressionPredictionDataFrame;
import static org.opensearch.ml.engine.helper.LinearRegressionHelper.constructLinearRegressionTrainDataFrame;
import static org.opensearch.ml.engine.helper.MLTestHelper.constructTestDataFrame;
Expand Down Expand Up @@ -68,6 +70,24 @@ public void testPrebuiltModelPath() {
assertEquals("https://artifacts.opensearch.org/models/ml-models/huggingface/sentence-transformers/msmarco-distilbert-base-tas-b/1.0.1/torch_script/config.json", prebuiltModelConfigPath);
}

@Test
public void testGetDeployModelZipPath() {
String modelId = "test_id";
String modelName = "huggingface/sentence-transformers/msmarco-distilbert-base-tas-b";
String modelZipPath = mlEngine.getDeployModelZipPath(modelId, modelName);
assertEquals(mlEngine.getMlCachePath() + Path.of("/models_cache/deploy/test_id/huggingface/sentence-transformers/msmarco-distilbert-base-tas-b.zip").toString(), modelZipPath);
}

@Test
public void testGetDeployModelChunkPath() {
String modelId = "test_id";
for (int i = 1; i <= 10; i++) {
Integer chunkNum = i;
Path chunkPath = mlEngine.getDeployModelChunkPath(modelId, chunkNum);
assertEquals(Path.of(mlEngine.getMlCachePath().toString() + "/models_cache/deploy/test_id/chunks/" + chunkNum.toString()), chunkPath);
}
}

@Test
public void predictKMeans() {
MLModel model = trainKMeansModel();
Expand Down Expand Up @@ -142,6 +162,33 @@ public void train_NullInput() {
}
}

@Test
public void testTrainNullTrainable() {
exceptionRule.expect(IllegalArgumentException.class);
MLInput mlInput = Mockito.mock(MLInput.class);
when(mlInput.getAlgorithm()).thenReturn(FunctionName.LINEAR_REGRESSION);
when(MLEngineClassLoader.initInstance(mlInput.getAlgorithm(), mlInput.getParameters(), MLAlgoParams.class)).thenReturn(null);
mlEngine.train(mlInput);
}

@Test
public void predictNullPredictable() {
exceptionRule.expect(IllegalArgumentException.class);
MLInput mlInput = Mockito.mock(MLInput.class);
MLModel mlModel = Mockito.mock(MLModel.class);
when(mlInput.getAlgorithm()).thenReturn(FunctionName.LINEAR_REGRESSION);
when(MLEngineClassLoader.initInstance(mlInput.getAlgorithm(), mlInput.getParameters(), MLAlgoParams.class)).thenReturn(null);
mlEngine.predict(mlInput, mlModel);
}

@Test
public void trainAndPredictNullTrainable() {
exceptionRule.expect(IllegalArgumentException.class);
MLInput mlInput = Mockito.mock(MLInput.class);
when(mlInput.getAlgorithm()).thenReturn(FunctionName.LINEAR_REGRESSION);
when(MLEngineClassLoader.initInstance(mlInput.getAlgorithm(), mlInput.getParameters(), MLAlgoParams.class)).thenReturn(null);
mlEngine.trainAndPredict(mlInput);
}
//TODO: fix mockito error
@Ignore
@Test
Comment on lines 192 to 194
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@dhrubo-os we should fix this while we're at it?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good idea. @divitr if you think it's easy enough to fix in this PR, please go forward. Otherwise we can create another issue to take out the @ignore and make this test working.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@dhrubo-os I don't think this issue is that easy to fix in this PR, I think we should open a new issue. I can open up a new issue if you'd like.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sure, I'll create an issue later.

Expand Down
Loading