Skip to content

Commit 8a8945e

Browse files
committed
Custom schedulers to execute @PreDestroy methods
Signed-off-by: Jorge Bescos Gascon <jorge.bescos.gascon@oracle.com>
1 parent 3f8ed16 commit 8a8945e

File tree

4 files changed

+90
-12
lines changed

4 files changed

+90
-12
lines changed

core-client/src/main/java/org/glassfish/jersey/client/ClientExecutorProvidersConfigurator.java

Lines changed: 3 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright (c) 2017, 2018 Oracle and/or its affiliates. All rights reserved.
2+
* Copyright (c) 2017, 2021 Oracle and/or its affiliates. All rights reserved.
33
*
44
* This program and the accompanying materials are made available under the
55
* terms of the Eclipse Public License v. 2.0, which is available at
@@ -65,7 +65,6 @@ class ClientExecutorProvidersConfigurator extends AbstractExecutorProvidersConfi
6565
@Override
6666
public void init(InjectionManager injectionManager, BootstrapBag bootstrapBag) {
6767
Map<String, Object> runtimeProperties = bootstrapBag.getConfiguration().getProperties();
68-
ManagedObjectsFinalizer finalizer = bootstrapBag.getManagedObjectsFinalizer();
6968

7069
ExecutorServiceProvider defaultAsyncExecutorProvider;
7170
ScheduledExecutorServiceProvider defaultScheduledExecutorProvider;
@@ -110,7 +109,6 @@ public void init(InjectionManager injectionManager, BootstrapBag bootstrapBag) {
110109
.to(ExecutorServiceProvider.class);
111110

112111
injectionManager.register(executorBinding);
113-
finalizer.registerForPreDestroyCall(defaultAsyncExecutorProvider);
114112

115113
final ScheduledExecutorService clientScheduledExecutorService = client.getScheduledExecutorService() == null
116114
// scheduled executor service set from {@link ClientConfig}.
@@ -134,9 +132,9 @@ public void init(InjectionManager injectionManager, BootstrapBag bootstrapBag) {
134132
.service(defaultScheduledExecutorProvider)
135133
.to(ScheduledExecutorServiceProvider.class);
136134
injectionManager.register(schedulerBinding);
137-
finalizer.registerForPreDestroyCall(defaultScheduledExecutorProvider);
138135

139-
registerExecutors(injectionManager, componentBag, defaultAsyncExecutorProvider, defaultScheduledExecutorProvider);
136+
registerExecutors(injectionManager, componentBag, defaultAsyncExecutorProvider,
137+
defaultScheduledExecutorProvider, bootstrapBag.getManagedObjectsFinalizer());
140138
}
141139

142140
private static ExecutorService lookupManagedExecutorService() {

core-common/src/main/java/org/glassfish/jersey/process/internal/AbstractExecutorProvidersConfigurator.java

Lines changed: 7 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright (c) 2017, 2018 Oracle and/or its affiliates. All rights reserved.
2+
* Copyright (c) 2017, 2021 Oracle and/or its affiliates. All rights reserved.
33
*
44
* This program and the accompanying materials are made available under the
55
* terms of the Eclipse Public License v. 2.0, which is available at
@@ -24,6 +24,7 @@
2424
import org.glassfish.jersey.internal.BootstrapConfigurator;
2525
import org.glassfish.jersey.internal.inject.InjectionManager;
2626
import org.glassfish.jersey.model.internal.ComponentBag;
27+
import org.glassfish.jersey.model.internal.ManagedObjectsFinalizer;
2728
import org.glassfish.jersey.spi.ExecutorServiceProvider;
2829
import org.glassfish.jersey.spi.ScheduledExecutorServiceProvider;
2930

@@ -49,12 +50,14 @@ public abstract class AbstractExecutorProvidersConfigurator implements Bootstrap
4950
* @param componentBag provides executor service providers registered by an application.
5051
* @param defaultAsyncExecutorProvider default implementation of {@link ExecutorServiceProvider}.
5152
* @param defaultScheduledExecutorProvider default implementation of {@link ScheduledExecutorServiceProvider}.
53+
* @param finalizer register finalizers.
5254
*/
5355
protected void registerExecutors(
5456
InjectionManager injectionManager,
5557
ComponentBag componentBag,
5658
ExecutorServiceProvider defaultAsyncExecutorProvider,
57-
ScheduledExecutorServiceProvider defaultScheduledExecutorProvider) {
59+
ScheduledExecutorServiceProvider defaultScheduledExecutorProvider,
60+
ManagedObjectsFinalizer finalizer) {
5861

5962
List<ExecutorServiceProvider> customExecutors =
6063
Stream.concat(
@@ -64,6 +67,7 @@ protected void registerExecutors(
6467
.map(CAST_TO_EXECUTOR_PROVIDER)
6568
.collect(Collectors.toList());
6669
customExecutors.add(defaultAsyncExecutorProvider);
70+
customExecutors.stream().forEach(e -> finalizer.registerForPreDestroyCall(e));
6771

6872
List<ScheduledExecutorServiceProvider> customScheduledExecutors =
6973
Stream.concat(
@@ -73,6 +77,7 @@ protected void registerExecutors(
7377
.map(CAST_TO_SCHEDULED_EXECUTOR_PROVIDER)
7478
.collect(Collectors.toList());
7579
customScheduledExecutors.add(defaultScheduledExecutorProvider);
80+
customScheduledExecutors.stream().forEach(e -> finalizer.registerForPreDestroyCall(e));
7681

7782
ExecutorProviders.registerExecutorBindings(injectionManager, customExecutors, customScheduledExecutors);
7883
}

core-server/src/main/java/org/glassfish/jersey/server/ServerExecutorProvidersConfigurator.java

Lines changed: 3 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright (c) 2017, 2018 Oracle and/or its affiliates. All rights reserved.
2+
* Copyright (c) 2017, 2021 Oracle and/or its affiliates. All rights reserved.
33
*
44
* This program and the accompanying materials are made available under the
55
* terms of the Eclipse Public License v. 2.0, which is available at
@@ -41,7 +41,6 @@ public void init(InjectionManager injectionManager, BootstrapBag bootstrapBag) {
4141
ServerBootstrapBag serverBag = (ServerBootstrapBag) bootstrapBag;
4242
ResourceConfig runtimeConfig = serverBag.getRuntimeConfig();
4343
ComponentBag componentBag = runtimeConfig.getComponentBag();
44-
ManagedObjectsFinalizer finalizer = serverBag.getManagedObjectsFinalizer();
4544

4645
// TODO: Do we need to register DEFAULT Executor and ScheduledExecutor to InjectionManager?
4746
ScheduledExecutorServiceProvider defaultScheduledExecutorProvider = new DefaultBackgroundSchedulerProvider();
@@ -50,16 +49,15 @@ public void init(InjectionManager injectionManager, BootstrapBag bootstrapBag) {
5049
.to(ScheduledExecutorServiceProvider.class)
5150
.qualifiedBy(BackgroundSchedulerLiteral.INSTANCE);
5251
injectionManager.register(schedulerBinding);
53-
finalizer.registerForPreDestroyCall(defaultScheduledExecutorProvider);
5452

5553
ExecutorServiceProvider defaultAsyncExecutorProvider = new DefaultManagedAsyncExecutorProvider();
5654
InstanceBinding<ExecutorServiceProvider> executorBinding = Bindings
5755
.service(defaultAsyncExecutorProvider)
5856
.to(ExecutorServiceProvider.class);
5957
injectionManager.register(executorBinding);
60-
finalizer.registerForPreDestroyCall(defaultAsyncExecutorProvider);
6158

62-
registerExecutors(injectionManager, componentBag, defaultAsyncExecutorProvider, defaultScheduledExecutorProvider);
59+
registerExecutors(injectionManager, componentBag, defaultAsyncExecutorProvider,
60+
defaultScheduledExecutorProvider, serverBag.getManagedObjectsFinalizer());
6361
}
6462

6563
/**
Lines changed: 77 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,77 @@
1+
/*
2+
* Copyright (c) 2021 Oracle and/or its affiliates. All rights reserved.
3+
*
4+
* This program and the accompanying materials are made available under the
5+
* terms of the Eclipse Public License v. 2.0, which is available at
6+
* http://www.eclipse.org/legal/epl-2.0.
7+
*
8+
* This Source Code may also be made available under the following Secondary
9+
* Licenses when the conditions for such availability set forth in the
10+
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
11+
* version 2 with the GNU Classpath Exception, which is available at
12+
* https://www.gnu.org/software/classpath/license.html.
13+
*
14+
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
15+
*/
16+
17+
package org.glassfish.jersey.tests.e2e.server;
18+
19+
import java.util.concurrent.RejectedExecutionHandler;
20+
import java.util.concurrent.ScheduledThreadPoolExecutor;
21+
import java.util.concurrent.ThreadFactory;
22+
23+
import javax.inject.Singleton;
24+
import javax.ws.rs.core.Application;
25+
26+
import org.glassfish.jersey.server.BackgroundScheduler;
27+
import org.glassfish.jersey.server.ResourceConfig;
28+
import org.glassfish.jersey.spi.ScheduledThreadPoolExecutorProvider;
29+
import org.glassfish.jersey.test.JerseyTest;
30+
import org.junit.Test;
31+
32+
import static org.junit.Assert.assertNotNull;
33+
import static org.junit.Assert.assertTrue;
34+
35+
public class ScheduledThreadPoolExecutorProviderTest {
36+
37+
@Test
38+
public void restartShutsdownScheduler() throws Exception {
39+
WebContainer container = new WebContainer();
40+
container.setUp();
41+
container.tearDown();
42+
assertNotNull(CustomScheduledThreadPoolExecutorProvider.executor);
43+
assertTrue(CustomScheduledThreadPoolExecutorProvider.selfRef.isClosed());
44+
assertTrue(CustomScheduledThreadPoolExecutorProvider.executor.isShutdown());
45+
}
46+
47+
private static class WebContainer extends JerseyTest {
48+
@Override
49+
protected Application configure() {
50+
return new ResourceConfig(CustomScheduledThreadPoolExecutorProvider.class);
51+
}
52+
}
53+
54+
@BackgroundScheduler
55+
@Singleton
56+
public static class CustomScheduledThreadPoolExecutorProvider extends ScheduledThreadPoolExecutorProvider {
57+
58+
private static CustomScheduledThreadPoolExecutorProvider selfRef;
59+
private static ScheduledThreadPoolExecutor executor;
60+
61+
public CustomScheduledThreadPoolExecutorProvider() {
62+
this("CustomScheduledThreadPoolExecutorProvider");
63+
}
64+
65+
public CustomScheduledThreadPoolExecutorProvider(String name) {
66+
super(name);
67+
CustomScheduledThreadPoolExecutorProvider.selfRef = this;
68+
}
69+
70+
@Override
71+
protected ScheduledThreadPoolExecutor createExecutor(int corePoolSize, ThreadFactory threadFactory,
72+
RejectedExecutionHandler handler) {
73+
executor = new ScheduledThreadPoolExecutor(5, threadFactory, handler);
74+
return executor;
75+
}
76+
}
77+
}

0 commit comments

Comments
 (0)