當前位置: 首頁>>代碼示例>>Python>>正文


Python FrequencyRule.add_terms_data方法代碼示例

本文整理匯總了Python中elastalert.ruletypes.FrequencyRule.add_terms_data方法的典型用法代碼示例。如果您正苦於以下問題:Python FrequencyRule.add_terms_data方法的具體用法?Python FrequencyRule.add_terms_data怎麽用?Python FrequencyRule.add_terms_data使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在elastalert.ruletypes.FrequencyRule的用法示例。


在下文中一共展示了FrequencyRule.add_terms_data方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_freq_terms

# 需要導入模塊: from elastalert.ruletypes import FrequencyRule [as 別名]
# 或者: from elastalert.ruletypes.FrequencyRule import add_terms_data [as 別名]
def test_freq_terms():
    rules = {'num_events': 10,
             'timeframe': datetime.timedelta(hours=1),
             'query_key': 'username'}
    rule = FrequencyRule(rules)

    terms1 = {ts_to_dt('2014-01-01T00:01:00Z'): [{'key': 'userA', 'doc_count': 1},
                                                 {'key': 'userB', 'doc_count': 5}]}
    terms2 = {ts_to_dt('2014-01-01T00:10:00Z'): [{'key': 'userA', 'doc_count': 8},
                                                 {'key': 'userB', 'doc_count': 5}]}
    terms3 = {ts_to_dt('2014-01-01T00:25:00Z'): [{'key': 'userA', 'doc_count': 3},
                                                 {'key': 'userB', 'doc_count': 0}]}
    # Initial data
    rule.add_terms_data(terms1)
    assert len(rule.matches) == 0

    # Match for user B
    rule.add_terms_data(terms2)
    assert len(rule.matches) == 1
    assert rule.matches[0].get('username') == 'userB'

    # Match for user A
    rule.add_terms_data(terms3)
    assert len(rule.matches) == 2
    assert rule.matches[1].get('username') == 'userA'
開發者ID:danielstorytel,項目名稱:elastalert,代碼行數:27,代碼來源:rules_test.py

示例2: test_freq_terms

# 需要導入模塊: from elastalert.ruletypes import FrequencyRule [as 別名]
# 或者: from elastalert.ruletypes.FrequencyRule import add_terms_data [as 別名]
def test_freq_terms():
    rules = {"num_events": 10, "timeframe": datetime.timedelta(hours=1), "query_key": "username"}
    rule = FrequencyRule(rules)

    terms1 = {ts_to_dt("2014-01-01T00:01:00Z"): [{"key": "userA", "doc_count": 1}, {"key": "userB", "doc_count": 5}]}
    terms2 = {ts_to_dt("2014-01-01T00:10:00Z"): [{"key": "userA", "doc_count": 8}, {"key": "userB", "doc_count": 5}]}
    terms3 = {ts_to_dt("2014-01-01T00:25:00Z"): [{"key": "userA", "doc_count": 3}, {"key": "userB", "doc_count": 0}]}
    # Initial data
    rule.add_terms_data(terms1)
    assert len(rule.matches) == 0

    # Match for user B
    rule.add_terms_data(terms2)
    assert len(rule.matches) == 1
    assert rule.matches[0].get("username") == "userB"

    # Match for user A
    rule.add_terms_data(terms3)
    assert len(rule.matches) == 2
    assert rule.matches[1].get("username") == "userA"
開發者ID:mesozoic,項目名稱:elastalert,代碼行數:22,代碼來源:rules_test.py


注:本文中的elastalert.ruletypes.FrequencyRule.add_terms_data方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。