Skip to content

Commit

Permalink
feat(notification): turn on digest notification on new strings by def…
Browse files Browse the repository at this point in the history
…ault

This should encourage users to complete the translation they contributed to.

It applies to new users only.

Fixes WeblateOrg#10533
  • Loading branch information
nijel committed May 15, 2024
1 parent 3b4f462 commit f539876
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 13 deletions.
2 changes: 2 additions & 0 deletions weblate/accounts/data.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

from weblate.accounts.notifications import (
FREQ_INSTANT,
FREQ_WEEKLY,
SCOPE_ADMIN,
SCOPE_ALL,
SCOPE_WATCHED,
Expand All @@ -14,6 +15,7 @@
(SCOPE_WATCHED, FREQ_INSTANT, "LastAuthorCommentNotificaton"),
(SCOPE_WATCHED, FREQ_INSTANT, "MentionCommentNotificaton"),
(SCOPE_WATCHED, FREQ_INSTANT, "NewAnnouncementNotificaton"),
(SCOPE_WATCHED, FREQ_WEEKLY, "NewStringNotificaton"),
(SCOPE_ADMIN, FREQ_INSTANT, "MergeFailureNotification"),
(SCOPE_ADMIN, FREQ_INSTANT, "ParseErrorNotification"),
(SCOPE_ADMIN, FREQ_INSTANT, "NewTranslationNotificaton"),
Expand Down
20 changes: 10 additions & 10 deletions weblate/accounts/tests/test_views.py
Original file line number Diff line number Diff line change
Expand Up @@ -436,7 +436,7 @@ def test_userdata(self) -> None:
def test_subscription(self) -> None:
# Get profile page
response = self.client.get(reverse("profile"))
self.assertEqual(self.user.subscription_set.count(), 9)
self.assertEqual(self.user.subscription_set.count(), 10)

# Extract current form data
data: dict[str, str | list[str]] = {}
Expand All @@ -454,20 +454,20 @@ def test_subscription(self) -> None:
# Save unchanged data
response = self.client.post(reverse("profile"), data, follow=True)
self.assertContains(response, "Your profile has been updated.")
self.assertEqual(self.user.subscription_set.count(), 9)
self.assertEqual(self.user.subscription_set.count(), 10)

# Remove some subscriptions
data["notifications__1-notify-LastAuthorCommentNotificaton"] = "0"
data["notifications__1-notify-MentionCommentNotificaton"] = "0"
response = self.client.post(reverse("profile"), data, follow=True)
self.assertContains(response, "Your profile has been updated.")
self.assertEqual(self.user.subscription_set.count(), 7)
self.assertEqual(self.user.subscription_set.count(), 8)

# Add some subscriptions
data["notifications__2-notify-ChangedStringNotificaton"] = "1"
response = self.client.post(reverse("profile"), data, follow=True)
self.assertContains(response, "Your profile has been updated.")
self.assertEqual(self.user.subscription_set.count(), 8)
self.assertEqual(self.user.subscription_set.count(), 9)

def test_subscription_customize(self) -> None:
# Initial view
Expand Down Expand Up @@ -497,7 +497,7 @@ def test_subscription_customize(self) -> None:

def test_watch(self) -> None:
self.assertEqual(self.user.profile.watched.count(), 0)
self.assertEqual(self.user.subscription_set.count(), 9)
self.assertEqual(self.user.subscription_set.count(), 10)

# Watch project
self.client.post(reverse("watch", kwargs={"path": self.project.get_url_path()}))
Expand All @@ -509,13 +509,13 @@ def test_watch(self) -> None:
# Mute notifications for component
self.client.post(reverse("mute", kwargs=self.kw_component))
self.assertEqual(
self.user.subscription_set.filter(component=self.component).count(), 18
self.user.subscription_set.filter(component=self.component).count(), 20
)

# Mute notifications for project
self.client.post(reverse("mute", kwargs={"path": self.project.get_url_path()}))
self.assertEqual(
self.user.subscription_set.filter(project=self.project).count(), 18
self.user.subscription_set.filter(project=self.project).count(), 20
)

# Unwatch project
Expand All @@ -529,18 +529,18 @@ def test_watch(self) -> None:
self.assertEqual(
self.user.subscription_set.filter(component=self.component).count(), 0
)
self.assertEqual(self.user.subscription_set.count(), 9)
self.assertEqual(self.user.subscription_set.count(), 10)

def test_watch_component(self) -> None:
self.assertEqual(self.user.profile.watched.count(), 0)
self.assertEqual(self.user.subscription_set.count(), 9)
self.assertEqual(self.user.subscription_set.count(), 10)

# Watch component
self.client.post(reverse("watch", kwargs=self.kw_component))
self.assertEqual(self.user.profile.watched.count(), 1)
# All project notifications should be muted
self.assertEqual(
self.user.subscription_set.filter(project=self.project).count(), 18
self.user.subscription_set.filter(project=self.project).count(), 20
)
# Only default notifications should be enabled
self.assertEqual(
Expand Down
6 changes: 3 additions & 3 deletions weblate/api/tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -253,7 +253,7 @@ def test_list_notifications(self) -> None:
superuser=True,
code=200,
)
self.assertEqual(response.data["count"], 9)
self.assertEqual(response.data["count"], 10)

def test_post_notifications(self) -> None:
self.do_request(
Expand All @@ -274,7 +274,7 @@ def test_post_notifications(self) -> None:
"frequency": 1,
},
)
self.assertEqual(Subscription.objects.count(), 10)
self.assertEqual(Subscription.objects.count(), 11)

def test_get_notifications(self) -> None:
user = User.objects.filter(is_active=True)[0]
Expand Down Expand Up @@ -344,7 +344,7 @@ def test_delete_notifications(self) -> None:
superuser=True,
code=204,
)
self.assertEqual(Subscription.objects.count(), 8)
self.assertEqual(Subscription.objects.count(), 9)

def test_statistics(self) -> None:
user = User.objects.filter(is_active=True)[0]
Expand Down

0 comments on commit f539876

Please sign in to comment.