That is a solution and we are already using @Alternative sometimes but
there are currently too many tests with too many mocks for me to transform
them all.

Thanks.

2017-10-17 16:48 GMT+02:00 Gerhard Petracek <[email protected]>:

> hi bruno,
>
> if a cdi-bean only gets replaced by one mocked bean (for all involved
> tests), you don't need the mock-support from deltaspike.
> just use (global) alternatives or @Specializes (for beans which are only in
> your test-classpath and change the default behavior).
>
> or use a cdi-producer for such beans (-> you can use an alternative
> producer in the test-classpath).
>
> regards,
> gerhard
>
>
>
> 2017-10-17 14:09 GMT+02:00 Bruno Boissard <[email protected]>:
>
> > John -> I do not use the allow_mocked_beans in the exact test that fails
> > but it is used in some other tests like this:
> > =======================
> > ApplicationMockManager mockManager =
> > getContextualReference(ApplicationMockManager.class);
> > mockManager.addMock(Mockito.mock(SomeClass.class));
> > =======================
> >
> > Documentation is here:
> > https://deltaspike.apache.org/documentation/test-control.
> > html#MockFrameworks
> >
> > Currently only application scoped beans are mocked and DynamicMockManager
> > is not used but it can evolve.
> > As stop_container is also set to false, I assume there is no chances
> that I
> > could deactivate the mock management for my particular test.
> >
> > Regards.
> >
> >
> >
> > 2017-10-17 13:37 GMT+02:00 John D. Ament <[email protected]>:
> >
> > > Bruno,
> > >
> > > It seems that your example isn't complete enough.  You
> > > have deltaspike.testcontrol.mock-support.allow_mocked_beans=true
> > enabled,
> > > however you're not using it (in the example).  How are you using mocked
> > > beans in your real test?
> > >
> > > John
> > >
> > > On Tue, Oct 17, 2017 at 6:56 AM Bruno Boissard <
> [email protected]
> > >
> > > wrote:
> > >
> > > > John -> Yes you found the sources and reproduced my issue.
> > > > Gerhard -> It's a pity that the mock functionality implies to have a
> > > > request context.
> > > > Using your code proposal make cdi-test work but in the real thing the
> > > > threads are not created explicitely by me so it will be harder to
> have
> > > them
> > > > creating the request context, and only in case of tests.
> > > >
> > > > It would have been nice to have the mock functionality working
> without
> > > > request context but I will implement your workaround and create the
> > > request
> > > > context in the separated thread.
> > > >
> > > > Thanks.
> > > >
> > > >
> > > > 2017-10-17 12:26 GMT+02:00 Gerhard Petracek <[email protected]>:
> > > >
> > > > > hi bruno,
> > > > >
> > > > > you don't have a request-scoped bean, but the mock-functionality
> you
> > > > > enabled (via config) is based on the request-scoped bean you
> > mentioned.
> > > > > it's needed to support different mocks (across tests).
> > > > >
> > > > > -> if MyThread is part of your test-code, just add the parts i've
> > > > mentioned
> > > > > in my previous answer.
> > > > > (otherwise use MyTestThread which extends MyThread for your tests +
> > add
> > > > the
> > > > > additional behavior there...)
> > > > >
> > > > > regards,
> > > > > gerhard
> > > > >
> > > > >
> > > > >
> > > > > 2017-10-17 11:58 GMT+02:00 John D. Ament <[email protected]>:
> > > > >
> > > > > > Bruno,
> > > > > >
> > > > > > When I run your project (assuming you meant :
> > > > > > https://github.com/rt15/cdi-test ) This is the exception I get,
> > > which
> > > > > > matches to what Gerhard is describing to you:
> > > > > >
> > > > > > javax.enterprise.context.ContextNotActiveException: WebBeans
> > context
> > > > > with
> > > > > > scope type annotation @RequestScoped does not exist within
> current
> > > > thread
> > > > > > at
> > > > > > org.apache.webbeans.container.BeanManagerImpl.getContext(
> > > > > > BeanManagerImpl.java:331)
> > > > > > at
> > > > > > org.apache.webbeans.intercept.NormalScopedBeanInterceptorHan
> > > > > > dler.getContextualInstance(NormalScopedBeanInterceptorHan
> > > dler.java:88)
> > > > > > at
> > > > > > org.apache.webbeans.intercept.RequestScopedBeanInterceptorHa
> > > > > >
> > > > ndler.getContextualInstance(RequestScopedBeanInterceptorHa
> > ndler.java:76)
> > > > > > at
> > > > > > org.apache.webbeans.intercept.NormalScopedBeanInterceptorHan
> > > dler.get(
> > > > > > NormalScopedBeanInterceptorHandler.java:70)
> > > > > > at
> > > > > > org.apache.deltaspike.testcontrol.impl.mock.SimpleMockManager$$
> > > > > > OwbNormalScopeProxy0.getMock(org/apache/deltaspike/
> > > > > testcontrol/impl/mock/
> > > > > > SimpleMockManager.java)
> > > > > > at
> > > > > > org.apache.deltaspike.testcontrol.impl.mock.
> > > > > MockAwareInjectionTargetWrappe
> > > > > > r.produce(MockAwareInjectionTargetWrapper.java:59)
> > > > > > at
> > > > > > org.apache.webbeans.component.AbstractOwbBean.create(
> > > > > > AbstractOwbBean.java:122)
> > > > > > at
> > > > org.apache.webbeans.component.ManagedBean.create(
> ManagedBean.java:67)
> > > > > > at
> > > > > > org.apache.webbeans.context.creational.BeanInstanceBag.
> > > > > > create(BeanInstanceBag.java:76)
> > > > > > at
> > > > > > org.apache.webbeans.context.AbstractContext.getInstance(
> > > > > > AbstractContext.java:159)
> > > > > > at org.apache.webbeans.context.AbstractContext.get(
> > > > > > AbstractContext.java:125)
> > > > > > at
> > > > > > org.apache.webbeans.intercept.NormalScopedBeanInterceptorHan
> > > > > > dler.getContextualInstance(NormalScopedBeanInterceptorHan
> > > dler.java:100)
> > > > > > at
> > > > > > org.apache.webbeans.intercept.ApplicationScopedBeanIntercept
> > > orHandler.
> > > > > > getContextualInstance(ApplicationScopedBeanIntercept
> > > orHandler.java:65)
> > > > > > at
> > > > > > org.apache.webbeans.intercept.NormalScopedBeanInterceptorHan
> > > dler.get(
> > > > > > NormalScopedBeanInterceptorHandler.java:70)
> > > > > > at fr.rt15.MyBean$$OwbNormalScopeProxy0.foo(fr/rt15/MyBean.java)
> > > > > > at fr.rt15.MyThread.run(MyThread.java:13)
> > > > > >
> > > > > > On Tue, Oct 17, 2017 at 5:04 AM Bruno Boissard <
> > > > [email protected]
> > > > > >
> > > > > > wrote:
> > > > > >
> > > > > > > Hi Gerhard,
> > > > > > >
> > > > > > > It would make sense to start a request context in order to be
> > able
> > > to
> > > > > > > access a @RequestScoped bean but my bean is @ApplicationScoped.
> > > > Should
> > > > > it
> > > > > > > not be accessible without starting a request context?
> > > > > > >
> > > > > > > But while searching for my bean, in deltaspike
> > > > > > > MockAwareInjectionTargetWrapper, a DynamicMockManager is
> > searched:
> > > > > > >
> > > > > > > DynamicMockManager mockManager =
> > > > > > > BeanProvider.getContextualReference(this.beanManager,
> > > > > > > DynamicMockManager.class, false);
> > > > > > >
> > > > > > > It returns a SimpleMockManager that is @RequestScoped so it
> > cannot
> > > be
> > > > > > used
> > > > > > > without a created request context.
> > > > > > >
> > > > > > > Maybe MockAwareInjectionTargetWrapper should use
> > > > > > > SimpleApplicationMockManager (Which is @ApplicationScoped) when
> > we
> > > > ask
> > > > > > for
> > > > > > > an @ApplicationScoped bean?
> > > > > > >
> > > > > > > Regards.
> > > > > > >
> > > > > > > 2017-10-17 10:20 GMT+02:00 Gerhard Petracek <
> > [email protected]
> > > >:
> > > > > > >
> > > > > > > > hi bruno,
> > > > > > > >
> > > > > > > > if you start your own threads, you have to control some
> scopes
> > > like
> > > > > the
> > > > > > > > request-scope on your own (>within< those new threads).
> > > > > > > > (that isn't specific to deltaspike)
> > > > > > > >
> > > > > > > > see a similar part [1] in our documentation.
> > > > > > > >
> > > > > > > > regards,
> > > > > > > > gerhard
> > > > > > > >
> > > > > > > > [1]
> > > > > > > > http://deltaspike.apache.org/documentation/container-
> > > control.html#
> > > > > > > > AttachaRequestContexttoaNewThreadinEE
> > > > > > > >
> > > > > > > >
> > > > > > > >
> > > > > > > > 2017-10-17 9:55 GMT+02:00 Bruno Boissard <
> > > [email protected]
> > > > >:
> > > > > > > >
> > > > > > > > > Hello,
> > > > > > > > >
> > > > > > > > > I am using deltaspike 1.8.0 and owb version 1.6.3.
> > > > > > > > >
> > > > > > > > > My test which has to be executed with CdiTestRunner, is
> > > starting
> > > > a
> > > > > > new
> > > > > > > > > thread.
> > > > > > > > > This thread retrieves an instance of MyBean from CDI and
> try
> > to
> > > > use
> > > > > > it.
> > > > > > > > > MyBean is @ApplicationScoped.
> > > > > > > > >
> > > > > > > > > It works fine unless I add in apache-deltaspike.properties:
> > > > > > > > > deltaspike.testcontrol.mock-support.allow_mocked_beans=
> true
> > > > > > > > > (It is necessary for some other tests. As well as
> > > > > > stop_container=false
> > > > > > > is
> > > > > > > > > also necessary).
> > > > > > > > >
> > > > > > > > > With allow_mocked_beans=true I have following exception:
> > > > > > > > > javax.enterprise.context.ContextNotActiveException:
> WebBeans
> > > > > context
> > > > > > > > with
> > > > > > > > > scope type annotation @RequestScoped does not exist within
> > > > current
> > > > > > > thread
> > > > > > > > >
> > > > > > > > > It appears that while searching for MyBean, it is searching
> > for
> > > > > > > > > SimpleMockManager bean.
> > > > > > > > > SimpleMockManager is @RequestScoped, so deltaspike does not
> > > find
> > > > it
> > > > > > > > > (Logical, there is no request context as we are in a new
> > > thread).
> > > > > > > > >
> > > > > > > > > A very ugly workaround is to use MyBean in MyTest: once it
> is
> > > > > > created,
> > > > > > > it
> > > > > > > > > become accessible in the other thread...
> > > > > > > > > Is there a better solution?
> > > > > > > > >
> > > > > > > > > A maven project corresponding to this available in github,
> > > please
> > > > > > > search
> > > > > > > > > for rt15/cdi-test.
> > > > > > > > >
> > > > > > > > >
> > > > > > > > > Otherwise here is the source code:
> > > > > > > > > =======================================================
> > > > > > > > > @RunWith(CdiTestRunner.class)
> > > > > > > > > public class MyTest {
> > > > > > > > >
> > > > > > > > >     @Inject
> > > > > > > > >     private MyBean myBean;
> > > > > > > > >
> > > > > > > > >     @Test
> > > > > > > > >     public void test() throws Exception {
> > > > > > > > >
> > > > > > > > >         // Ugly workaround: uncomment next line.
> > > > > > > > >         // this.myBean.foo();
> > > > > > > > >
> > > > > > > > >         MyThread myThread = new MyThread();
> > > > > > > > >         myThread.start();
> > > > > > > > >         myThread.join();
> > > > > > > > >         if (myThread.exception != null) {
> > > > > > > > >             throw myThread.exception;
> > > > > > > > >         }
> > > > > > > > >     }
> > > > > > > > > }
> > > > > > > > > =======================================================
> > > > > > > > > public class MyThread extends Thread {
> > > > > > > > >
> > > > > > > > >     public Exception exception;
> > > > > > > > >
> > > > > > > > >     @Override
> > > > > > > > >     public void run() {
> > > > > > > > >         try {
> > > > > > > > >             MyBean myBean = CDI.current().select(MyBean.
> > > > > > class).get();
> > > > > > > > >             myBean.foo();
> > > > > > > > >         } catch (Exception e) {
> > > > > > > > >             this.exception = e;
> > > > > > > > >         }
> > > > > > > > >     }
> > > > > > > > > }
> > > > > > > > > =======================================================
> > > > > > > > > @ApplicationScoped
> > > > > > > > > public class MyBean {
> > > > > > > > >
> > > > > > > > >     public void foo() {
> > > > > > > > >         System.out.println("foo");
> > > > > > > > >     }
> > > > > > > > > }
> > > > > > > > > =======================================================
> > > > > > > > > deltaspike.testcontrol.mock-support.allow_mocked_beans=
> true
> > > > > > > > > =======================================================
> > > > > > > > >
> > > > > > > > > Regards.
> > > > > > > > >
> > > > > > > >
> > > > > > >
> > > > > >
> > > > >
> > > >
> > >
> >
>

Reply via email to