diff options
| -rw-r--r-- | test/tc_mauve_person.rb | 42 | 
1 files changed, 27 insertions, 15 deletions
| diff --git a/test/tc_mauve_person.rb b/test/tc_mauve_person.rb index 5303b65..9e6f9ac 100644 --- a/test/tc_mauve_person.rb +++ b/test/tc_mauve_person.rb @@ -25,11 +25,18 @@ class TcMauvePerson < Mauve::UnitTest      #      # Allows us to pick up notifications sent.      # -    $sent_notifications = [] +    notification_buffer = []      config =<<EOF +notification_method("email") { +  debug! +  deliver_to_queue [] +  disable_normal_delivery! +} +  person ("test") { -  all { $sent_notifications << Time.now ; true } +  email "test@example.com" +  all { email }    suppress_notifications_after( 6 => 60.seconds )  } @@ -43,6 +50,8 @@ alert_group("default") {  EOF      Configuration.current = ConfigurationBuilder.parse(config) +    notification_buffer = Configuration.current.notification_methods["email"].deliver_to_queue +      Server.instance.setup      person = Configuration.current.people["test"] @@ -80,20 +89,20 @@ EOF        # Advance in to the future!        #        Timecop.freeze(start_time + offset) -        person.send_alert(alert.level, alert)        if notification_sent  -        assert_equal(1, $sent_notifications.length, "Notification not sent when it should have been at #{Time.now}.") +        assert_equal(1, notification_buffer.length, "Notification not sent when it should have been at #{Time.now}.")          #          # Pop the notification off the buffer.          # -        last_notification_sent_at = $sent_notifications.pop +        notification_buffer.pop          assert_equal(Time.now, person.notification_thresholds[60][-1], "Notification thresholds not updated at #{Time.now}.")        else -        assert_equal(0, $sent_notifications.length, "Notification sent when it should not have been at #{Time.now}.") +        assert_equal(0, notification_buffer.length, "Notification sent when it should not have been at #{Time.now}.")        end +        logger_pop      end @@ -101,17 +110,19 @@ EOF    def test_send_alert_when_only_one_blargh      # -    # Allows us to pick up notifications sent. -    # -    $sent_notifications = [] - -    #      # This configuration is a bit different.  We only want one alert per      # minute.      #      config =<<EOF +notification_method("email") { +  debug! +  deliver_to_queue [] +  disable_normal_delivery! +} +  person ("test") { -  all { $sent_notifications << Time.now ; true } +  email "test@example.com" +  all { email }    suppress_notifications_after( 1 => 1.minute )  } @@ -125,6 +136,7 @@ alert_group("default") {  EOF      Configuration.current = ConfigurationBuilder.parse(config) +    notification_buffer = Configuration.current.notification_methods["email"].deliver_to_queue      Server.instance.setup      person = Configuration.current.people["test"] @@ -159,14 +171,14 @@ EOF        person.send_alert(alert.level, alert)        if notification_sent  -        assert_equal(1, $sent_notifications.length, "Notification not sent when it should have been at #{Time.now}.") +        assert_equal(1, notification_buffer.length, "Notification not sent when it should have been at #{Time.now}.")          #          # Pop the notification off the buffer.          # -        last_notification_sent_at = $sent_notifications.pop +        notification_buffer.pop          assert_equal(Time.now, person.notification_thresholds[60][-1], "Notification thresholds not updated at #{Time.now}.")        else -        assert_equal(0, $sent_notifications.length, "Notification sent when it should not have been at #{Time.now}.") +        assert_equal(0, notification_buffer.length, "Notification sent when it should not have been at #{Time.now}.")        end        logger_pop | 
