/*
* Demoiselle Framework
* Copyright (C) 2010 SERPRO
* ----------------------------------------------------------------------------
* This file is part of Demoiselle Framework.
*
* Demoiselle Framework is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public License version 3
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License version 3
* along with this program; if not, see
* or write to the Free Software Foundation, Inc., 51 Franklin Street,
* Fifth Floor, Boston, MA 02110-1301, USA.
* ----------------------------------------------------------------------------
* Este arquivo é parte do Framework Demoiselle.
*
* O Framework Demoiselle é um software livre; você pode redistribuí-lo e/ou
* modificá-lo dentro dos termos da GNU LGPL versão 3 como publicada pela Fundação
* do Software Livre (FSF).
*
* Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA
* GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou
* APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU/LGPL em português
* para maiores detalhes.
*
* Você deve ter recebido uma cópia da GNU LGPL versão 3, sob o título
* "LICENCA.txt", junto com esse programa. Se não, acesse
* ou escreva para a Fundação do Software Livre (FSF) Inc.,
* 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA.
*/
package transaction;
import java.sql.Connection;
import java.sql.SQLException;
import javax.inject.Inject;
import junit.framework.Assert;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import test.Tests;
import br.gov.frameworkdemoiselle.transaction.JDBCTransaction;
import br.gov.frameworkdemoiselle.transaction.Transaction;
import br.gov.frameworkdemoiselle.transaction.TransactionContext;
import br.gov.frameworkdemoiselle.util.Beans;
import br.gov.frameworkdemoiselle.util.NameQualifier;
@RunWith(Arquillian.class)
public class TransactionTest {
private static String PATH = "src/test/resources/transaction";
@Inject
private TransactionalBusiness tb;
private Transaction transaction;
@Inject
private TransactionContext context;
@Inject
private DDL ddl;
@Deployment
public static WebArchive createDeployment() {
WebArchive deployment = Tests.createDeployment(TransactionTest.class);
deployment.addAsResource(Tests.createFileAsset(PATH + "/demoiselle.properties"), "demoiselle.properties");
return deployment;
}
@Before
public void init() throws Exception {
transaction = context.getCurrentTransaction();
ddl.dropAndCreate();
transaction.commit();
}
@Test
public void isTransactionActiveWithInterceptor() {
Assert.assertTrue(tb.isTransactionActiveWithInterceptor());
}
@Test
public void isTransactionActiveWithoutInterceptor() {
Assert.assertFalse(tb.isTransactionActiveWithoutInterceptor());
}
@Test
public void verifyIfTransactionIsJdbcTransaction() {
Assert.assertEquals(transaction.getClass(), JDBCTransaction.class);
}
@Test
public void verifyIfTransactionIsActive() {
Assert.assertTrue(!transaction.isActive());
transaction.begin();
Assert.assertTrue(transaction.isActive());
}
@Test
public void commitWithSuccess() throws Exception{
MyEntity m = new MyEntity();
m.setId(1);
m.setDescription("desc-1");
tb.insert(m);
Assert.assertEquals("desc-1", tb.find(m.getId()).getDescription());
tb.delete(m);
Assert.assertNull(tb.find(m.getId()).getDescription());
}
@Test
public void rollbackWithSuccess() throws Exception {
try{
tb.rollbackWithSuccess();
} catch (Exception e) {
Assert.assertEquals("Exceção criada para marcar transação para rollback", e.getMessage());
}
finally{
MyEntity m = tb.find(3);
Assert.assertNull(tb.find(m.getId()).getDescription());
}
}
@Test(expected=SQLException.class)
public void closedConnection() throws Exception{
MyEntity m = new MyEntity();
m.setId(1);
m.setDescription("desc-1");
tb.insertWithouTransaction(m);
Connection conn = Beans.getReference(Connection.class, new NameQualifier("conn"));
conn.close();
tb.find(m.getId());
}
}