Commit 9b0c4238d5eb35d64c39adec5383fda08aa36112
1 parent
b119a612
Exists in
master
Adicionados testes de transação usando a anotação @Transactional
Showing
7 changed files
with
356 additions
and
1 deletions
Show diff stats
impl/extension/jpa/src/test/java/transaction/interceptor/JPATransactionTest.java
0 → 100644
| @@ -0,0 +1,93 @@ | @@ -0,0 +1,93 @@ | ||
| 1 | +package transaction.interceptor; | ||
| 2 | + | ||
| 3 | +import javax.inject.Inject; | ||
| 4 | +import javax.persistence.EntityManager; | ||
| 5 | + | ||
| 6 | +import junit.framework.Assert; | ||
| 7 | + | ||
| 8 | +import org.jboss.arquillian.container.test.api.Deployment; | ||
| 9 | +import org.jboss.arquillian.junit.Arquillian; | ||
| 10 | +import org.jboss.shrinkwrap.api.spec.WebArchive; | ||
| 11 | +import org.junit.Before; | ||
| 12 | +import org.junit.Test; | ||
| 13 | +import org.junit.runner.RunWith; | ||
| 14 | + | ||
| 15 | +import test.Tests; | ||
| 16 | +import br.gov.frameworkdemoiselle.annotation.Name; | ||
| 17 | +import br.gov.frameworkdemoiselle.transaction.TransactionContext; | ||
| 18 | + | ||
| 19 | +@RunWith(Arquillian.class) | ||
| 20 | +public class JPATransactionTest { | ||
| 21 | + | ||
| 22 | + private static final String PATH = "src/test/resources/transaction/interceptor"; | ||
| 23 | + | ||
| 24 | + @Inject | ||
| 25 | + private TransactionalBusiness tb; | ||
| 26 | + | ||
| 27 | + @Inject | ||
| 28 | + @Name("pu1") | ||
| 29 | + private EntityManager em1; | ||
| 30 | + | ||
| 31 | + @Inject | ||
| 32 | + @Name("pu2") | ||
| 33 | + private EntityManager em2; | ||
| 34 | + | ||
| 35 | + @Inject | ||
| 36 | + private TransactionContext transactionContext; | ||
| 37 | + | ||
| 38 | + @Deployment | ||
| 39 | + public static WebArchive createDeployment() { | ||
| 40 | + WebArchive deployment = Tests.createDeployment(JPATransactionTest.class); | ||
| 41 | + deployment.addAsResource(Tests.createFileAsset(PATH + "/persistence.xml"), "META-INF/persistence.xml"); | ||
| 42 | + | ||
| 43 | + return deployment; | ||
| 44 | + } | ||
| 45 | + | ||
| 46 | + @Before | ||
| 47 | + public void eraseDatabases(){ | ||
| 48 | + transactionContext.getCurrentTransaction().begin(); | ||
| 49 | + em1.createQuery("DELETE FROM MyEntity1").executeUpdate(); | ||
| 50 | + em2.createQuery("DELETE FROM MyEntity2").executeUpdate(); | ||
| 51 | + transactionContext.getCurrentTransaction().commit(); | ||
| 52 | + } | ||
| 53 | + | ||
| 54 | + @Test | ||
| 55 | + public void isTransactionActiveWithInterceptor(){ | ||
| 56 | + Assert.assertTrue(tb.isTransactionActiveWithInterceptor()); | ||
| 57 | + } | ||
| 58 | + | ||
| 59 | + @Test | ||
| 60 | + public void isTransactionActiveWithoutInterceptor(){ | ||
| 61 | + Assert.assertFalse(tb.isTransactionActiveWithoutInterceptor()); | ||
| 62 | + } | ||
| 63 | + | ||
| 64 | + @Test | ||
| 65 | + public void commitWithSuccess() { | ||
| 66 | + | ||
| 67 | + tb.commitWithSuccess(); | ||
| 68 | + | ||
| 69 | + MyEntity1 entity1 = em1.find(MyEntity1.class, tb.createId("id-1")); | ||
| 70 | + MyEntity2 entity2 = em2.find(MyEntity2.class, tb.createId("id-2")); | ||
| 71 | + | ||
| 72 | + Assert.assertEquals("desc-1", entity1.getDescription()); | ||
| 73 | + Assert.assertEquals("desc-2", entity2.getDescription()); | ||
| 74 | + } | ||
| 75 | + | ||
| 76 | + @Test | ||
| 77 | + public void rollbackWithSuccess() { | ||
| 78 | + | ||
| 79 | + try{ | ||
| 80 | + tb.rollbackWithSuccess(); | ||
| 81 | + } catch (Exception e) { | ||
| 82 | + Assert.assertEquals("Exceção criada para marcar transação para rollback", e.getMessage()); | ||
| 83 | + } | ||
| 84 | + finally{ | ||
| 85 | + MyEntity1 entity1 = em1.find(MyEntity1.class, tb.createId("id-1")); | ||
| 86 | + MyEntity2 entity2 = em2.find(MyEntity2.class, tb.createId("id-2")); | ||
| 87 | + | ||
| 88 | + Assert.assertNull(entity1); | ||
| 89 | + Assert.assertNull(entity2); | ||
| 90 | + } | ||
| 91 | + } | ||
| 92 | + | ||
| 93 | +} | ||
| 0 | \ No newline at end of file | 94 | \ No newline at end of file |
impl/extension/jpa/src/test/java/transaction/interceptor/MyEntity1.java
0 → 100644
| @@ -0,0 +1,29 @@ | @@ -0,0 +1,29 @@ | ||
| 1 | +package transaction.interceptor; | ||
| 2 | + | ||
| 3 | +import javax.persistence.Entity; | ||
| 4 | +import javax.persistence.Id; | ||
| 5 | + | ||
| 6 | +@Entity | ||
| 7 | +public class MyEntity1 { | ||
| 8 | + | ||
| 9 | + @Id | ||
| 10 | + private String id; | ||
| 11 | + | ||
| 12 | + private String description; | ||
| 13 | + | ||
| 14 | + public String getId() { | ||
| 15 | + return id; | ||
| 16 | + } | ||
| 17 | + | ||
| 18 | + public void setId(String id) { | ||
| 19 | + this.id = id; | ||
| 20 | + } | ||
| 21 | + | ||
| 22 | + public String getDescription() { | ||
| 23 | + return description; | ||
| 24 | + } | ||
| 25 | + | ||
| 26 | + public void setDescription(String description) { | ||
| 27 | + this.description = description; | ||
| 28 | + } | ||
| 29 | +} |
impl/extension/jpa/src/test/java/transaction/interceptor/MyEntity2.java
0 → 100644
| @@ -0,0 +1,29 @@ | @@ -0,0 +1,29 @@ | ||
| 1 | +package transaction.interceptor; | ||
| 2 | + | ||
| 3 | +import javax.persistence.Entity; | ||
| 4 | +import javax.persistence.Id; | ||
| 5 | + | ||
| 6 | +@Entity | ||
| 7 | +public class MyEntity2 { | ||
| 8 | + | ||
| 9 | + @Id | ||
| 10 | + private String id; | ||
| 11 | + | ||
| 12 | + private String description; | ||
| 13 | + | ||
| 14 | + public String getId() { | ||
| 15 | + return id; | ||
| 16 | + } | ||
| 17 | + | ||
| 18 | + public void setId(String id) { | ||
| 19 | + this.id = id; | ||
| 20 | + } | ||
| 21 | + | ||
| 22 | + public String getDescription() { | ||
| 23 | + return description; | ||
| 24 | + } | ||
| 25 | + | ||
| 26 | + public void setDescription(String description) { | ||
| 27 | + this.description = description; | ||
| 28 | + } | ||
| 29 | +} |
impl/extension/jpa/src/test/java/transaction/interceptor/TransactionalBusiness.java
0 → 100644
| @@ -0,0 +1,64 @@ | @@ -0,0 +1,64 @@ | ||
| 1 | +package transaction.interceptor; | ||
| 2 | + | ||
| 3 | +import javax.inject.Inject; | ||
| 4 | +import javax.persistence.EntityManager; | ||
| 5 | + | ||
| 6 | +import br.gov.frameworkdemoiselle.annotation.Name; | ||
| 7 | +import br.gov.frameworkdemoiselle.transaction.TransactionContext; | ||
| 8 | +import br.gov.frameworkdemoiselle.transaction.Transactional; | ||
| 9 | + | ||
| 10 | +public class TransactionalBusiness { | ||
| 11 | + | ||
| 12 | + @Inject | ||
| 13 | + @Name("pu1") | ||
| 14 | + private EntityManager em1; | ||
| 15 | + | ||
| 16 | + @Inject | ||
| 17 | + @Name("pu2") | ||
| 18 | + private EntityManager em2; | ||
| 19 | + | ||
| 20 | + @Inject | ||
| 21 | + private TransactionContext transactionContext; | ||
| 22 | + | ||
| 23 | + @Transactional | ||
| 24 | + public boolean isTransactionActiveWithInterceptor(){ | ||
| 25 | + return transactionContext.getCurrentTransaction().isActive(); | ||
| 26 | + } | ||
| 27 | + | ||
| 28 | + public boolean isTransactionActiveWithoutInterceptor(){ | ||
| 29 | + return transactionContext.getCurrentTransaction().isActive(); | ||
| 30 | + } | ||
| 31 | + | ||
| 32 | + @Transactional | ||
| 33 | + public void commitWithSuccess() { | ||
| 34 | + MyEntity1 entity1 = new MyEntity1(); | ||
| 35 | + entity1.setId(createId("id-1")); | ||
| 36 | + entity1.setDescription("desc-1"); | ||
| 37 | + | ||
| 38 | + MyEntity2 entity2 = new MyEntity2(); | ||
| 39 | + entity2.setId(createId("id-2")); | ||
| 40 | + entity2.setDescription("desc-2"); | ||
| 41 | + | ||
| 42 | + em1.persist(entity1); | ||
| 43 | + em2.persist(entity2); | ||
| 44 | + } | ||
| 45 | + | ||
| 46 | + @Transactional | ||
| 47 | + public void rollbackWithSuccess() throws Exception { | ||
| 48 | + MyEntity1 entity1 = new MyEntity1(); | ||
| 49 | + entity1.setId(createId("id-3")); | ||
| 50 | + | ||
| 51 | + MyEntity2 entity2 = new MyEntity2(); | ||
| 52 | + entity2.setId(createId("id-4")); | ||
| 53 | + | ||
| 54 | + em1.persist(entity1); | ||
| 55 | + em2.persist(entity2); | ||
| 56 | + | ||
| 57 | + throw new Exception("Exceção criada para marcar transação para rollback"); | ||
| 58 | + } | ||
| 59 | + | ||
| 60 | + String createId(String id) { | ||
| 61 | + return this.getClass().getName() + "_" + id; | ||
| 62 | + } | ||
| 63 | + | ||
| 64 | +} |
impl/extension/jpa/src/test/java/transaction/manual/JPATransactionTest.java
| @@ -9,6 +9,8 @@ import javax.inject.Inject; | @@ -9,6 +9,8 @@ import javax.inject.Inject; | ||
| 9 | import javax.persistence.EntityManager; | 9 | import javax.persistence.EntityManager; |
| 10 | import javax.persistence.TransactionRequiredException; | 10 | import javax.persistence.TransactionRequiredException; |
| 11 | 11 | ||
| 12 | +import junit.framework.Assert; | ||
| 13 | + | ||
| 12 | import org.jboss.arquillian.container.test.api.Deployment; | 14 | import org.jboss.arquillian.container.test.api.Deployment; |
| 13 | import org.jboss.arquillian.junit.Arquillian; | 15 | import org.jboss.arquillian.junit.Arquillian; |
| 14 | import org.jboss.shrinkwrap.api.spec.WebArchive; | 16 | import org.jboss.shrinkwrap.api.spec.WebArchive; |
| @@ -20,6 +22,8 @@ import br.gov.frameworkdemoiselle.annotation.Name; | @@ -20,6 +22,8 @@ import br.gov.frameworkdemoiselle.annotation.Name; | ||
| 20 | import br.gov.frameworkdemoiselle.transaction.JPATransaction; | 22 | import br.gov.frameworkdemoiselle.transaction.JPATransaction; |
| 21 | import br.gov.frameworkdemoiselle.transaction.Transaction; | 23 | import br.gov.frameworkdemoiselle.transaction.Transaction; |
| 22 | import br.gov.frameworkdemoiselle.transaction.TransactionContext; | 24 | import br.gov.frameworkdemoiselle.transaction.TransactionContext; |
| 25 | +import br.gov.frameworkdemoiselle.util.Beans; | ||
| 26 | +import br.gov.frameworkdemoiselle.util.NameQualifier; | ||
| 23 | 27 | ||
| 24 | @RunWith(Arquillian.class) | 28 | @RunWith(Arquillian.class) |
| 25 | public class JPATransactionTest { | 29 | public class JPATransactionTest { |
| @@ -37,7 +41,7 @@ public class JPATransactionTest { | @@ -37,7 +41,7 @@ public class JPATransactionTest { | ||
| 37 | @Name("pu2") | 41 | @Name("pu2") |
| 38 | private EntityManager em2; | 42 | private EntityManager em2; |
| 39 | 43 | ||
| 40 | - @Deployment(name = "2") | 44 | + @Deployment |
| 41 | public static WebArchive createDeployment() { | 45 | public static WebArchive createDeployment() { |
| 42 | WebArchive deployment = Tests.createDeployment(JPATransactionTest.class); | 46 | WebArchive deployment = Tests.createDeployment(JPATransactionTest.class); |
| 43 | deployment.addAsResource(Tests.createFileAsset(PATH + "/persistence.xml"), "META-INF/persistence.xml"); | 47 | deployment.addAsResource(Tests.createFileAsset(PATH + "/persistence.xml"), "META-INF/persistence.xml"); |
| @@ -120,6 +124,33 @@ public class JPATransactionTest { | @@ -120,6 +124,33 @@ public class JPATransactionTest { | ||
| 120 | assertNull(persisted1); | 124 | assertNull(persisted1); |
| 121 | assertNull(persisted2); | 125 | assertNull(persisted2); |
| 122 | } | 126 | } |
| 127 | + | ||
| 128 | + @Test | ||
| 129 | + public void checkEntityManagerCreatedAfterTransaction(){ | ||
| 130 | + Transaction transaction = transactionContext.getCurrentTransaction(); | ||
| 131 | + | ||
| 132 | + String id = createId("id-5"); | ||
| 133 | + MyEntity1 entity1 = new MyEntity1(); | ||
| 134 | + entity1.setId(id); | ||
| 135 | + entity1.setDescription("Test description"); | ||
| 136 | + | ||
| 137 | + Assert.assertFalse(transaction.isActive()); | ||
| 138 | + transaction.begin(); | ||
| 139 | + Assert.assertTrue(transaction.isActive()); | ||
| 140 | + | ||
| 141 | + EntityManager em1 = Beans.getReference(EntityManager.class, new NameQualifier("pu3")); | ||
| 142 | + | ||
| 143 | + try{ | ||
| 144 | + em1.persist(entity1); | ||
| 145 | + transaction.commit(); | ||
| 146 | + } | ||
| 147 | + catch(TransactionRequiredException te){ | ||
| 148 | + Assert.fail("Entity Manager não ingressou em transação já em curso: "+te.getMessage()); | ||
| 149 | + } | ||
| 150 | + | ||
| 151 | + entity1 = em1.find(MyEntity1.class, id); | ||
| 152 | + Assert.assertEquals("Test description", entity1.getDescription()); | ||
| 153 | + } | ||
| 123 | 154 | ||
| 124 | private String createId(String id) { | 155 | private String createId(String id) { |
| 125 | return this.getClass().getName() + "_" + id; | 156 | return this.getClass().getName() + "_" + id; |
impl/extension/jpa/src/test/resources/transaction/interceptor/persistence.xml
0 → 100644
| @@ -0,0 +1,96 @@ | @@ -0,0 +1,96 @@ | ||
| 1 | +<!-- | ||
| 2 | + Demoiselle Framework | ||
| 3 | + Copyright (C) 2010 SERPRO | ||
| 4 | + ============================================================================ | ||
| 5 | + This file is part of Demoiselle Framework. | ||
| 6 | + | ||
| 7 | + Demoiselle Framework is free software; you can redistribute it and/or | ||
| 8 | + modify it under the terms of the GNU Lesser General Public License version 3 | ||
| 9 | + as published by the Free Software Foundation. | ||
| 10 | + | ||
| 11 | + This program 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 | ||
| 14 | + GNU General Public License for more details. | ||
| 15 | + | ||
| 16 | + You should have received a copy of the GNU Lesser General Public License version 3 | ||
| 17 | + along with this program; if not, see <http://www.gnu.org/licenses/> | ||
| 18 | + or write to the Free Software Foundation, Inc., 51 Franklin Street, | ||
| 19 | + Fifth Floor, Boston, MA 02110-1301, USA. | ||
| 20 | + ============================================================================ | ||
| 21 | + Este arquivo é parte do Framework Demoiselle. | ||
| 22 | + | ||
| 23 | + O Framework Demoiselle é um software livre; você pode redistribuí-lo e/ou | ||
| 24 | + modificá-lo dentro dos termos da GNU LGPL versão 3 como publicada pela Fundação | ||
| 25 | + do Software Livre (FSF). | ||
| 26 | + | ||
| 27 | + Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA | ||
| 28 | + GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou | ||
| 29 | + APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU/LGPL em português | ||
| 30 | + para maiores detalhes. | ||
| 31 | + | ||
| 32 | + Você deve ter recebido uma cópia da GNU LGPL versão 3, sob o título | ||
| 33 | + "LICENCA.txt", junto com esse programa. Se não, acesse <http://www.gnu.org/licenses/> | ||
| 34 | + ou escreva para a Fundação do Software Livre (FSF) Inc., | ||
| 35 | + 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA. | ||
| 36 | +--> | ||
| 37 | +<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||
| 38 | + xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"> | ||
| 39 | + | ||
| 40 | + <!-- | ||
| 41 | + <persistence-unit name="pu1" transaction-type="RESOURCE_LOCAL"> | ||
| 42 | + <non-jta-data-source>jdbc/arquillian1</non-jta-data-source> | ||
| 43 | + | ||
| 44 | + <class>transaction.manual.MyEntity1</class> | ||
| 45 | + <class>transaction.manual.MyEntity2</class> | ||
| 46 | + | ||
| 47 | + <properties> | ||
| 48 | + <property name="eclipselink.ddl-generation" value="drop-and-create-tables" /> | ||
| 49 | + <property name="eclipselink.logging.level.sql" value="FINE" /> | ||
| 50 | + <property name="eclipselink.logging.parameters" value="true" /> | ||
| 51 | + </properties> | ||
| 52 | + </persistence-unit> | ||
| 53 | + | ||
| 54 | + <persistence-unit name="pu2" transaction-type="RESOURCE_LOCAL"> | ||
| 55 | + <non-jta-data-source>jdbc/arquillian2</non-jta-data-source> | ||
| 56 | + | ||
| 57 | + <class>transaction.manual.MyEntity1</class> | ||
| 58 | + <class>transaction.manual.MyEntity2</class> | ||
| 59 | + | ||
| 60 | + <properties> | ||
| 61 | + <property name="eclipselink.ddl-generation" value="drop-and-create-tables" /> | ||
| 62 | + <property name="eclipselink.logging.level.sql" value="FINE" /> | ||
| 63 | + <property name="eclipselink.logging.parameters" value="true" /> | ||
| 64 | + </properties> | ||
| 65 | + </persistence-unit> | ||
| 66 | + --> | ||
| 67 | + | ||
| 68 | + <!-- | ||
| 69 | + --> | ||
| 70 | + <persistence-unit name="pu1" transaction-type="RESOURCE_LOCAL"> | ||
| 71 | + <non-jta-data-source>java:jboss/datasources/ExampleDS</non-jta-data-source> | ||
| 72 | + | ||
| 73 | + <class>transaction.interceptor.MyEntity1</class> | ||
| 74 | + <class>transaction.interceptor.MyEntity2</class> | ||
| 75 | + | ||
| 76 | + <properties> | ||
| 77 | + <property name="hibernate.show_sql" value="true" /> | ||
| 78 | + <property name="hibernate.format_sql" value="false" /> | ||
| 79 | + <property name="hibernate.hbm2ddl.auto" value="create-drop" /> | ||
| 80 | + </properties> | ||
| 81 | + </persistence-unit> | ||
| 82 | + | ||
| 83 | + <persistence-unit name="pu2" transaction-type="RESOURCE_LOCAL"> | ||
| 84 | + <non-jta-data-source>java:jboss/datasources/ExampleDS</non-jta-data-source> | ||
| 85 | + | ||
| 86 | + <class>transaction.interceptor.MyEntity1</class> | ||
| 87 | + <class>transaction.interceptor.MyEntity2</class> | ||
| 88 | + | ||
| 89 | + <properties> | ||
| 90 | + <property name="hibernate.show_sql" value="true" /> | ||
| 91 | + <property name="hibernate.format_sql" value="false" /> | ||
| 92 | + <property name="hibernate.hbm2ddl.auto" value="create-drop" /> | ||
| 93 | + </properties> | ||
| 94 | + </persistence-unit> | ||
| 95 | + | ||
| 96 | +</persistence> | ||
| 0 | \ No newline at end of file | 97 | \ No newline at end of file |
impl/extension/jpa/src/test/resources/transaction/manual/persistence.xml
| @@ -92,5 +92,18 @@ | @@ -92,5 +92,18 @@ | ||
| 92 | <property name="hibernate.hbm2ddl.auto" value="create-drop" /> | 92 | <property name="hibernate.hbm2ddl.auto" value="create-drop" /> |
| 93 | </properties> | 93 | </properties> |
| 94 | </persistence-unit> | 94 | </persistence-unit> |
| 95 | + | ||
| 96 | + <persistence-unit name="pu3" transaction-type="RESOURCE_LOCAL"> | ||
| 97 | + <non-jta-data-source>java:jboss/datasources/ExampleDS</non-jta-data-source> | ||
| 98 | + | ||
| 99 | + <class>transaction.manual.MyEntity1</class> | ||
| 100 | + <class>transaction.manual.MyEntity2</class> | ||
| 101 | + | ||
| 102 | + <properties> | ||
| 103 | + <property name="hibernate.show_sql" value="true" /> | ||
| 104 | + <property name="hibernate.format_sql" value="false" /> | ||
| 105 | + <property name="hibernate.hbm2ddl.auto" value="create-drop" /> | ||
| 106 | + </properties> | ||
| 107 | + </persistence-unit> | ||
| 95 | 108 | ||
| 96 | </persistence> | 109 | </persistence> |
| 97 | \ No newline at end of file | 110 | \ No newline at end of file |