[forge-issues] [JBoss JIRA] (FURNACE-35) PostStartup event is not fired for every deployed addon

George Gastaldi (JIRA) issues at jboss.org
Thu Mar 26 16:25:19 EDT 2015


    [ https://issues.jboss.org/browse/FURNACE-35?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13053806#comment-13053806 ] 

George Gastaldi commented on FURNACE-35:
----------------------------------------

The test passes when using the simple container, so it all points to a bug in the CDI container: 

{code:java}
/*
 * Copyright 2013 Red Hat, Inc. and/or its affiliates.
 *
 * Licensed under the Eclipse Public License version 1.0, available at
 * http://www.eclipse.org/legal/epl-v10.html
 */
package test.org.jboss.forge.furnace.events;

import java.util.ArrayList;
import java.util.List;
import java.util.Map.Entry;

import javax.inject.Inject;
import javax.xml.xpath.XPathFactory;

import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.forge.arquillian.AddonDeployment;
import org.jboss.forge.arquillian.AddonDeployments;
import org.jboss.forge.arquillian.archive.AddonArchive;
import org.jboss.forge.furnace.repositories.AddonDependencyEntry;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;

/**
 * @author Matej Briškár
 * @author <a href="mailto:lincolnbaxter at gmail.com">Lincoln Baxter, III</a>
 */
@RunWith(Arquillian.class)
public class ContainerLifecycleEventsTest
{

   @Deployment(order = 3)
   @AddonDeployments({
            @AddonDeployment(name = "org.jboss.forge.furnace.container:cdi"),
            @AddonDeployment(name = "org.jboss.forge.furnace.container:simple", version = "2.15.4-SNAPSHOT")
   })
   public static AddonArchive getDeployment1()
   {
      AddonArchive archive = ShrinkWrap.create(AddonArchive.class)
               .addAsAddonDependencies(
                        AddonDependencyEntry.create("org.jboss.forge.furnace.container:cdi"),
                        AddonDependencyEntry.create("dep2"),
                        AddonDependencyEntry.create("dep3"),
                        AddonDependencyEntry.create("dep4")
               ).addBeansXML();
      return archive;
   }

   @Deployment(name = "dep2,1", testable = false, order = 2)
   public static AddonArchive getDeploymentDep2()
   {
      AddonArchive archive = ShrinkWrap.create(AddonArchive.class)
               .addAsAddonDependencies(
                        AddonDependencyEntry.create("org.jboss.forge.furnace.container:simple", "2.15.4-SNAPSHOT")
               )
               .addBeansXML();
      return archive;
   }

   @Deployment(name = "dep3,1", testable = false, order = 1)
   public static AddonArchive getDeploymentDep3()
   {
      AddonArchive archive = ShrinkWrap.create(AddonArchive.class)
               .addAsAddonDependencies(
                        AddonDependencyEntry.create("org.jboss.forge.furnace.container:simple", "2.15.4-SNAPSHOT")
               )
               .addBeansXML();
      return archive;
   }

   @Deployment(name = "dep4,1", testable = false, order = 0)
   public static AddonArchive getDeploymentDep4()
   {
      AddonArchive archive = ShrinkWrap.create(AddonArchive.class)
               .addClass(ContainerLifecycleEventObserver.class)
               .addAsAddonDependencies(
                        AddonDependencyEntry.create("org.jboss.forge.furnace.container:cdi")
               )
               .addBeansXML();
      return archive;
   }

   @Inject
   private ContainerLifecycleEventObserver observer;

   @Test
   public void testContainerStartup()
   {
      Assert.assertTrue(observer.isObservedPerform());
      Assert.assertTrue("PostStartup should be called for each installed addon. Only "
               + observer.getPostStartupMap().size() + " calls were registered.",
               observer.getPostStartupMap().size() == 4);
      List<String> messages = new ArrayList<>();
      for (Entry<String, Integer> entry : observer.getPostStartupMap().entrySet())
      {
         if (entry.getValue() > 1)
         {
            messages.add("Multiple PostStartup events for addon: " + entry.getKey() + ": " + entry.getValue());
         }
      }
      if (!messages.isEmpty())
         Assert.fail(messages.toString());
   }
}
{code}

> PostStartup event is not fired for every deployed addon
> -------------------------------------------------------
>
>                 Key: FURNACE-35
>                 URL: https://issues.jboss.org/browse/FURNACE-35
>             Project: Forge: Furnace
>          Issue Type: Bug
>          Components: Container - CDI, Runtime
>    Affects Versions: 2.15.3.Final
>            Reporter: Matej Briskar
>             Fix For: 2.x Future
>
>




--
This message was sent by Atlassian JIRA
(v6.3.11#6341)



More information about the forge-issues mailing list