本文整理匯總了Python中elastalert.ruletypes.FrequencyRule.add_data方法的典型用法代碼示例。如果您正苦於以下問題:Python FrequencyRule.add_data方法的具體用法?Python FrequencyRule.add_data怎麽用?Python FrequencyRule.add_data使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類elastalert.ruletypes.FrequencyRule
的用法示例。
在下文中一共展示了FrequencyRule.add_data方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_freq
# 需要導入模塊: from elastalert.ruletypes import FrequencyRule [as 別名]
# 或者: from elastalert.ruletypes.FrequencyRule import add_data [as 別名]
def test_freq():
events = hits(60, timestamp_field='blah', username='qlo')
rules = {'num_events': 59,
'timeframe': datetime.timedelta(hours=1),
'timestamp_field': 'blah'}
rule = FrequencyRule(rules)
rule.add_data(events)
assert len(rule.matches) == 1
# Test wit query_key
events = hits(60, timestamp_field='blah', username='qlo')
rules['query_key'] = 'username'
rule = FrequencyRule(rules)
rule.add_data(events)
assert len(rule.matches) == 1
# Doesn't match
events = hits(60, timestamp_field='blah', username='qlo')
rules['num_events'] = 61
rule = FrequencyRule(rules)
rule.add_data(events)
assert len(rule.matches) == 0
# garbage collection
assert 'qlo' in rule.occurrences
rule.garbage_collect(ts_to_dt('2014-09-28T12:0:0'))
assert rule.occurrences == {}
示例2: test_freq
# 需要導入模塊: from elastalert.ruletypes import FrequencyRule [as 別名]
# 或者: from elastalert.ruletypes.FrequencyRule import add_data [as 別名]
def test_freq():
events = hits(60, timestamp_field="blah", username="qlo")
rules = {"num_events": 59, "timeframe": datetime.timedelta(hours=1), "timestamp_field": "blah"}
rule = FrequencyRule(rules)
rule.add_data(events)
assert len(rule.matches) == 1
# Test wit query_key
events = hits(60, timestamp_field="blah", username="qlo")
rules["query_key"] = "username"
rule = FrequencyRule(rules)
rule.add_data(events)
assert len(rule.matches) == 1
# Doesn't match
events = hits(60, timestamp_field="blah", username="qlo")
rules["num_events"] = 61
rule = FrequencyRule(rules)
rule.add_data(events)
assert len(rule.matches) == 0
# garbage collection
assert "qlo" in rule.occurrences
rule.garbage_collect(ts_to_dt("2014-09-28T12:0:0"))
assert rule.occurrences == {}
示例3: test_freq_out_of_order
# 需要導入模塊: from elastalert.ruletypes import FrequencyRule [as 別名]
# 或者: from elastalert.ruletypes.FrequencyRule import add_data [as 別名]
def test_freq_out_of_order():
events = hits(60, timestamp_field='blah', username='qlo')
rules = {'num_events': 59,
'timeframe': datetime.timedelta(hours=1),
'timestamp_field': 'blah'}
rule = FrequencyRule(rules)
rule.add_data(events[:10])
assert len(rule.matches) == 0
# Try to add events from before the first occurrence
rule.add_data([{'blah': ts_to_dt('2014-09-26T11:00:00'), 'username': 'qlo'}] * 50)
assert len(rule.matches) == 0
rule.add_data(events[15:20])
assert len(rule.matches) == 0
rule.add_data(events[10:15])
assert len(rule.matches) == 0
rule.add_data(events[20:55])
rule.add_data(events[57:])
assert len(rule.matches) == 0
rule.add_data(events[55:57])
assert len(rule.matches) == 1
示例4: test_freq_out_of_order
# 需要導入模塊: from elastalert.ruletypes import FrequencyRule [as 別名]
# 或者: from elastalert.ruletypes.FrequencyRule import add_data [as 別名]
def test_freq_out_of_order():
events = hits(60, timestamp_field="blah", username="qlo")
rules = {"num_events": 59, "timeframe": datetime.timedelta(hours=1), "timestamp_field": "blah"}
rule = FrequencyRule(rules)
rule.add_data(events[:10])
assert len(rule.matches) == 0
# Try to add events from before the first occurrence
rule.add_data([{"blah": ts_to_dt("2014-09-26T11:00:00"), "username": "qlo"}] * 50)
assert len(rule.matches) == 0
rule.add_data(events[15:20])
assert len(rule.matches) == 0
rule.add_data(events[10:15])
assert len(rule.matches) == 0
rule.add_data(events[20:55])
rule.add_data(events[57:])
assert len(rule.matches) == 0
rule.add_data(events[55:57])
assert len(rule.matches) == 1