package com.vst.dao;
import java.util.List;
import com.vst.dao.BaseDaoTestCase;
import com.vst.model.Reason;
import org.springframework.dao.InvalidDataAccessApiUsageException;
import org.springframework.orm.ObjectRetrievalFailureException;
public class ReasonDaoTest extends BaseDaoTestCase {
private Integer reasonId = new Integer("1");
private ReasonDao dao = null;
public void setReasonDao(ReasonDao dao) {
this.dao = dao;
}
public void testAddReason() throws Exception {
Reason reason = new Reason();
// set required fields
dao.saveReason(reason);
// verify a primary key was assigned
assertNotNull(reason.getReasonId());
// verify set fields are same after save
}
public void testGetReason() throws Exception {
Reason reason = dao.getReason(reasonId);
assertNotNull(reason);
}
public void testGetReasons() throws Exception {
Reason reason = new Reason();
List results = dao.getReasons(reason);
assertTrue(results.size() > 0);
}
public void testSaveReason() throws Exception {
Reason reason = dao.getReason(reasonId);
// update required fields
dao.saveReason(reason);
}
public void testRemoveReason() throws Exception {
Integer removeId = new Integer("3");
dao.removeReason(removeId);
try {
dao.getReason(removeId);
fail("reason found in database");
} catch (ObjectRetrievalFailureException e) {
assertNotNull(e.getMessage());
} catch (InvalidDataAccessApiUsageException e) { // Spring 2.0 throws this one
assertNotNull(e.getMessage());
}
}
}