/*
* PatientView
*
* Copyright (c) Worth Solutions Limited 2004-2013
*
* This file is part of PatientView.
*
* PatientView is free software: you can redistribute it and/or modify it under the terms of the
* GNU General Public License as published by the Free Software Foundation, either version 3 of the License,
* or (at your option) any later version.
* PatientView 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 General Public License along with PatientView in a file
* titled COPYING. If not, see <http://www.gnu.org/licenses/>.
*
* @package PatientView
* @link http://www.patientview.org
* @author PatientView <info@patientview.org>
* @copyright Copyright (c) 2004-2013, Worth Solutions Limited
* @license http://www.gnu.org/licenses/gpl-3.0.html The GNU General Public License V3.0
*/
package org.patientview.test.repository;
import org.patientview.patientview.model.Letter;
import org.patientview.model.Specialty;
import org.patientview.patientview.model.UserMapping;
import org.patientview.repository.LetterDao;
import org.patientview.repository.UserMappingDao;
import org.patientview.test.helpers.RepositoryHelpers;
import org.junit.Before;
import org.junit.Test;
import javax.inject.Inject;
import java.util.Calendar;
import java.util.List;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
public class LetterDaoTest extends BaseDaoTest {
@Inject
private LetterDao letterDao;
@Inject
private UserMappingDao userMappingDao;
@Inject
private RepositoryHelpers repositoryHelpers;
private Specialty specialty;
@Before
public void setupSystem() {
specialty = repositoryHelpers.createSpecialty("Specialty1", "ten1", "A test specialty");
}
@Test
public void testAddGetLetter() throws Exception {
Letter letter = getTestObject();
/**
* add
*/
letterDao.save(letter);
assertTrue("Invalid id for new letter", letter.getId() > 0);
/**
* get
*/
Letter savedLetter = letterDao.get(letter.getId());
assertNotNull(savedLetter);
assertEquals("Nhs no not persisted", letter.getNhsno(), letter.getNhsno());
assertEquals("Content not persisted", letter.getContent(), letter.getContent());
assertEquals("Date not persisted", letter.getDate(), letter.getDate());
assertEquals("Type not persisted", letter.getType(), letter.getType());
assertEquals("Unit code not persisted", letter.getUnitcode(), letter.getUnitcode());
}
@Test
public void testDeleteLetterByParameters() throws Exception {
Letter letter = getTestObject();
/**
* add
*/
letterDao.save(letter);
assertTrue("Invalid id for new letter", letter.getId() > 0);
/**
* delete
*/
letterDao.delete(letter.getNhsno(), letter.getUnitcode());
List<Letter> deletedLetters = letterDao.getAll();
assertTrue("Can't delete letter", deletedLetters.size() == 0);
}
@Test
public void testDeleteLetterById() throws Exception {
Letter letter = getTestObject();
/**
* add
*/
letterDao.save(letter);
assertTrue("Invalid id for new letter", letter.getId() > 0);
/**
* delete
*/
letterDao.delete(letter.getId());
List<Letter> deletedLetters = letterDao.getAll();
assertTrue("Can't delete letter", deletedLetters.size() == 0);
}
@Test
public void testGetLettersByUsername() throws Exception {
// create some user mappings to map the letters to
UserMapping userMapping1 = new UserMapping();
userMapping1.setSpecialty(specialty);
userMapping1.setNhsno("nhsno1");
userMapping1.setUnitcode("unicode1");
userMapping1.setUsername("username1");
userMappingDao.save(userMapping1);
assertTrue("Invalid id for new usermapping 1", userMapping1.getId() > 0);
UserMapping userMapping2 = new UserMapping();
userMapping2.setSpecialty(specialty);
userMapping2.setNhsno("nhsno2");
userMapping2.setUnitcode("unicode2");
userMapping2.setUsername("username2");
userMappingDao.save(userMapping2);
assertTrue("Invalid id for new usermapping 2", userMapping2.getId() > 0);
// date for first as want this to be older so we can check ordering
Calendar calendar = Calendar.getInstance();
calendar.add(Calendar.DATE, 5);
// create 2 letters for user 1
Letter letter1 = getTestObject();
letter1.setNhsno(userMapping1.getNhsno());
letter1.setDate(calendar);
letterDao.save(letter1);
assertTrue("Invalid id for letter 1", letter1.getId() > 0);
Letter letter2 = getTestObject();
letter2.setNhsno(userMapping1.getNhsno());
letterDao.save(letter2);
assertTrue("Invalid id for letter 2", letter2.getId() > 0);
// create a third letter for user 2 - we expect this not to be pulled back
Letter letter3 = getTestObject();
letter3.setNhsno(userMapping2.getNhsno());
letterDao.save(letter3);
assertTrue("Invalid id for letter 3", letter3.getId() > 0);
List<Letter> checkLetters = letterDao.get(userMapping1.getUsername(), specialty);
assertNotNull(checkLetters);
assertTrue("No letters found", !checkLetters.isEmpty() && checkLetters.size() > 0);
assertTrue("To many letters found", checkLetters.size() == 2);
assertEquals("Letter1 was not first", checkLetters.get(0).getId(), letter1.getId());
assertEquals("Letter2 was not second", checkLetters.get(1).getId(), letter2.getId());
}
private Letter getTestObject() {
Letter letter = new Letter();
letter.setNhsno("123456789");
letter.setContent("Test letter");
letter.setDate(Calendar.getInstance());
letter.setType("testtype");
letter.setUnitcode("testunit");
return letter;
}
}