2023-11-21 23:29:58 +03:00
|
|
|
/*
|
|
|
|
* This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
|
|
*
|
2024-01-23 14:26:48 +03:00
|
|
|
* Copyright 2022 The Matrix.org Foundation C.I.C.
|
2023-11-21 23:29:58 +03:00
|
|
|
* Copyright (C) 2023 New Vector, Ltd
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* See the GNU Affero General Public License for more details:
|
|
|
|
* <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
|
|
*
|
|
|
|
* Originally licensed under the Apache License, Version 2.0:
|
|
|
|
* <http://www.apache.org/licenses/LICENSE-2.0>.
|
|
|
|
*
|
|
|
|
* [This file includes modifications made by New Vector Limited]
|
|
|
|
*
|
|
|
|
*/
|
2022-09-29 18:12:09 +03:00
|
|
|
|
|
|
|
#![feature(test)]
|
2023-08-02 15:41:32 +03:00
|
|
|
|
|
|
|
use std::borrow::Cow;
|
|
|
|
|
2022-09-29 18:12:09 +03:00
|
|
|
use synapse::push::{
|
2023-02-14 22:02:19 +03:00
|
|
|
evaluator::PushRuleEvaluator, Condition, EventMatchCondition, FilteredPushRules, JsonValue,
|
|
|
|
PushRules, SimpleJsonValue,
|
2022-09-29 18:12:09 +03:00
|
|
|
};
|
|
|
|
use test::Bencher;
|
|
|
|
|
|
|
|
extern crate test;
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_match_exact(b: &mut Bencher) {
|
|
|
|
let flattened_keys = [
|
2023-02-10 20:37:07 +03:00
|
|
|
(
|
|
|
|
"type".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("m.text"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
|
|
|
(
|
|
|
|
"room_id".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("!room:server"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
|
|
|
(
|
|
|
|
"content.body".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("test message"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
2022-09-29 18:12:09 +03:00
|
|
|
]
|
|
|
|
.into_iter()
|
|
|
|
.collect();
|
|
|
|
|
|
|
|
let eval = PushRuleEvaluator::py_new(
|
|
|
|
flattened_keys,
|
2023-02-03 19:28:20 +03:00
|
|
|
false,
|
2022-09-29 18:12:09 +03:00
|
|
|
10,
|
2022-12-02 21:04:28 +03:00
|
|
|
Some(0),
|
2022-09-29 18:12:09 +03:00
|
|
|
Default::default(),
|
|
|
|
Default::default(),
|
|
|
|
true,
|
2022-12-02 21:04:28 +03:00
|
|
|
vec![],
|
|
|
|
false,
|
2022-09-29 18:12:09 +03:00
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let condition = Condition::Known(synapse::push::KnownCondition::EventMatch(
|
|
|
|
EventMatchCondition {
|
|
|
|
key: "room_id".into(),
|
2023-02-28 18:11:20 +03:00
|
|
|
pattern: "!room:server".into(),
|
2022-09-29 18:12:09 +03:00
|
|
|
},
|
|
|
|
));
|
|
|
|
|
|
|
|
let matched = eval.match_condition(&condition, None, None).unwrap();
|
|
|
|
assert!(matched, "Didn't match");
|
|
|
|
|
|
|
|
b.iter(|| eval.match_condition(&condition, None, None).unwrap());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_match_word(b: &mut Bencher) {
|
|
|
|
let flattened_keys = [
|
2023-02-10 20:37:07 +03:00
|
|
|
(
|
|
|
|
"type".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("m.text"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
|
|
|
(
|
|
|
|
"room_id".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("!room:server"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
|
|
|
(
|
|
|
|
"content.body".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("test message"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
2022-09-29 18:12:09 +03:00
|
|
|
]
|
|
|
|
.into_iter()
|
|
|
|
.collect();
|
|
|
|
|
|
|
|
let eval = PushRuleEvaluator::py_new(
|
|
|
|
flattened_keys,
|
2023-02-03 19:28:20 +03:00
|
|
|
false,
|
2022-09-29 18:12:09 +03:00
|
|
|
10,
|
2022-12-02 21:04:28 +03:00
|
|
|
Some(0),
|
2022-09-29 18:12:09 +03:00
|
|
|
Default::default(),
|
|
|
|
Default::default(),
|
|
|
|
true,
|
2022-12-02 21:04:28 +03:00
|
|
|
vec![],
|
|
|
|
false,
|
2022-09-29 18:12:09 +03:00
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let condition = Condition::Known(synapse::push::KnownCondition::EventMatch(
|
|
|
|
EventMatchCondition {
|
|
|
|
key: "content.body".into(),
|
2023-02-28 18:11:20 +03:00
|
|
|
pattern: "test".into(),
|
2022-09-29 18:12:09 +03:00
|
|
|
},
|
|
|
|
));
|
|
|
|
|
|
|
|
let matched = eval.match_condition(&condition, None, None).unwrap();
|
|
|
|
assert!(matched, "Didn't match");
|
|
|
|
|
|
|
|
b.iter(|| eval.match_condition(&condition, None, None).unwrap());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_match_word_miss(b: &mut Bencher) {
|
|
|
|
let flattened_keys = [
|
2023-02-10 20:37:07 +03:00
|
|
|
(
|
|
|
|
"type".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("m.text"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
|
|
|
(
|
|
|
|
"room_id".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("!room:server"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
|
|
|
(
|
|
|
|
"content.body".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("test message"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
2022-09-29 18:12:09 +03:00
|
|
|
]
|
|
|
|
.into_iter()
|
|
|
|
.collect();
|
|
|
|
|
|
|
|
let eval = PushRuleEvaluator::py_new(
|
|
|
|
flattened_keys,
|
2023-02-03 19:28:20 +03:00
|
|
|
false,
|
2022-09-29 18:12:09 +03:00
|
|
|
10,
|
2022-12-02 21:04:28 +03:00
|
|
|
Some(0),
|
2022-09-29 18:12:09 +03:00
|
|
|
Default::default(),
|
|
|
|
Default::default(),
|
|
|
|
true,
|
2022-12-02 21:04:28 +03:00
|
|
|
vec![],
|
|
|
|
false,
|
2022-09-29 18:12:09 +03:00
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let condition = Condition::Known(synapse::push::KnownCondition::EventMatch(
|
|
|
|
EventMatchCondition {
|
|
|
|
key: "content.body".into(),
|
2023-02-28 18:11:20 +03:00
|
|
|
pattern: "foobar".into(),
|
2022-09-29 18:12:09 +03:00
|
|
|
},
|
|
|
|
));
|
|
|
|
|
|
|
|
let matched = eval.match_condition(&condition, None, None).unwrap();
|
|
|
|
assert!(!matched, "Didn't match");
|
|
|
|
|
|
|
|
b.iter(|| eval.match_condition(&condition, None, None).unwrap());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_eval_message(b: &mut Bencher) {
|
|
|
|
let flattened_keys = [
|
2023-02-10 20:37:07 +03:00
|
|
|
(
|
|
|
|
"type".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("m.text"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
|
|
|
(
|
|
|
|
"room_id".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("!room:server"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
|
|
|
(
|
|
|
|
"content.body".to_string(),
|
2023-08-02 15:41:32 +03:00
|
|
|
JsonValue::Value(SimpleJsonValue::Str(Cow::Borrowed("test message"))),
|
2023-02-10 20:37:07 +03:00
|
|
|
),
|
2022-09-29 18:12:09 +03:00
|
|
|
]
|
|
|
|
.into_iter()
|
|
|
|
.collect();
|
|
|
|
|
|
|
|
let eval = PushRuleEvaluator::py_new(
|
|
|
|
flattened_keys,
|
2023-02-03 19:28:20 +03:00
|
|
|
false,
|
2022-09-29 18:12:09 +03:00
|
|
|
10,
|
2022-12-02 21:04:28 +03:00
|
|
|
Some(0),
|
2022-09-29 18:12:09 +03:00
|
|
|
Default::default(),
|
|
|
|
Default::default(),
|
|
|
|
true,
|
2022-12-02 21:04:28 +03:00
|
|
|
vec![],
|
|
|
|
false,
|
2022-09-29 18:12:09 +03:00
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
|
2023-01-19 15:47:10 +03:00
|
|
|
let rules = FilteredPushRules::py_new(
|
|
|
|
PushRules::new(Vec::new()),
|
|
|
|
Default::default(),
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
2023-09-26 18:52:19 +03:00
|
|
|
false,
|
2023-01-19 15:47:10 +03:00
|
|
|
);
|
2022-09-29 18:12:09 +03:00
|
|
|
|
|
|
|
b.iter(|| eval.run(&rules, Some("bob"), Some("person")));
|
|
|
|
}
|