|
14 | 14 |
|
15 | 15 | """Tests REST events for /rooms paths.""" |
16 | 16 |
|
| 17 | +from typing import List |
| 18 | + |
17 | 19 | from synapse.api.constants import APP_SERVICE_REGISTRATION_TYPE, LoginType |
18 | 20 | from synapse.api.errors import Codes, HttpResponseException, SynapseError |
19 | 21 | from synapse.appservice import ApplicationService |
@@ -229,6 +231,78 @@ def test_tracked_but_not_limited(self): |
229 | 231 | self.reactor.advance(100) |
230 | 232 | self.assertEqual(2, self.successResultOf(count)) |
231 | 233 |
|
| 234 | + @override_config( |
| 235 | + { |
| 236 | + "mau_trial_days": 3, |
| 237 | + "mau_appservice_trial_days": {"SomeASID": 1, "AnotherASID": 2}, |
| 238 | + } |
| 239 | + ) |
| 240 | + def test_as_trial_days(self): |
| 241 | + user_tokens: List[str] = [] |
| 242 | + |
| 243 | + def advance_time_and_sync(): |
| 244 | + self.reactor.advance(24 * 60 * 61) |
| 245 | + for token in user_tokens: |
| 246 | + self.do_sync_for_user(token) |
| 247 | + |
| 248 | + # Cheekily add an application service that we use to register a new user |
| 249 | + # with. |
| 250 | + as_token_1 = "foobartoken1" |
| 251 | + self.store.services_cache.append( |
| 252 | + ApplicationService( |
| 253 | + token=as_token_1, |
| 254 | + hostname=self.hs.hostname, |
| 255 | + id="SomeASID", |
| 256 | + sender="@as_sender_1:test", |
| 257 | + namespaces={"users": [{"regex": "@as_1.*", "exclusive": True}]}, |
| 258 | + ) |
| 259 | + ) |
| 260 | + |
| 261 | + as_token_2 = "foobartoken2" |
| 262 | + self.store.services_cache.append( |
| 263 | + ApplicationService( |
| 264 | + token=as_token_2, |
| 265 | + hostname=self.hs.hostname, |
| 266 | + id="AnotherASID", |
| 267 | + sender="@as_sender_2:test", |
| 268 | + namespaces={"users": [{"regex": "@as_2.*", "exclusive": True}]}, |
| 269 | + ) |
| 270 | + ) |
| 271 | + |
| 272 | + user_tokens.append(self.create_user("kermit1")) |
| 273 | + user_tokens.append(self.create_user("kermit2")) |
| 274 | + user_tokens.append( |
| 275 | + self.create_user("as_1kermit3", token=as_token_1, appservice=True) |
| 276 | + ) |
| 277 | + user_tokens.append( |
| 278 | + self.create_user("as_2kermit4", token=as_token_2, appservice=True) |
| 279 | + ) |
| 280 | + |
| 281 | + # Advance time by 1 day to include the first appservice |
| 282 | + advance_time_and_sync() |
| 283 | + self.assertEqual( |
| 284 | + self.get_success(self.store.get_monthly_active_count_by_service()), |
| 285 | + {"SomeASID": 1}, |
| 286 | + ) |
| 287 | + |
| 288 | + # Advance time by 1 day to include the next appservice |
| 289 | + advance_time_and_sync() |
| 290 | + self.assertEqual( |
| 291 | + self.get_success(self.store.get_monthly_active_count_by_service()), |
| 292 | + {"SomeASID": 1, "AnotherASID": 1}, |
| 293 | + ) |
| 294 | + |
| 295 | + # Advance time by 1 day to include the native users |
| 296 | + advance_time_and_sync() |
| 297 | + self.assertEqual( |
| 298 | + self.get_success(self.store.get_monthly_active_count_by_service()), |
| 299 | + { |
| 300 | + "SomeASID": 1, |
| 301 | + "AnotherASID": 1, |
| 302 | + "native": 2, |
| 303 | + }, |
| 304 | + ) |
| 305 | + |
232 | 306 | def create_user(self, localpart, token=None, appservice=False): |
233 | 307 | request_data = { |
234 | 308 | "username": localpart, |
|
0 commit comments