[ 
https://issues.apache.org/jira/browse/ARTEMIS-3808?focusedWorklogId=771550&page=com.atlassian.jira.plugin.system.issuetabpanels:worklog-tabpanel#worklog-771550
 ]

ASF GitHub Bot logged work on ARTEMIS-3808:
-------------------------------------------

                Author: ASF GitHub Bot
            Created on: 17/May/22 20:01
            Start Date: 17/May/22 20:01
    Worklog Time Spent: 10m 
      Work Description: jbertram commented on code in PR #4061:
URL: https://github.com/apache/activemq-artemis/pull/4061#discussion_r875214526


##########
artemis-web/src/main/java/org/apache/activemq/artemis/component/WebServerComponent.java:
##########
@@ -363,9 +366,17 @@ public void stop() throws Exception {
    }
 
    @Override
-   public void stop(boolean isShutdown) throws Exception {
+   public synchronized void stop(boolean isShutdown) throws Exception {
       if (isShutdown) {
-         internalStop();
+         ActiveMQWebLogger.LOGGER.stoppingEmbeddedWebServer();
+         server.stop();
+         server = null;

Review Comment:
   Done.



##########
tests/integration-tests/src/test/java/org/apache/activemq/artemis/tests/integration/management/ActiveMQServerControlTest.java:
##########
@@ -4290,6 +4295,101 @@ public boolean isStarted() {
       }
    }
 
+   @Test
+   public void testManualStopStartEmbeddedWebServer() throws Exception {
+      FakeWebServerComponent fake = new FakeWebServerComponent();
+      server.addExternalComponent(fake, true);
+      Assert.assertTrue(fake.isStarted());
+
+      ActiveMQServerControl serverControl = createManagementControl();
+      serverControl.stopEmbeddedWebServer();
+      Assert.assertFalse(fake.isStarted());
+      serverControl.startEmbeddedWebServer();
+      Assert.assertTrue(fake.isStarted());
+   }
+
+   @Test
+   public void testRestartEmbeddedWebServer() throws Exception {
+      FakeWebServerComponent fake = new FakeWebServerComponent();
+      server.addExternalComponent(fake, true);
+      Assert.assertTrue(fake.isStarted());
+
+      ActiveMQServerControl serverControl = createManagementControl();
+      long time = System.currentTimeMillis();
+      Assert.assertTrue(time >= fake.getStartTime());
+      Assert.assertTrue(time > fake.getStopTime());
+      Thread.sleep(5);
+      serverControl.restartEmbeddedWebServer();
+      Assert.assertTrue(serverControl.isEmbeddedWebServerStarted());
+      Assert.assertTrue(time < fake.getStartTime());
+      Assert.assertTrue(time < fake.getStopTime());
+   }
+
+   @Test
+   public void testRestartEmbeddedWebServerTimeout() throws Exception {
+      FakeWebServerComponent fake = new FakeWebServerComponent(400);
+      server.addExternalComponent(fake, false);
+
+      ActiveMQServerControl serverControl = createManagementControl();
+      try {
+         serverControl.restartEmbeddedWebServer(100);

Review Comment:
   I _think_ I understood your point. Let me know if I didn't.





Issue Time Tracking
-------------------

    Worklog Id:     (was: 771550)
    Time Spent: 5h  (was: 4h 50m)

> Support starting/stopping the embedded web server via mangement
> ---------------------------------------------------------------
>
>                 Key: ARTEMIS-3808
>                 URL: https://issues.apache.org/jira/browse/ARTEMIS-3808
>             Project: ActiveMQ Artemis
>          Issue Type: Improvement
>            Reporter: Justin Bertram
>            Assignee: Justin Bertram
>            Priority: Major
>          Time Spent: 5h
>  Remaining Estimate: 0h
>
> It would be useful to be able to cycle the embedded web server if, for 
> example, one needed to renew the SSL certificates.



--
This message was sent by Atlassian Jira
(v8.20.7#820007)

Reply via email to