/*******************************************************************************
* This file is part of OpenNMS(R).
*
* Copyright (C) 2009-2011 The OpenNMS Group, Inc.
* OpenNMS(R) is Copyright (C) 1999-2011 The OpenNMS Group, Inc.
*
* OpenNMS(R) is a registered trademark of The OpenNMS Group, Inc.
*
* OpenNMS(R) 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.
*
* OpenNMS(R) 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 OpenNMS(R). If not, see:
* http://www.gnu.org/licenses/
*
* For more information contact:
* OpenNMS(R) Licensing <license@opennms.org>
* http://www.opennms.org/
* http://www.opennms.com/
*******************************************************************************/
package org.opennms.web.outage;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import java.util.Date;
import java.util.Properties;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.opennms.core.utils.BeanUtils;
import org.opennms.core.utils.InetAddressUtils;
import org.opennms.netmgt.dao.DatabasePopulator;
import org.opennms.netmgt.dao.db.JUnitConfigurationEnvironment;
import org.opennms.netmgt.dao.db.JUnitTemporaryDatabase;
import org.opennms.core.test.MockLogAppender;
import org.opennms.core.test.OpenNMSJUnit4ClassRunner;
import org.opennms.netmgt.model.OnmsEvent;
import org.opennms.netmgt.model.OnmsMonitoredService;
import org.opennms.netmgt.model.OnmsOutage;
import org.opennms.netmgt.model.outage.OutageSummary;
import org.opennms.web.outage.filter.OutageCriteria;
import org.opennms.web.outage.filter.OutageIdFilter;
import org.opennms.web.outage.filter.RegainedServiceDateBeforeFilter;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.transaction.annotation.Transactional;
@RunWith(OpenNMSJUnit4ClassRunner.class)
@ContextConfiguration(locations={
"classpath:/META-INF/opennms/applicationContext-dao.xml",
"classpath*:/META-INF/opennms/component-dao.xml",
"classpath*:/META-INF/opennms/component-service.xml",
"classpath:/daoWebRepositoryTestContext.xml"
})
@JUnitConfigurationEnvironment
@JUnitTemporaryDatabase
public class DaoWebOutageRepositoryTest implements InitializingBean {
@Autowired
DatabasePopulator m_dbPopulator;
@Autowired
WebOutageRepository m_daoOutageRepo;
@Override
public void afterPropertiesSet() throws Exception {
BeanUtils.assertAutowiring(this);
}
@BeforeClass
public static void setupLogging(){
Properties props = new Properties();
props.setProperty("log4j.logger.org.hibernate", "INFO");
props.setProperty("log4j.logger.org.springframework", "INFO");
props.setProperty("log4j.logger.org.hibernate.SQL", "DEBUG");
MockLogAppender.setupLogging(props);
}
@Before
public void setUp(){
m_dbPopulator.populateDatabase();
OnmsMonitoredService svc2 = m_dbPopulator.getMonitoredServiceDao().get(2, InetAddressUtils.addr("192.168.2.1"), "ICMP");
OnmsEvent event = m_dbPopulator.getEventDao().get(1);
OnmsOutage unresolved2 = new OnmsOutage(new Date(), event, svc2);
m_dbPopulator.getOutageDao().save(unresolved2);
m_dbPopulator.getOutageDao().flush();
}
@Test
@Transactional
public void testCountMatchingOutages(){
int count = m_daoOutageRepo.countMatchingOutages(new OutageCriteria());
assertEquals(3, count);
count = m_daoOutageRepo.countMatchingOutages(new OutageCriteria(new RegainedServiceDateBeforeFilter(new Date())));
assertEquals(1, count);
}
@Test
@JUnitTemporaryDatabase // Relies on specific IDs so we need a fresh database
public void testGetMatchingOutages(){
Outage[] outage = m_daoOutageRepo.getMatchingOutages(new OutageCriteria());
assertEquals(3, outage.length);
outage = m_daoOutageRepo.getMatchingOutages(new OutageCriteria(new RegainedServiceDateBeforeFilter(new Date())));
assertEquals(1, outage.length);
outage = m_daoOutageRepo.getMatchingOutages(new OutageCriteria(new OutageIdFilter(1)));
assertEquals(1, outage.length);
assertEquals(1, outage[0].getId());
outage = m_daoOutageRepo.getMatchingOutages(new OutageCriteria(new OutageIdFilter(2)));
assertEquals(1, outage.length);
assertEquals(2, outage[0].getId());
}
@Test
@JUnitTemporaryDatabase // Relies on specific IDs so we need a fresh database
public void testGetOutage(){
Outage outage = m_daoOutageRepo.getOutage(1);
assertNotNull(outage);
}
@Test
@JUnitTemporaryDatabase // Relies on records created in @Before so we need a fresh database
public void testGetOutageSummaries() {
OutageSummary[] summaries = m_daoOutageRepo.getMatchingOutageSummaries(new OutageCriteria());
assertEquals("there should be 2 outage summary in the default (current) outage criteria match", 2, summaries.length);
}
@Test
@JUnitTemporaryDatabase // Relies on records created in @Before so we need a fresh database
public void testCountMatchingSummaries(){
int count = m_daoOutageRepo.countMatchingOutageSummaries(new OutageCriteria());
assertEquals(2, count);
}
}