/* Copyright 2011 Jose Maria Arranz Santamaria Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ package unittest; import example.CreateDBModel; import example.DataSourceFactoryOfLoaderJDBC; import example.DataSourceLoader; import example.dao.CompanyDAO; import example.dao.ContactDAO; import example.dao.ContactTreeDAO; import example.dao.PersonDAO; import example.loadmanually.DataSourceLoaderManualLoad; import example.model.Company; import example.model.Contact; import example.model.Person; import java.util.List; import javax.sql.DataSource; import jepl.*; import static org.junit.Assert.assertTrue; import org.junit.*; import unittest.shared.TestDAOShared; /** * * @author jmarranz */ public class TestDAOTreeInheritance { public TestDAOTreeInheritance() { } @BeforeClass public static void setUpClass() throws Exception { } @AfterClass public static void tearDownClass() throws Exception { } @Before public void setUp() { } @After public void tearDown() { } @Test public void someTest() { DataSourceLoader[] dsFactoryArr = DataSourceFactoryOfLoaderJDBC.getDataSourceFactoryOfLoaderJDBC().getDataSourceLoaderList(); for(int i = 0; i < dsFactoryArr.length; i++) { DataSourceLoader dsFactory = dsFactoryArr[i]; try { System.out.println("PROVIDER: " + dsFactory.getName()); DataSource ds = dsFactory.getDataSource(); CreateDBModel.createDB(ds); execTest(ds); } finally { dsFactory.destroy(); } } } public void execTest(DataSource ds) { JEPLBootNonJTA boot = JEPLBootRoot.get().createJEPLBootNonJTA(); JEPLNonJTADataSource jds; try { jds = boot.createJEPLNonJTADataSource(ds); jds.setDefaultAutoCommit(false); operations(new ContactTreeDAO(jds),new PersonDAO(jds),new CompanyDAO(jds),new ContactDAO(jds)); jds = boot.createJEPLNonJTADataSource(ds); jds.setDefaultAutoCommit(true); operations(new ContactTreeDAO(jds),new PersonDAO(jds),new CompanyDAO(jds),new ContactDAO(jds)); jds = boot.createJEPLNonJTADataSource(ds); final JEPLDataSource jds2 = jds; JEPLTask<Object> task = new JEPLTask<Object>() { @Override public Object exec() throws Exception { operations(new ContactTreeDAO(jds2),new PersonDAO(jds2),new CompanyDAO(jds2),new ContactDAO(jds2)); return null; } }; jds.exec(task,true); // No transaction jds.exec(task,false); // Transaction } catch(AssertionError ex) { ex.printStackTrace(); // To show the stack fully throw ex; } catch(Exception ex) { ex.printStackTrace(); // To show the stack fully throw new RuntimeException(ex); } } public void operations(ContactTreeDAO contactDAOMult,PersonDAO personDao,CompanyDAO companyDao,ContactDAO contactDao) { // Tables empty initialization // because delete actions are tricky, doing manually (testing delete later) contactDAOMult.getJEPLDAO().createJEPLDALQuery("DELETE FROM PERSON").executeUpdate(); contactDAOMult.getJEPLDAO().createJEPLDALQuery("DELETE FROM COMPANY").executeUpdate(); contactDAOMult.getJEPLDAO().createJEPLDALQuery("DELETE FROM CONTACT").executeUpdate(); // Test ContactTreeDAO selectAll List<Contact> list = contactDAOMult.selectAll(); assertTrue(list.isEmpty()); Contact contact = TestDAOShared.insertContact(contactDao); Person person = TestDAOShared.insertPerson(personDao); Company company = TestDAOShared.insertCompany(companyDao); list = contactDAOMult.selectAll(); assertTrue(list.size() == 3); assertTrue(list.get(0).getClass().equals(Contact.class)); assertTrue(list.get(1).getClass().equals(Person.class)); assertTrue(list.get(2).getClass().equals(Company.class)); // Test ContactTreeDAO selectById Contact contact3 = contactDAOMult.selectById(contact.getId()); assertTrue(contact3 != null); assertTrue(contact3.getClass().equals(Contact.class)); assertTrue(contact3.getName().equals(contact.getName())); assertTrue(contact3.getPhone().equals(contact.getPhone())); assertTrue(contact3.getEmail().equals(contact.getEmail())); Contact person3 = contactDAOMult.selectById(person.getId()); assertTrue(person3 != null); assertTrue(person3.getClass().equals(Person.class)); assertTrue(person3.getName().equals(person.getName())); assertTrue(person3.getPhone().equals(person.getPhone())); assertTrue(person3.getEmail().equals(person.getEmail())); assertTrue(((Person)person3).getAge() == person.getAge()); Contact company3 = contactDAOMult.selectById(company.getId()); assertTrue(company3 != null); assertTrue(company3.getClass().equals(Company.class)); assertTrue(company3.getName().equals(company.getName())); assertTrue(company3.getPhone().equals(company.getPhone())); assertTrue(company3.getEmail().equals(company.getEmail())); assertTrue(((Company)company3).getAddress().equals(company.getAddress())); // Test ContactTreeDAO.deleteAllCascade list = contactDAOMult.selectAll(); assertTrue(list.size() == 3); int count = contactDAOMult.deleteAllCascade(); if (!DataSourceLoaderManualLoad.android) // SQLDroid devuelve siempre 0 assertTrue(count == 3); list = contactDAOMult.selectAll(); assertTrue(list.isEmpty()); // Test ContactTreeDAO.deleteAllNotCascade (MySQL Only) if (!DataSourceLoaderManualLoad.android) { contact = TestDAOShared.insertContact(contactDao); person = TestDAOShared.insertPerson(personDao); company = TestDAOShared.insertCompany(companyDao); count = contactDAOMult.deleteAllNotCascade(); // MySQL Only assertTrue(count == 3); list = contactDAOMult.selectAll(); assertTrue(list.isEmpty()); } // Test ContactTreeDAO.deleteByIdNotCascade (MySQL Only) if (!DataSourceLoaderManualLoad.android) { contact = TestDAOShared.insertContact(contactDao); person = TestDAOShared.insertPerson(personDao); company = TestDAOShared.insertCompany(companyDao); boolean deleted; deleted = contactDAOMult.deleteByIdNotCascade(contact.getId()); // MySQL Only assertTrue(deleted); deleted = contactDAOMult.deleteByIdNotCascade(person.getId()); assertTrue(deleted); deleted = contactDAOMult.deleteByIdNotCascade(company.getId()); assertTrue(deleted); list = contactDAOMult.selectAll(); assertTrue(list.isEmpty()); } } }