AlarmRulesWatcherTest.java 9.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 */

package org.apache.skywalking.oap.server.core.alarm.provider;

21 22 23 24
import java.io.IOException;
import java.io.Reader;
import java.util.ArrayList;
import java.util.Arrays;
L
liqiangz 已提交
25 26
import java.util.HashMap;

27 28 29 30 31 32 33 34 35
import org.apache.skywalking.oap.server.configuration.api.ConfigChangeWatcher;
import org.apache.skywalking.oap.server.library.util.ResourceUtils;
import org.junit.Before;
import org.junit.Test;
import org.mockito.MockitoAnnotations;
import org.mockito.Spy;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotEquals;
J
Jared Tan 已提交
36
import static org.junit.Assert.assertNotNull;
37 38 39 40 41 42 43 44 45
import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertTrue;
import static org.mockito.Mockito.spy;

public class AlarmRulesWatcherTest {
    @Spy
    private AlarmRulesWatcher alarmRulesWatcher = new AlarmRulesWatcher(new Rules(), null);

    private AlarmRule.AlarmRuleBuilder rulePrototypeBuilder = AlarmRule.builder()
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
                                                                       .alarmRuleName("name1")
                                                                       .count(1)
                                                                       .includeNames(new ArrayList<String>() {
                                                                           {
                                                                               add("1");
                                                                               add("2");
                                                                           }
                                                                       })
                                                                       .excludeNames(new ArrayList<String>() {
                                                                           {
                                                                               add("3");
                                                                               add("4");
                                                                           }
                                                                       })
                                                                       .message("test")
                                                                       .metricsName("metrics1")
                                                                       .op(">")
                                                                       .period(1)
                                                                       .silencePeriod(2)
L
liqiangz 已提交
65 66 67
                                                                       .tags(new HashMap<String, String>() {{
                                                                           put("key", "value");
                                                                       }})
68
                                                                       .threshold("2");
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84

    @Before
    public void setUp() {
        MockitoAnnotations.initMocks(this);
    }

    @Test
    public void shouldSetAlarmRulesOnEventChanged() throws IOException {
        assertTrue(alarmRulesWatcher.getRules().isEmpty());

        Reader reader = ResourceUtils.read("alarm-settings.yml");
        char[] chars = new char[1024 * 1024];
        int length = reader.read(chars);

        alarmRulesWatcher.notify(new ConfigChangeWatcher.ConfigChangeEvent(new String(chars, 0, length), ConfigChangeWatcher.EventType.MODIFY));

85
        assertEquals(3, alarmRulesWatcher.getRules().size());
86
        assertEquals(2, alarmRulesWatcher.getWebHooks().size());
J
Jared Tan 已提交
87 88
        assertNotNull(alarmRulesWatcher.getGrpchookSetting());
        assertEquals(9888, alarmRulesWatcher.getGrpchookSetting().getTargetPort());
89
        assertEquals(2, alarmRulesWatcher.getRunningContext().size());
X
xbkaishui 已提交
90 91 92
        assertNotNull(alarmRulesWatcher.getDingtalkSettings());
        assertNotNull(alarmRulesWatcher.getWechatSettings());
        assertNotNull(alarmRulesWatcher.getSlackSettings());
93
        assertNotNull(alarmRulesWatcher.getWeLinkSettings());
94 95 96 97 98 99 100 101 102 103 104 105 106
    }

    @Test
    public void shouldClearAlarmRulesOnEventDeleted() throws IOException {
        Reader reader = ResourceUtils.read("alarm-settings.yml");
        Rules defaultRules = new RulesReader(reader).readRules();

        alarmRulesWatcher = spy(new AlarmRulesWatcher(defaultRules, null));

        alarmRulesWatcher.notify(new ConfigChangeWatcher.ConfigChangeEvent("whatever", ConfigChangeWatcher.EventType.DELETE));

        assertEquals(0, alarmRulesWatcher.getRules().size());
        assertEquals(0, alarmRulesWatcher.getWebHooks().size());
J
Jared Tan 已提交
107
        assertNull(alarmRulesWatcher.getGrpchookSetting());
108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
        assertEquals(0, alarmRulesWatcher.getRunningContext().size());
    }

    @Test
    public void shouldKeepExistedRunningRuleIfAlarmRuleExists() {
        AlarmRule.AlarmRuleBuilder ruleBuilder = rulePrototypeBuilder;

        AlarmRule rule = ruleBuilder.build();
        Rules rules = new Rules();
        rules.getRules().add(rule);

        alarmRulesWatcher = spy(new AlarmRulesWatcher(rules, null));
        assertEquals(1, alarmRulesWatcher.getRunningContext().size());
        assertEquals(1, alarmRulesWatcher.getRunningContext().get(rule.getMetricsName()).size());

        RunningRule runningRule = alarmRulesWatcher.getRunningContext().get(rule.getMetricsName()).get(0);

        Rules updatedRules = new Rules();
        updatedRules.getRules().addAll(Arrays.asList(rule, ruleBuilder.alarmRuleName("name2").build()));

        alarmRulesWatcher.notify(updatedRules);

        assertEquals(1, alarmRulesWatcher.getRunningContext().size());
        assertEquals(2, alarmRulesWatcher.getRunningContext().get(rule.getMetricsName()).size());
132 133 134 135
        assertEquals("The same alarm rule should map to the same existed running rule", runningRule, alarmRulesWatcher.getRunningContext()
                                                                                                                      .get(rule
                                                                                                                          .getMetricsName())
                                                                                                                      .get(0));
136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158
    }

    @Test
    public void shouldRemoveRunningRuleIfAlarmRuleIsRemoved() {
        AlarmRule.AlarmRuleBuilder ruleBuilder = rulePrototypeBuilder;

        AlarmRule rule = ruleBuilder.build();
        Rules rules = new Rules();
        rules.getRules().add(rule);

        alarmRulesWatcher = spy(new AlarmRulesWatcher(rules, null));
        assertEquals(1, alarmRulesWatcher.getRunningContext().size());
        assertEquals(1, alarmRulesWatcher.getRunningContext().get(rule.getMetricsName()).size());

        RunningRule runningRule = alarmRulesWatcher.getRunningContext().get(rule.getMetricsName()).get(0);

        Rules updatedRules = new Rules();
        updatedRules.getRules().add(ruleBuilder.alarmRuleName("name2").build());

        alarmRulesWatcher.notify(updatedRules);

        assertEquals(1, alarmRulesWatcher.getRunningContext().size());
        assertEquals(1, alarmRulesWatcher.getRunningContext().get(rule.getMetricsName()).size());
159 160 161 162
        assertNotEquals("The new alarm rule should map to a different running rule", runningRule, alarmRulesWatcher.getRunningContext()
                                                                                                                   .get(rule
                                                                                                                       .getMetricsName())
                                                                                                                   .get(0));
163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178
    }

    @Test
    public void shouldReplaceRunningRuleIfAlarmRulesAreReplaced() {
        AlarmRule.AlarmRuleBuilder ruleBuilder = rulePrototypeBuilder;

        AlarmRule rule = ruleBuilder.build();
        Rules rules = new Rules();
        rules.getRules().add(rule);

        alarmRulesWatcher = spy(new AlarmRulesWatcher(rules, null));
        assertEquals(1, alarmRulesWatcher.getRunningContext().size());
        assertEquals(1, alarmRulesWatcher.getRunningContext().get(rule.getMetricsName()).size());

        Rules updatedRules = new Rules();
        // replace the original alarm rules
179 180 181 182 183 184
        updatedRules.getRules()
                    .addAll(Arrays.asList(ruleBuilder.alarmRuleName("name2")
                                                     .metricsName("metrics2")
                                                     .build(), ruleBuilder.alarmRuleName("name3")
                                                                          .metricsName("metrics3")
                                                                          .build()));
185 186 187 188 189 190 191 192 193

        alarmRulesWatcher.notify(updatedRules);

        assertEquals(2, alarmRulesWatcher.getRunningContext().size());
        assertNull(alarmRulesWatcher.getRunningContext().get("metrics1"));
        assertEquals(1, alarmRulesWatcher.getRunningContext().get("metrics2").size());
        assertEquals(1, alarmRulesWatcher.getRunningContext().get("metrics3").size());
    }
}