All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.elasticsearch.test.TaskAssertions Maven / Gradle / Ivy

There is a newer version: 8.16.0
Show newest version
/*
 * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
 * or more contributor license agreements. Licensed under the Elastic License
 * 2.0 and the Server Side Public License, v 1; you may not use this file except
 * in compliance with, at your election, the Elastic License 2.0 or the Server
 * Side Public License, v 1.
 */

package org.elasticsearch.test;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.elasticsearch.tasks.CancellableTask;
import org.elasticsearch.tasks.Task;
import org.elasticsearch.tasks.TaskInfo;
import org.elasticsearch.tasks.TaskManager;
import org.elasticsearch.transport.TransportService;

import java.util.List;
import java.util.concurrent.TimeUnit;
import java.util.stream.Collectors;

import static junit.framework.TestCase.assertTrue;
import static junit.framework.TestCase.fail;
import static org.elasticsearch.test.ESIntegTestCase.client;
import static org.elasticsearch.test.ESIntegTestCase.internalCluster;
import static org.elasticsearch.test.ESTestCase.assertBusy;

public class TaskAssertions {
    private static final Logger logger = LogManager.getLogger(TaskAssertions.class);

    private TaskAssertions() {}

    public static void awaitTaskWithPrefix(String actionPrefix) throws Exception {
        awaitTaskWithPrefix(actionPrefix, internalCluster().getInstances(TransportService.class));
    }

    public static void awaitTaskWithPrefixOnMaster(String actionPrefix) throws Exception {
        awaitTaskWithPrefix(actionPrefix, List.of(internalCluster().getCurrentMasterNodeInstance(TransportService.class)));
    }

    private static void awaitTaskWithPrefix(String actionPrefix, Iterable transportServiceInstances) throws Exception {
        logger.info("--> waiting for task with prefix [{}] to start", actionPrefix);

        assertBusy(() -> {
            for (TransportService transportService : transportServiceInstances) {
                List matchingTasks = transportService.getTaskManager()
                    .getTasks()
                    .values()
                    .stream()
                    .filter(t -> t.getAction().startsWith(actionPrefix))
                    .collect(Collectors.toList());
                if (matchingTasks.isEmpty() == false) {
                    logger.trace("--> found {} tasks with prefix [{}]: {}", matchingTasks.size(), actionPrefix, matchingTasks);
                    return;
                }
            }
            fail("no task with prefix [" + actionPrefix + "] found");
        });
    }

    public static void assertAllCancellableTasksAreCancelled(String actionPrefix) throws Exception {
        logger.info("--> checking that all tasks with prefix {} are marked as cancelled", actionPrefix);

        assertBusy(() -> {
            boolean foundTask = false;
            for (TransportService transportService : internalCluster().getInstances(TransportService.class)) {
                final TaskManager taskManager = transportService.getTaskManager();
                assertTrue(taskManager.assertCancellableTaskConsistency());
                for (CancellableTask cancellableTask : taskManager.getCancellableTasks().values()) {
                    if (cancellableTask.getAction().startsWith(actionPrefix)) {
                        logger.trace("--> found task with prefix [{}]: [{}]", actionPrefix, cancellableTask);
                        foundTask = true;
                        assertTrue(
                            "task " + cancellableTask.getId() + "/" + cancellableTask.getAction() + " not cancelled",
                            cancellableTask.isCancelled()
                        );
                        logger.trace("--> Task with prefix [{}] is marked as cancelled: [{}]", actionPrefix, cancellableTask);
                    }
                }
            }
            assertTrue("found no cancellable tasks", foundTask);
        }, 30, TimeUnit.SECONDS);
    }

    public static void assertAllTasksHaveFinished(String actionPrefix) throws Exception {
        logger.info("--> checking that all tasks with prefix {} have finished", actionPrefix);
        assertBusy(() -> {
            final List tasks = client().admin().cluster().prepareListTasks().get().getTasks();
            assertTrue(tasks.toString(), tasks.stream().noneMatch(t -> t.action().startsWith(actionPrefix)));
        });
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy