package org.opennms.web.rest; import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; import java.util.Calendar; import java.util.Date; import java.util.GregorianCalendar; import java.util.regex.Matcher; import java.util.regex.Pattern; import org.junit.Test; import org.opennms.core.test.MockLogAppender; import org.opennms.core.utils.InetAddressUtils; import org.opennms.core.utils.LogUtils; import org.opennms.netmgt.dao.AlarmDao; import org.opennms.netmgt.dao.DatabasePopulator; import org.opennms.netmgt.dao.DistPollerDao; import org.opennms.netmgt.dao.EventDao; import org.opennms.netmgt.model.OnmsAlarm; import org.opennms.netmgt.model.OnmsEvent; import org.opennms.netmgt.model.OnmsSeverity; import org.springframework.web.context.WebApplicationContext; import org.springframework.web.context.support.WebApplicationContextUtils; public class AlarmStatsRestServiceTest extends AbstractSpringJerseyRestTestCase { private DatabasePopulator m_databasePopulator; private WebApplicationContext m_context; private int count = 0; @Override protected void afterServletStart() throws Exception { count = 0; MockLogAppender.setupLogging(true, "DEBUG"); m_context = WebApplicationContextUtils.getWebApplicationContext(getServletContext()); m_databasePopulator = m_context.getBean("databasePopulator", DatabasePopulator.class); m_databasePopulator.populateDatabase(); final EventDao eventDao = getEventDao(); for (final OnmsEvent event : eventDao.findAll()) { eventDao.delete(event); } eventDao.flush(); final AlarmDao alarmDao = getAlarmDao(); for (final OnmsAlarm alarm : alarmDao.findAll()) { alarmDao.delete(alarm); } alarmDao.flush(); } @Test public void testGetAlarmStats() throws Exception { createAlarm(OnmsSeverity.CLEARED, "admin"); createAlarm(OnmsSeverity.MAJOR, "admin"); createAlarm(OnmsSeverity.CRITICAL, "admin"); createAlarm(OnmsSeverity.CRITICAL, null); createAlarm(OnmsSeverity.MINOR, null); createAlarm(OnmsSeverity.NORMAL, null); final String xml = sendRequest(GET, "/stats/alarms", 200); assertTrue(xml.contains(" totalCount=\"6\"")); assertTrue(xml.contains(" unacknowledgedCount=\"3\"")); assertTrue(xml.contains(" acknowledgedCount=\"3\"")); } @Test public void testGetAlarmStatsBySeverity() throws Exception { createAlarm(OnmsSeverity.CLEARED, "admin"); createAlarm(OnmsSeverity.MAJOR, "admin"); createAlarm(OnmsSeverity.CRITICAL, "admin"); createAlarm(OnmsSeverity.CRITICAL, null); createAlarm(OnmsSeverity.MINOR, null); createAlarm(OnmsSeverity.NORMAL, null); final String xml = sendRequest(GET, "/stats/alarms", parseParamData("comparator=ge&severity=MAJOR"), 200); assertTrue(xml.contains(" totalCount=\"3\"")); assertTrue(xml.contains(" unacknowledgedCount=\"1\"")); assertTrue(xml.contains(" acknowledgedCount=\"2\"")); } @Test public void testNewestAndOldestBySeverity() throws Exception { final OnmsAlarm oldestAckedAlarm = createAlarm(OnmsSeverity.WARNING, "admin"); final OnmsAlarm newestAckedAlarm = createAlarm(OnmsSeverity.WARNING, "admin"); final OnmsAlarm oldestUnackedAlarm = createAlarm(OnmsSeverity.WARNING, null); final OnmsAlarm newestUnackedAlarm = createAlarm(OnmsSeverity.WARNING, null); final String xml = sendRequest(GET, "/stats/alarms/by-severity", 200); final String oldestAckedXml = getXml("oldestAcked", xml); final String newestAckedXml = getXml("newestAcked", xml); final String oldestUnackedXml = getXml("oldestUnacked", xml); final String newestUnackedXml = getXml("newestUnacked", xml); assertTrue("should contain WARNING with ID#" + oldestAckedAlarm.getId(), oldestAckedXml.contains("<alarm severity=\"WARNING\" id=\"" + oldestAckedAlarm.getId() + "\"")); assertTrue(oldestAckedXml.contains("<firstEventTime>2010-01-01T00:00:00")); assertTrue("should contain WARNING with ID#" + newestAckedAlarm.getId(), newestAckedXml.contains("<alarm severity=\"WARNING\" id=\"" + newestAckedAlarm.getId() + "\"")); assertTrue(newestAckedXml.contains("<firstEventTime>2010-01-01T01:00:00")); assertTrue("should contain WARNING with ID#" + oldestUnackedAlarm.getId(), oldestUnackedXml.contains("<alarm severity=\"WARNING\" id=\"" + oldestUnackedAlarm.getId() + "\"")); assertTrue(oldestUnackedXml.contains("<firstEventTime>2010-01-01T02:00:00")); assertTrue("should contain WARNING with ID#" + newestUnackedAlarm.getId(), newestUnackedXml.contains("<alarm severity=\"WARNING\" id=\"" + newestUnackedAlarm.getId() + "\"")); assertTrue(newestUnackedXml.contains("<firstEventTime>2010-01-01T03:00:00")); } private String getXml(final String tag, final String xml) { final Pattern p = Pattern.compile("(<" + tag + ">.*?</" + tag + ">)", Pattern.DOTALL | Pattern.CASE_INSENSITIVE | Pattern.MULTILINE); final Matcher m = p.matcher(xml); if (m.find()) { return m.group(1); } return ""; } @Test public void testGetAlarmStatsSeverityList() throws Exception { createAlarm(OnmsSeverity.CLEARED, "admin"); createAlarm(OnmsSeverity.MAJOR, "admin"); createAlarm(OnmsSeverity.CRITICAL, "admin"); createAlarm(OnmsSeverity.CRITICAL, null); createAlarm(OnmsSeverity.MINOR, null); createAlarm(OnmsSeverity.NORMAL, null); String xml = sendRequest(GET, "/stats/alarms/by-severity", 200); assertTrue(xml.contains("<severities>")); assertTrue(xml.contains("<alarmStatistics")); assertTrue(xml.contains("severity=")); xml = sendRequest(GET, "/stats/alarms/by-severity", parseParamData("severities=MINOR,NORMAL"), 200); assertFalse(xml.contains("CLEARED")); assertFalse(xml.contains("CRITICAL")); assertTrue(xml.contains("MINOR")); assertTrue(xml.contains("NORMAL")); } private OnmsAlarm createAlarm(final OnmsSeverity severity, final String ackUser) { final OnmsEvent event = createEvent(); final OnmsAlarm alarm = new OnmsAlarm(); alarm.setDistPoller(getDistPollerDao().load("localhost")); alarm.setUei(event.getEventUei()); alarm.setAlarmType(1); alarm.setNode(m_databasePopulator.getNode1()); alarm.setDescription("This is a test alarm"); alarm.setLogMsg("this is a test alarm log message"); alarm.setCounter(1); alarm.setIpAddr(InetAddressUtils.UNPINGABLE_ADDRESS); alarm.setSeverity(severity); alarm.setFirstEventTime(event.getEventTime()); alarm.setLastEvent(event); if (ackUser != null) { alarm.setAlarmAckTime(new Date()); alarm.setAlarmAckUser(ackUser); } getAlarmDao().save(alarm); getAlarmDao().flush(); LogUtils.debugf(this, "CreateAlarm: %s", alarm); return alarm; } protected OnmsEvent createEvent() { final Calendar c = new GregorianCalendar(); c.set(2010, Calendar.JANUARY, 1, 0, 0, 0); long time = c.getTimeInMillis(); time = (time - (time % 1000)); final Date date = new Date(time + (count * 60 * 60 * 1000)); final OnmsEvent event = new OnmsEvent(); event.setDistPoller(getDistPollerDao().load("localhost")); event.setEventUei("uei.opennms.org/test/" + count); event.setEventCreateTime(date); event.setEventTime(date); event.setEventDescr("Test event " + count); event.setEventDisplay("Y"); event.setEventLog("Y"); event.setEventHost("es-with-the-most-es"); event.setEventLogMsg("Test event " + count + " (log)"); event.setEventSeverity(OnmsSeverity.MAJOR.getId()); event.setEventSource("AlarmStatsRestServiceTest"); event.setNode(m_databasePopulator.getNode1()); getEventDao().save(event); getEventDao().flush(); count++; return event; } private AlarmDao getAlarmDao() { return m_context.getBean("alarmDao", AlarmDao.class); } private DistPollerDao getDistPollerDao() { return m_context.getBean("distPollerDao", DistPollerDao.class); } private EventDao getEventDao() { return m_context.getBean("eventDao", EventDao.class); } }