/* * Copyright OpenSearch Contributors * SPDX-License-Identifier: Apache-2.0 */ package org.opensearch.ml.rest; import static org.mockito.ArgumentMatchers.any; import static org.mockito.ArgumentMatchers.eq; import static org.mockito.Mockito.*; import static org.mockito.Mockito.times; import static org.opensearch.ml.utils.RestActionUtils.PARAMETER_TASK_ID; import java.util.HashMap; import java.util.List; import java.util.Map; import org.junit.Before; import org.mockito.ArgumentCaptor; import org.mockito.Mock; import org.opensearch.action.ActionListener; import org.opensearch.client.node.NodeClient; import org.opensearch.common.settings.Settings; import org.opensearch.core.common.Strings; import org.opensearch.core.xcontent.NamedXContentRegistry; import org.opensearch.ml.common.transport.task.*; import org.opensearch.rest.RestChannel; import org.opensearch.rest.RestHandler; import org.opensearch.rest.RestRequest; import org.opensearch.test.OpenSearchTestCase; import org.opensearch.test.rest.FakeRestRequest; import org.opensearch.threadpool.TestThreadPool; import org.opensearch.threadpool.ThreadPool; public class RestMLGetTaskActionTests extends OpenSearchTestCase { private RestMLGetTaskAction restMLGetTaskAction; NodeClient client; private ThreadPool threadPool; @Mock RestChannel channel; @Before public void setup() { restMLGetTaskAction = new RestMLGetTaskAction(); threadPool = new TestThreadPool(this.getClass().getSimpleName() + "ThreadPool"); client = spy(new NodeClient(Settings.EMPTY, threadPool)); doAnswer(invocation -> { ActionListener actionListener = invocation.getArgument(2); return null; }).when(client).execute(eq(MLTaskGetAction.INSTANCE), any(), any()); } @Override public void tearDown() throws Exception { super.tearDown(); threadPool.shutdown(); client.close(); } public void testConstructor() { RestMLGetTaskAction mlGetTaskAction = new RestMLGetTaskAction(); assertNotNull(mlGetTaskAction); } public void testGetName() { String actionName = restMLGetTaskAction.getName(); assertFalse(Strings.isNullOrEmpty(actionName)); assertEquals("ml_get_task_action", actionName); } public void testRoutes() { List routes = restMLGetTaskAction.routes(); assertNotNull(routes); assertFalse(routes.isEmpty()); RestHandler.Route route = routes.get(0); assertEquals(RestRequest.Method.GET, route.getMethod()); assertEquals("/_plugins/_ml/tasks/{task_id}", route.getPath()); } public void test_PrepareRequest() throws Exception { RestRequest request = getRestRequest(); restMLGetTaskAction.handleRequest(request, channel, client); ArgumentCaptor argumentCaptor = ArgumentCaptor.forClass(MLTaskGetRequest.class); verify(client, times(1)).execute(eq(MLTaskGetAction.INSTANCE), argumentCaptor.capture(), any()); String taskId = argumentCaptor.getValue().getTaskId(); assertEquals(taskId, "test_id"); } private RestRequest getRestRequest() { Map params = new HashMap<>(); params.put(PARAMETER_TASK_ID, "test_id"); RestRequest request = new FakeRestRequest.Builder(NamedXContentRegistry.EMPTY).withParams(params).build(); return request; } }