diff options
author | Evgeny Fadeev <evgeny.fadeev@gmail.com> | 2013-06-03 14:54:40 -0400 |
---|---|---|
committer | Evgeny Fadeev <evgeny.fadeev@gmail.com> | 2013-06-03 14:54:40 -0400 |
commit | 38d1bcb8dd34c4d7a4fa713667a4b38e527f5d6e (patch) | |
tree | 8b49bd7029dc2e0961d92995bf047263008947ae | |
parent | 0f2dc303750f3ddd88e911b0e4af9a497774036d (diff) | |
download | askbot-38d1bcb8dd34c4d7a4fa713667a4b38e527f5d6e.tar.gz askbot-38d1bcb8dd34c4d7a4fa713667a4b38e527f5d6e.tar.bz2 askbot-38d1bcb8dd34c4d7a4fa713667a4b38e527f5d6e.zip |
made "send_email_alerts" language aware
-rw-r--r-- | askbot/management/commands/send_email_alerts.py | 49 | ||||
-rw-r--r-- | askbot/tests/post_model_tests.py | 3 |
2 files changed, 36 insertions, 16 deletions
diff --git a/askbot/management/commands/send_email_alerts.py b/askbot/management/commands/send_email_alerts.py index b7432296..06f40c65 100644 --- a/askbot/management/commands/send_email_alerts.py +++ b/askbot/management/commands/send_email_alerts.py @@ -29,7 +29,8 @@ def get_all_origin_posts(mentions): def extend_question_list( src, dst, cutoff_time = None, limit=False, add_mention=False, - add_comment = False + add_comment = False, + languages=None ): """src is a query set with questions or None @@ -48,6 +49,8 @@ def extend_question_list( raise ValueError('cutoff_time is a mandatory parameter') for q in src: + if languages and src.language_code not in languages: + continue if q in dst: meta_data = dst[q] else: @@ -162,6 +165,11 @@ class Command(NoArgsCommand): Q_set_A = not_seen_qs Q_set_B = seen_before_last_mod_qs + if django_settings.ASKBOT_MULTILINGUAL: + languages = user.languages.split() + else: + languages = None + for feed in user_feeds: if feed.feed_type == 'm_and_c': #alerts on mentions and comments are processed separately @@ -216,8 +224,8 @@ class Command(NoArgsCommand): q_list = SortedDict() #todo: refactor q_list into a separate class? - extend_question_list(q_sel_A, q_list) - extend_question_list(q_sel_B, q_list) + extend_question_list(q_sel_A, q_list, languages=languages) + extend_question_list(q_sel_B, q_list, languages=languages) #build list of comment and mention responses here #it is separate because posts are not marked as changed @@ -247,8 +255,9 @@ class Command(NoArgsCommand): extend_question_list( q_commented, q_list, - cutoff_time = cutoff_time, - add_comment = True + cutoff_time=cutoff_time, + add_comment=True, + languages=languages ) mentions = Activity.objects.get_mentions( @@ -267,27 +276,37 @@ class Command(NoArgsCommand): q_mentions_A = Q_set_A.filter(id__in = q_mentions_id) q_mentions_A.cutoff_time = cutoff_time - extend_question_list(q_mentions_A, q_list, add_mention=True) + extend_question_list( + q_mentions_A, + q_list, + add_mention=True, + languages=languages + ) q_mentions_B = Q_set_B.filter(id__in = q_mentions_id) q_mentions_B.cutoff_time = cutoff_time - extend_question_list(q_mentions_B, q_list, add_mention=True) + extend_question_list( + q_mentions_B, + q_list, + add_mention=True, + languages=languages + ) except EmailFeedSetting.DoesNotExist: pass if user.email_tag_filter_strategy == const.INCLUDE_INTERESTING: - extend_question_list(q_all_A, q_list) - extend_question_list(q_all_B, q_list) + extend_question_list(q_all_A, q_list, languages=languages) + extend_question_list(q_all_B, q_list, languages=languages) - extend_question_list(q_ask_A, q_list, limit=True) - extend_question_list(q_ask_B, q_list, limit=True) + extend_question_list(q_ask_A, q_list, limit=True, languages=languages) + extend_question_list(q_ask_B, q_list, limit=True, languages=languages) - extend_question_list(q_ans_A, q_list, limit=True) - extend_question_list(q_ans_B, q_list, limit=True) + extend_question_list(q_ans_A, q_list, limit=True, languages=languages) + extend_question_list(q_ans_B, q_list, limit=True, languages=languages) if user.email_tag_filter_strategy == const.EXCLUDE_IGNORED: - extend_question_list(q_all_A, q_list, limit=True) - extend_question_list(q_all_B, q_list, limit=True) + extend_question_list(q_all_A, q_list, limit=True, languages=languages) + extend_question_list(q_all_B, q_list, limit=True, languages=languages) ctype = ContentType.objects.get_for_model(Post) EMAIL_UPDATE_ACTIVITY = const.TYPE_ACTIVITY_EMAIL_UPDATE_SENT diff --git a/askbot/tests/post_model_tests.py b/askbot/tests/post_model_tests.py index 703603c3..2e785802 100644 --- a/askbot/tests/post_model_tests.py +++ b/askbot/tests/post_model_tests.py @@ -546,7 +546,8 @@ class ThreadRenderCacheUpdateTests(AskbotTestCase): }) self.assertEqual(2, Post.objects.count()) answer = Post.objects.get_answers()[0] - self.assertRedirects(response=response, expected_url=answer.get_absolute_url()) + expected_url=answer.get_absolute_url() + self.assertRedirects(response=response, expected_url=expected_url) thread = answer.thread self.assertEqual(1, thread.answer_count) |