$:.unshift "../lib" require 'th_mauve' require 'mauve/people_list' require 'mauve/configuration' require 'mauve/configuration_builder' require 'mauve/configuration_builders' require 'pp' class TcMauvePeopleList < Mauve::UnitTest include Mauve def setup super setup_database end def teardown teardown_database super end def test_send_alert # # Allows us to pick up notifications sent. # $sent_notifications = [] config =< 60.seconds ) } person ("test2") { email "test@example.com" all { email } suppress_notifications_after( 1 => 1.minute ) } people_list "testers", %w(test1 test2) alert_group("default") { level URGENT notify("testers") { every 10.seconds } } EOF Configuration.current = ConfigurationBuilder.parse(config) notification_buffer = Configuration.current.notification_methods["email"].deliver_to_queue Server.instance.setup people_list = Configuration.current.people_lists["testers"] alert = Alert.new( :alert_id => "test", :source => "test", :subject => "test" ) alert.raise! # assert_equal(false, .suppressed?, "Person suppressed before we even begin!") start_time = Time.now # # 6 alerts every 60 seconds. # [ [0, true, true], [5, true, false], [10, true, false], [15, true, false], [20, true, false], [25, true, false], # 6th alert -- suppress from now on [30, false, false], [35, false, false], [40, false, false], [60, false, true], # One minute after starting -- should still be suppressed [65, false, false], [70, false, false], [75, false, false], [80, false, false], [85, true, false], # One minute after the last alert was sent, start sending again. [90, true, false] ].each do |offset, test1sent, test2sent| # # Advance in to the future! # Timecop.freeze(start_time + offset) people_list.people.each{|person| person.send_alert(alert.level, alert) } if test1sent or test2sent n_notifications = (test2sent ? 1 : 0) + (test1sent ? 1 : 0) assert_equal(n_notifications, notification_buffer.length, "Notification not sent when it should have been at #{Time.now}.") # # Pop the notification off the buffer. # n_notifications.times{ notification_buffer.pop } # assert_equal(Time.now, person.notification_thresholds[60][-1], "Notification thresholds not updated at #{Time.now}.") else assert_equal(0, notification_buffer.length, "Notification sent when it should not have been at #{Time.now}.") end logger_pop end end end