本文整理汇总了Java中org.apache.deltaspike.cdise.api.ContextControl.stopContext方法的典型用法代码示例。如果您正苦于以下问题:Java ContextControl.stopContext方法的具体用法?Java ContextControl.stopContext怎么用?Java ContextControl.stopContext使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类org.apache.deltaspike.cdise.api.ContextControl
的用法示例。
在下文中一共展示了ContextControl.stopContext方法的12个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: startRequestScope
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
@AroundInvoke
public Object startRequestScope(final InvocationContext ctx) throws Exception {
Object result = null;
ContextControl contextControl = null;
if(!isRequestScopeActive()) {
contextControl = CDI.current().select(ContextControl.class).get();
contextControl.startContext(RequestScoped.class);
}
try {
result = ctx.proceed();
}
finally {
if(contextControl != null) {
contextControl.stopContext(RequestScoped.class);
}
}
return result;
}
示例2: testRequestScopedBeanPerformance
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
@Test(priority = 3)
public void testRequestScopedBeanPerformance() throws InterruptedException
{
final SimpleRequestScopedBeanWithoutInterceptor underTest = getInstance(cdiContainer.getBeanManager(), SimpleRequestScopedBeanWithoutInterceptor.class);
final ContextControl contextControl = cdiContainer.getContextControl();
contextControl.startContext(RequestScoped.class);
Assert.assertEquals(underTest.theMeaningOfLife(), 42);
contextControl.stopContext(RequestScoped.class);
executeInParallel("invocation on @RequestScoped bean", new Runnable()
{
@Override
public void run()
{
contextControl.startContext(RequestScoped.class);
for (int i = 0; i < NUM_ITERATION; i++)
{
// this line does the actual bean invocation.
underTest.theMeaningOfLife();
}
contextControl.stopContext(RequestScoped.class);
}
});
}
示例3: setUp
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
@Before
public final void setUp() throws Exception {
System.out.printf("AbstractCdiContainerTest#setUp() containerRefCount=%d, cdiContainer=%s\n", containerRefCount.get(), cdiContainer );
if ( cdiContainer != null ) {
containerRefCount.incrementAndGet();
final ContextControl ctxCtrl = BeanProvider.getContextualReference(ContextControl.class);
//stop the RequestContext to dispose of the @RequestScoped EntityManager
ctxCtrl.stopContext(RequestScoped.class);
//immediately restart the context again
ctxCtrl.startContext(RequestScoped.class);
// perform injection into the very own test class
final BeanManager beanManager = cdiContainer.getBeanManager();
final CreationalContext creationalContext = beanManager.createCreationalContext(null);
final AnnotatedType annotatedType = beanManager.createAnnotatedType(this.getClass());
final InjectionTarget injectionTarget = beanManager.createInjectionTarget(annotatedType);
injectionTarget.inject(this, creationalContext);
}
}
示例4: tearDown
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
@After
public final void tearDown() throws Exception {
System.out.printf("AbstractCdiContainerTest#tearDown() containerRefCount=%d, cdiContainer=%s\n", containerRefCount.get(), cdiContainer );
if (cdiContainer != null) {
final ContextControl ctxCtrl = BeanProvider.getContextualReference(ContextControl.class);
//stop the RequestContext to dispose of the @RequestScoped EntityManager
ctxCtrl.stopContext(RequestScoped.class);
//immediately restart the context again
ctxCtrl.startContext(RequestScoped.class);
// cdiContainer.getContextControl().stopContext(RequestScoped.class);
// cdiContainer.getContextControl().startContext(RequestScoped.class);
containerRefCount.decrementAndGet();
}
}
示例5: main
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
public static void main(String[] args) throws InterruptedException
{
CdiContainer cdiContainer = CdiContainerLoader.getCdiContainer();
cdiContainer.boot();
ContextControl contextControl = cdiContainer.getContextControl();
contextControl.startContext(ApplicationScoped.class);
GlobalResultHolder globalResultHolder =
BeanProvider.getContextualReference(GlobalResultHolder.class);
while (globalResultHolder.getCount() < 100)
{
Thread.sleep(500);
LOG.info("current count: " + globalResultHolder.getCount());
}
LOG.info("completed!");
contextControl.stopContext(ApplicationScoped.class);
cdiContainer.shutdown();
}
示例6: testCreateEmployee
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
@Test
public void testCreateEmployee() {
ContextControl contextControl = CDI.current().select(ContextControl.class).get();
contextControl.startContext(RequestScoped.class);
Employees e = new Employees();
e.setFirstName("Bob");
e.setLastName("Hope");
EntityManager em = CDI.current().select(EntityManager.class).get();
Employees e2 = em.merge(e);
System.out.println("Employee id :"+e2.getId());
contextControl.stopContext(RequestScoped.class);
}
示例7: preStop
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
@Override
public void preStop() {
final ContextControl contextControl = this.container.getContextControl();
contextControl.stopContext(RequestScoped.class);
contextControl.stopContext(SessionScoped.class);
contextControl.stopContext(ApplicationScoped.class);
}
示例8: requestDestroyed
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
@Override
public void requestDestroyed(ServletRequestEvent servletRequestEvent)
{
LOG.log(Level.FINER,"Request done.");
ContextControl contextControl = (ContextControl)servletRequestEvent.getServletRequest()
.getAttribute(CDI_REQ_CONTEXT);
contextControl.stopContext(RequestScoped.class);
}
示例9: startScopes
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
private void startScopes(CdiContainer container,
Class testClass,
Method testMethod,
Class<? extends Annotation>... restrictedScopes) {
ContextControl contextControl = container.getContextControl();
List<Class<? extends Annotation>> scopeClasses = new ArrayList<Class<? extends Annotation>>();
Collections.addAll(scopeClasses, this.testControl.startScopes());
if (scopeClasses.isEmpty()) {
addScopesForDefaultBehavior(scopeClasses);
} else {
List<TestControlValidator> testControlValidatorList =
ServiceUtils.loadServiceImplementations(TestControlValidator.class);
for (TestControlValidator testControlValidator : testControlValidatorList) {
if (testControlValidator instanceof TestAware) {
if (testMethod != null) {
((TestAware) testControlValidator).setTestMethod(testMethod);
}
((TestAware) testControlValidator).setTestClass(testClass);
}
try {
testControlValidator.validate(this.testControl);
} finally {
if (testControlValidator instanceof TestAware) {
((TestAware) testControlValidator).setTestClass(null);
((TestAware) testControlValidator).setTestMethod(null);
}
}
}
}
for (Class<? extends Annotation> scopeAnnotation : scopeClasses) {
if (this.parent != null && this.parent.isScopeStarted(scopeAnnotation)) {
continue;
}
if (isRestrictedScope(scopeAnnotation, restrictedScopes)) {
continue;
}
try {
//force a clean context - TODO discuss onScopeStopped call
contextControl.stopContext(scopeAnnotation);
contextControl.startContext(scopeAnnotation);
this.startedScopes.add(scopeAnnotation);
onScopeStarted(scopeAnnotation);
} catch (RuntimeException e) {
Logger logger = Logger.getLogger(CdiCucumberTestRunner.class.getName());
logger.setLevel(Level.SEVERE);
logger.log(Level.SEVERE, "failed to start scope @" + scopeAnnotation.getName(), e);
}
}
}
示例10: requestDestroyed
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
@Override
public void requestDestroyed(ServletRequestEvent servletRequestEvent) {
CdiContainer container = CdiContainerLoader.getCdiContainer();
ContextControl contextControl = container.getContextControl();
contextControl.stopContext(RequestScoped.class);
}
示例11: testParallelThreadExecution
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
@Test
public void testParallelThreadExecution() throws Exception
{
final CdiContainer cc = CdiContainerLoader.getCdiContainer();
Assert.assertNotNull(cc);
cc.boot();
cc.getContextControl().startContexts();
final BeanManager bm = cc.getBeanManager();
Assert.assertNotNull(bm);
final AtomicInteger numErrors = new AtomicInteger(0);
final ContextControl contextControl = cc.getContextControl();
Runnable runnable = new Runnable()
{
@Override
public void run()
{
try
{
contextControl.startContext(SessionScoped.class);
contextControl.startContext(RequestScoped.class);
Set<Bean<?>> beans = bm.getBeans(CarRepair.class);
Bean<?> bean = bm.resolve(beans);
CarRepair carRepair = (CarRepair)
bm.getReference(bean, CarRepair.class, bm.createCreationalContext(bean));
Assert.assertNotNull(carRepair);
for (int i = 0; i < 100000; i++)
{
// we need the threads doing something ;)
Assert.assertNotNull(carRepair.getCar());
Assert.assertNotNull(carRepair.getCar().getUser());
Assert.assertNull(carRepair.getCar().getUser().getName());
}
contextControl.stopContext(RequestScoped.class);
contextControl.stopContext(SessionScoped.class);
}
catch (Throwable e)
{
log.log(Level.SEVERE, "An exception happened on a new worker thread", e);
numErrors.incrementAndGet();
}
}
};
Thread[] threads = new Thread[NUM_THREADS];
for (int i = 0 ; i < NUM_THREADS; i++)
{
threads[i] = new Thread(runnable);
}
for (int i = 0 ; i < NUM_THREADS; i++)
{
threads[i].start();
}
for (int i = 0 ; i < NUM_THREADS; i++)
{
threads[i].join();
}
Assert.assertEquals("An error happened while executing parallel threads", 0, numErrors.get());
cc.shutdown();
}
示例12: helloRequestScoped
import org.apache.deltaspike.cdise.api.ContextControl; //导入方法依赖的package包/类
@Test
@InSequence(0)
@Ignore
public void helloRequestScoped() {
Assert.assertNotNull(myRequestBean);
ContextControl ctxCtrl = BeanProvider.getContextualReference(ContextControl.class);
ctxCtrl.startContext(RequestScoped.class);
int myBeanHashcode = myRequestBean.getMyBean().hashCode();
int myKieSessionHashcode = myRequestBean.getkSession().hashCode();
int result = myRequestBean.doSomething("hello 0");
Assert.assertEquals(1, result);
ctxCtrl.stopContext(RequestScoped.class);
ctxCtrl.startContext(RequestScoped.class);
Assert.assertNotEquals(myBeanHashcode, myRequestBean.getMyBean().hashCode());
Assert.assertNotEquals(myKieSessionHashcode, myRequestBean.getkSession().hashCode());
myBeanHashcode = myRequestBean.getMyBean().hashCode();
myKieSessionHashcode = myRequestBean.getkSession().hashCode();
result = myRequestBean.doSomething("hello 1");
Assert.assertEquals(1, result);
ctxCtrl.stopContext(RequestScoped.class);
ctxCtrl.startContext(RequestScoped.class);
Assert.assertNotEquals(myBeanHashcode, myRequestBean.getMyBean().hashCode());
Assert.assertNotEquals(myKieSessionHashcode, myRequestBean.getkSession().hashCode());
myBeanHashcode = myRequestBean.getMyBean().hashCode();
myKieSessionHashcode = myRequestBean.getkSession().hashCode();
result = myRequestBean.doSomething("hello 2");
Assert.assertEquals(1, result);
myBeanHashcode = myRequestBean.getMyBean().hashCode();
myKieSessionHashcode = myRequestBean.getkSession().hashCode();
ctxCtrl.stopContext(RequestScoped.class);
ctxCtrl.startContext(RequestScoped.class);
Assert.assertNotEquals(myBeanHashcode, myRequestBean.getMyBean().hashCode());
Assert.assertNotEquals(myKieSessionHashcode, myRequestBean.getkSession().hashCode());
}