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

ee.jakarta.tck.concurrent.api.ManagedExecutors.ManagedExecutorsServlet Maven / Gradle / Ivy

/*
 * Copyright (c) 2013, 2022 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */
package ee.jakarta.tck.concurrent.api.ManagedExecutors;

import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.Callable;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

import ee.jakarta.tck.concurrent.common.CallableTask;
import ee.jakarta.tck.concurrent.common.RunnableTask;
import ee.jakarta.tck.concurrent.common.managedTaskListener.ListenerEvent;
import ee.jakarta.tck.concurrent.common.managedTaskListener.ManagedTaskListenerImpl;
import ee.jakarta.tck.concurrent.framework.TestLogger;
import ee.jakarta.tck.concurrent.framework.TestServlet;
import ee.jakarta.tck.concurrent.framework.TestUtil;
import jakarta.enterprise.concurrent.ManagedExecutors;
import jakarta.enterprise.concurrent.ManagedTask;
import jakarta.servlet.annotation.WebServlet;

@WebServlet("/ManagedExecutorsServlet")
public class ManagedExecutorsServlet extends TestServlet{
	
	private static final TestLogger log = TestLogger.get(ManagedExecutorsServlet.class);
	
	private static final String ENV_ENTRY_JNDI_NAME = "java:comp/env/StringValue";

	private static final String ENV_ENTRY_VALUE = "something";

	private ManagedTaskListenerImpl managedTaskListener = new ManagedTaskListenerImpl();

	private boolean shutdown = true;

	@Override
	public void after() {
		managedTaskListener.clearEvents();
	}
	
	private RunnableTask createRunnableTask() {
		return new RunnableTask(ENV_ENTRY_JNDI_NAME, ENV_ENTRY_VALUE, this.getClass().getName());
	}

	private CallableTask createCallableTask(String expectedReturnValue) {
		return new CallableTask(ENV_ENTRY_JNDI_NAME, ENV_ENTRY_VALUE, this.getClass().getName(),
				expectedReturnValue);
	}

	public void IsCurrentThreadShutdown() {
		Thread createdThread = TestUtil.getManagedThreadFactory().newThread(new Runnable() {
			@Override
			public void run() {
				shutdown = ManagedExecutors.isCurrentThreadShutdown();
			}
		});
		// Executors.newSingleThreadExecutor() uses Executors.defaultThreadFactory()
		// to create new thread. So the thread used in this test is a non Manageable
		// Thread.
		Future future = Executors.newSingleThreadExecutor().submit(createdThread);
		TestUtil.waitForTaskComplete(future);
		if(shutdown) {
			throw new RuntimeException("Failed because shutdown is set to be true when running job");
		}
	}

	public void IsCurrentThreadShutdown_ManageableThread() {
		Thread createdThread = TestUtil.getManagedThreadFactory().newThread(new Runnable() {
			@Override
			public void run() {
				shutdown = ManagedExecutors.isCurrentThreadShutdown();
			}
		});
		// Executors.newSingleThreadExecutor(managedThreadFactory) uses
		// ManagedThreadFactory
		// to create new (Manageable) thread.
		Future future = Executors.newSingleThreadExecutor(TestUtil.getManagedThreadFactory()).submit(createdThread);
		TestUtil.waitForTaskComplete(future);
		if(shutdown) {
			throw new RuntimeException("Failed because shutdown is set to be true when running job");
		}
	}

	public void ManageRunnableTaskWithTaskListener() {
		RunnableTask runnableTask = createRunnableTask();
		Runnable taskWithListener = ManagedExecutors.managedTask(runnableTask, managedTaskListener);
		Future futureResult = TestUtil.getManagedExecutorService().submit(taskWithListener);
		assertTaskAndListenerComplete(futureResult, runnableTask);
	}

	public void ManageRunnableTaskWithNullArg() {
		Runnable nullTask = null;
		try {
			ManagedExecutors.managedTask(nullTask, managedTaskListener);
		} catch (IllegalArgumentException e) {
			return; //expected
		} catch (Exception e) {
			log.warning("Unexpected Exception Caught", e);
		}
		
		throw new RuntimeException("Failed to get expected exception");
	}

	public void ManageRunnableTaskWithTaskListenerAndMap() {
		Map properties = new HashMap();
		properties.put("key", "value");
		RunnableTask runnableTask = createRunnableTask();
		Runnable task = ManagedExecutors.managedTask(runnableTask, properties, managedTaskListener);
		boolean pass = false;
		if (task instanceof ManagedTask) {
			ManagedTask managedTask = (ManagedTask) task;
			if (managedTask.getExecutionProperties().get("key") != "value")
				throw new RuntimeException("Failed to get expected property");
		}

		assertTaskAndListenerComplete(TestUtil.getManagedExecutorService().submit(task), runnableTask);
	}

	public void ManageRunnableTaskWithMapAndNullArg() {
		Runnable nullTask = null;
		Map properties = new HashMap();
		try {
			ManagedExecutors.managedTask(nullTask, properties, managedTaskListener);
		} catch (IllegalArgumentException e) {
			return; //expected
		} catch (Exception e) {
			log.warning("Unexpected Exception Caught", e);
		}		
		throw new RuntimeException("Failed to get expected exception");
	}

	public void ManageCallableTaskWithTaskListener() {
		String expectedResultStr = "expected something";
		CallableTask callableTask = createCallableTask(expectedResultStr);
		Callable taskWithListener = ManagedExecutors.managedTask((Callable) callableTask,
				managedTaskListener);
		Future futureResult = TestUtil.getManagedExecutorService().submit(taskWithListener);
		assertTaskAndListenerComplete(expectedResultStr, futureResult, callableTask);
	}

	public void ManageCallableTaskWithNullArg() {
		Callable nullTask = null;
		try {
			ManagedExecutors.managedTask(nullTask, managedTaskListener);
		} catch (IllegalArgumentException e) {
			return; //expected
		} catch (Exception e) {
			log.warning("Unexpected Exception Caught", e);
		}
		throw new RuntimeException("Failed to get expected exception");
	}

	public void ManageCallableTaskWithTaskListenerAndMap() {
		Map properties = new HashMap();
		properties.put("key", "value");
		properties.put(ManagedTask.IDENTITY_NAME, "id");
		String expectedResultStr = "expected something";

		CallableTask callableTask = createCallableTask(expectedResultStr);
		Callable task = ManagedExecutors.managedTask((Callable) callableTask, properties,
				managedTaskListener);

		boolean pass = false;
		if (task instanceof ManagedTask) {
			ManagedTask managedTask = (ManagedTask) task;
			if (managedTask.getExecutionProperties().get("key") != "value")
				throw new RuntimeException("Failed to get expected property");
		}
		assertTaskAndListenerComplete(expectedResultStr, TestUtil.getManagedExecutorService().submit(task), callableTask);
	}

	public void ManageCallableTaskWithMapAndNullArg() {
		Callable nullTask = null;
		Map properties = new HashMap();
		try {
			ManagedExecutors.managedTask(nullTask, properties, managedTaskListener);
		} catch (IllegalArgumentException e) {
			return; //expected
		} catch (Exception e) {
			log.warning("Unexpected Exception Caught", e);
		}
		throw new RuntimeException("Failed to get expected exception");
	}

	private void assertTaskAndListenerComplete(Future future, RunnableTask runnableTask) {
		TestUtil.waitForTaskComplete(future);
		assertListenerComplete(runnableTask);
	}

	private void assertTaskAndListenerComplete(String expectedResult, Future future,
			CallableTask callableTask) {
		String result = TestUtil.waitForTaskComplete(future);
		if(!expectedResult.endsWith(result))
			throw new RuntimeException("Task return different value with expected one.");
		assertListenerComplete(callableTask);
	}

	private void assertListenerComplete(RunnableTask task) {
		// wait for the listener run done.
		TestUtil.waitForListenerComplete(managedTaskListener);
		// check listener status.
		if (!(managedTaskListener.eventCalled(ListenerEvent.SUBMITTED)
				&& managedTaskListener.eventCalled(ListenerEvent.STARTING)
				&& managedTaskListener.eventCalled(ListenerEvent.DONE))) {
			throw new RuntimeException("TaskListener is not completely executed.");
		}
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy