01: /**
02: * EasyBeans
03: * Copyright (C) 2006 Bull S.A.S.
04: * Contact: easybeans@ow2.org
05: *
06: * This library is free software; you can redistribute it and/or
07: * modify it under the terms of the GNU Lesser General Public
08: * License as published by the Free Software Foundation; either
09: * version 2.1 of the License, or any later version.
10: *
11: * This library is distributed in the hope that it will be useful,
12: * but WITHOUT ANY WARRANTY; without even the implied warranty of
13: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14: * Lesser General Public License for more details.
15: *
16: * You should have received a copy of the GNU Lesser General Public
17: * License along with this library; if not, write to the Free Software
18: * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19: * USA
20: *
21: * --------------------------------------------------------------------------
22: * $Id: TestEntityManagerFlush.java 1970 2007-10-16 11:49:25Z benoitf $
23: * --------------------------------------------------------------------------
24: */package org.ow2.easybeans.tests.entity;
25:
26: import org.ow2.easybeans.tests.common.ejbs.stateful.containermanaged.flushoperation.ItfEntityManagerFlushTester;
27: import org.ow2.easybeans.tests.common.ejbs.stateful.containermanaged.flushoperation.SFSBEntityManagerFlushTester;
28: import org.ow2.easybeans.tests.common.helper.EJBHelper;
29: import org.testng.annotations.BeforeMethod;
30: import org.testng.annotations.Test;
31:
32: /**
33: * Verifies if the methods related with flush(flush(), getFlushMode(),
34: * setFlushMode()) from EntityManager are working properly. The items 3.2.3
35: * (Persistence doc)
36: * @reference JSR 220-PROPOSED FINAL
37: * @requirement Application Server must be running; the bean
38: * SFSBEntityManagerFlushTester must be deployed.
39: * @setup gets the reference of SFSBEntityManagerFlushTester
40: * @author Gisele Pinheiro Souza
41: * @author Eduardo Studzinski Estima de Castro
42: */
43: public class TestEntityManagerFlush {
44:
45: /**
46: * Bean used during the tests.
47: */
48: private ItfEntityManagerFlushTester sfsbFlushTester;
49:
50: /**
51: * Creates the stateful bean used during the tests.
52: * @throws Exception if an error occurs during the lookup.
53: */
54: @BeforeMethod
55: public void setup() throws Exception {
56: sfsbFlushTester = EJBHelper.getBeanRemoteInstance(
57: SFSBEntityManagerFlushTester.class,
58: ItfEntityManagerFlushTester.class);
59: sfsbFlushTester.startup();
60: }
61:
62: /**
63: * Verifies when the persistence context default value is AUTO.
64: * @input -
65: * @output the correct method execution.
66: */
67: @Test
68: public void testVerifyDefaultValue() {
69: sfsbFlushTester.verifyDefaultFlushMode();
70: }
71:
72: /**
73: * Verifies if the container manages the synchronization to the database
74: * when the flush mode is AUTO. In this case, the flush must be made after
75: * query methods.
76: * @input -
77: * @output the correct method execution.
78: */
79: @Test
80: public void testVerifyFlushAuto() {
81: sfsbFlushTester.setFlushModeAuto();
82: }
83:
84: /**
85: * Verifies if the container manages the synchronization to the database
86: * when the flush mode is COMMIT. In this case, the flush must be made when
87: * the container makes the commit.
88: * @input -
89: * @output the correct method execution.
90: */
91: @Test
92: public void testVerifyFlushCommit() {
93: sfsbFlushTester.setFlushModeCommit();
94: }
95: }
|