From edefe1ed64673198835a6d21910b7430e3941f2c Mon Sep 17 00:00:00 2001 From: Anders Lindeberg Date: Fri, 22 Nov 2024 19:34:53 +0100 Subject: [PATCH 1/2] Alert email subject in the receivers language --- app/mailers/alaveteli_pro/embargo_mailer.rb | 36 +++-- .../alaveteli_pro/subscription_mailer.rb | 13 +- app/mailers/application_mailer.rb | 5 +- app/mailers/contact_mailer.rb | 4 +- app/mailers/info_request_batch_mailer.rb | 8 +- app/mailers/notification_mailer.rb | 67 ++++---- app/mailers/request_mailer.rb | 58 +++++-- app/mailers/survey_mailer.rb | 4 +- app/mailers/track_mailer.rb | 5 +- app/mailers/user_mailer.rb | 24 +-- spec/fixtures/locale/es/app.po | 64 ++++++-- .../alaveteli_pro/embargo_mailer_spec.rb | 60 ++++++++ .../alaveteli_pro/subscription_mailer_spec.rb | 11 ++ .../mailers/info_request_batch_mailer_spec.rb | 16 ++ spec/mailers/notification_mailer_spec.rb | 82 ++++++++++ spec/mailers/request_mailer_spec.rb | 143 ++++++++++++++++++ spec/mailers/survey_mailer_spec.rb | 25 +++ spec/mailers/track_mailer_spec.rb | 11 +- 18 files changed, 538 insertions(+), 98 deletions(-) diff --git a/app/mailers/alaveteli_pro/embargo_mailer.rb b/app/mailers/alaveteli_pro/embargo_mailer.rb index 9bbdc00cfa..66297722ce 100644 --- a/app/mailers/alaveteli_pro/embargo_mailer.rb +++ b/app/mailers/alaveteli_pro/embargo_mailer.rb @@ -68,27 +68,35 @@ def self.alert_expired def expiring_alert(user, info_requests) @user = user @info_requests = info_requests - subject = n_( - "{{count}} request will be made public on {{site_name}} this week", - "{{count}} requests will be made public on {{site_name}} this week", - info_requests.count, - site_name: site_name.html_safe, - count: info_requests.count + mail_user( + @user, + subject: -> { + n_( + "{{count}} request will be made public on {{site_name}} this week", + "{{count}} requests will be made public on {{site_name}} this week", + info_requests.count, + site_name: site_name.html_safe, + count: info_requests.count + ) + } ) - mail_user(@user, subject: subject) end def expired_alert(user, info_requests) @user = user @info_requests = info_requests - subject = n_( - "{{count}} request has been made public on {{site_name}}", - "{{count}} requests have been made public on {{site_name}}", - info_requests.count, - site_name: site_name.html_safe, - count: info_requests.count + mail_user( + @user, + subject: -> { + n_( + "{{count}} request has been made public on {{site_name}}", + "{{count}} requests have been made public on {{site_name}}", + info_requests.count, + site_name: site_name.html_safe, + count: info_requests.count + ) + } ) - mail_user(@user, subject: subject) end end end diff --git a/app/mailers/alaveteli_pro/subscription_mailer.rb b/app/mailers/alaveteli_pro/subscription_mailer.rb index 5c9d6f8d00..92261d345f 100644 --- a/app/mailers/alaveteli_pro/subscription_mailer.rb +++ b/app/mailers/alaveteli_pro/subscription_mailer.rb @@ -3,13 +3,18 @@ class AlaveteliPro::SubscriptionMailer < ApplicationMailer def payment_failed(user) auto_generated_headers(user) - subject = _('Action Required: Payment failed on {{pro_site_name}}', - pro_site_name: pro_site_name) - @user_name = user.name @pro_site_name = pro_site_name.html_safe @subscriptions_url = subscriptions_url - mail_user(user, subject: subject) + mail_user( + user, + subject: -> { + _( + 'Action Required: Payment failed on {{pro_site_name}}', + pro_site_name: pro_site_name + ) + } + ) end private diff --git a/app/mailers/application_mailer.rb b/app/mailers/application_mailer.rb index c8cd1469f4..cd02306b3a 100644 --- a/app/mailers/application_mailer.rb +++ b/app/mailers/application_mailer.rb @@ -24,8 +24,10 @@ class ApplicationMailer < ActionMailer::Base # about the errors, and have to do error checking on return codes. self.raise_delivery_errors = true + # The subject: arg must be a proc, it is localized with the user's locale. def mail_user(user, subject:, **opts) if user.is_a?(User) + locale = user.locale opts[:to] = user.name_and_email else opts[:to] = user @@ -36,7 +38,6 @@ def mail_user(user, subject:, **opts) opts[:from] = MailHandler.address_from_name_and_email( opts[:from].name, blackhole_email ) - else set_reply_to_headers opts[:from] ||= blackhole_email @@ -45,7 +46,7 @@ def mail_user(user, subject:, **opts) set_auto_generated_headers default_opts = { - subject: subject + subject: AlaveteliLocalization.with_locale(locale) { subject.call } } default_opts.merge!(opts) mail(default_opts) diff --git a/app/mailers/contact_mailer.rb b/app/mailers/contact_mailer.rb index 0a465cb5e7..ec30af27e3 100644 --- a/app/mailers/contact_mailer.rb +++ b/app/mailers/contact_mailer.rb @@ -34,7 +34,7 @@ def user_message(from_user, recipient_user, from_user_url, subject, message) mail_user( recipient_user, from: from_user, - subject: subject + subject: -> { subject } ) end @@ -53,7 +53,7 @@ def from_admin_message(recipient_name, recipient_email, subject, message) to_address, from: from_address, bcc: AlaveteliConfiguration.contact_email, - subject: subject + subject: -> { subject } ) end end diff --git a/app/mailers/info_request_batch_mailer.rb b/app/mailers/info_request_batch_mailer.rb index 6895b522f5..c7df490e29 100644 --- a/app/mailers/info_request_batch_mailer.rb +++ b/app/mailers/info_request_batch_mailer.rb @@ -12,8 +12,12 @@ def batch_sent(info_request_batch, unrequestable, user) mail_user( user, - subject: _("Your batch request \"{{title}}\" has been sent", - title: info_request_batch.title.html_safe) + subject: -> { + _( + "Your batch request \"{{title}}\" has been sent", + title: info_request_batch.title.html_safe + ) + } ) end end diff --git a/app/mailers/notification_mailer.rb b/app/mailers/notification_mailer.rb index 8ed37dd00a..93d1a8a9bb 100644 --- a/app/mailers/notification_mailer.rb +++ b/app/mailers/notification_mailer.rb @@ -84,8 +84,10 @@ def daily_summary(user, notifications) mail_user( user, - subject: _("Your daily request summary from {{pro_site_name}}", - pro_site_name: pro_site_name) + subject: -> { + _("Your daily request summary from {{pro_site_name}}", + pro_site_name: pro_site_name) + } ) end @@ -99,11 +101,12 @@ def response_notification(notification) @info_request = notification.info_request_event.info_request @incoming_message = notification.info_request_event.incoming_message - subject = _("New response to your FOI request - {{request_title}}", - request_title: @info_request.title.html_safe) mail_user( @info_request.user, - subject: subject, + subject: -> { + _("New response to your FOI request - {{request_title}}", + request_title: @info_request.title.html_safe) + }, template_name: 'response_notification' ) end @@ -111,16 +114,16 @@ def response_notification(notification) def embargo_expiring_notification(notification) @info_request = notification.info_request_event.info_request - subject = _( - "Your FOI request - {{request_title}} will be made public on " \ - "{{site_name}} this week", - request_title: @info_request.title.html_safe, - site_name: site_name.html_safe - ) - mail_user( @info_request.user, - subject: subject, + subject: -> { + _( + "Your FOI request - {{request_title}} will be made public on " \ + "{{site_name}} this week", + request_title: @info_request.title.html_safe, + site_name: site_name.html_safe + ) + }, template_name: 'embargo_expiring_notification' ) end @@ -128,16 +131,16 @@ def embargo_expiring_notification(notification) def expire_embargo_notification(notification) @info_request = notification.info_request_event.info_request - subject = _( - "Your FOI request - {{request_title}} has been made public on " \ - "{{site_name}}", - request_title: @info_request.title.html_safe, - site_name: site_name.html_safe - ) - mail_user( @info_request.user, - subject: subject, + subject: -> { + _( + "Your FOI request - {{request_title}} has been made public on " \ + "{{site_name}}", + request_title: @info_request.title.html_safe, + site_name: site_name.html_safe + ) + }, template_name: 'expire_embargo_notification' ) end @@ -146,12 +149,14 @@ def overdue_notification(notification) @info_request = notification.info_request_event.info_request @url = signin_url(r: respond_to_last_path(@info_request)) - subject = _("Delayed response to your FOI request - {{request_title}}", - request_title: @info_request.title.html_safe) - mail_user( @info_request.user, - subject: subject, + subject: -> { + _( + "Delayed response to your FOI request - {{request_title}}", + request_title: @info_request.title.html_safe + ) + }, template_name: 'overdue_notification' ) end @@ -160,13 +165,15 @@ def very_overdue_notification(notification) @info_request = notification.info_request_event.info_request @url = signin_url(r: respond_to_last_path(@info_request)) - subject = _("You're long overdue a response to your FOI request " \ - "- {{request_title}}", - request_title: @info_request.title.html_safe) - mail_user( @info_request.user, - subject: subject, + subject: -> { + _( + "You're long overdue a response to your FOI request " \ + "- {{request_title}}", + request_title: @info_request.title.html_safe + ) + }, template_name: 'very_overdue_notification' ) end diff --git a/app/mailers/request_mailer.rb b/app/mailers/request_mailer.rb index 712bb4362d..6157b2e8d2 100644 --- a/app/mailers/request_mailer.rb +++ b/app/mailers/request_mailer.rb @@ -90,8 +90,10 @@ def new_response(info_request, incoming_message) mail_user( info_request.user, - subject: _("New response to your FOI request - {{request_title}}", - request_title: info_request.title.html_safe), + subject: -> { + _("New response to your FOI request - {{request_title}}", + request_title: info_request.title.html_safe) + }, charset: "UTF-8" ) end @@ -103,8 +105,12 @@ def overdue_alert(info_request, user) mail_user( user, - subject: _("Delayed response to your FOI request - {{request_title}}", - request_title: info_request.title.html_safe) + subject: -> { + _( + "Delayed response to your FOI request - {{request_title}}", + request_title: info_request.title.html_safe + ) + } ) end @@ -115,9 +121,13 @@ def very_overdue_alert(info_request, user) mail_user( user, - subject: _("You're long overdue a response to your FOI request - " \ - "{{request_title}}", - request_title: info_request.title.html_safe) + subject: -> { + _( + "You're long overdue a response to your FOI request - " \ + "{{request_title}}", + request_title: info_request.title.html_safe + ) + } ) end @@ -133,8 +143,12 @@ def new_response_reminder_alert(info_request, incoming_message) mail_user( info_request.user, - subject: _("Please update the status of your request - {{request_title}}", - request_title: info_request.title.html_safe) + subject: -> { + _( + "Please update the status of your request - {{request_title}}", + request_title: info_request.title.html_safe + ) + } ) end @@ -145,7 +159,7 @@ def old_unclassified_updated(info_request) mail_user( info_request.user, - subject: _("Someone has updated the status of your request") + subject: -> { _("Someone has updated the status of your request") } ) end @@ -162,8 +176,12 @@ def not_clarified_alert(info_request, incoming_message) mail_user( info_request.user, - subject: _("Clarify your FOI request - {{request_title}}", - request_title: info_request.title.html_safe) + subject: -> { + _( + "Clarify your FOI request - {{request_title}}", + request_title: info_request.title.html_safe + ) + } ) end @@ -175,8 +193,12 @@ def comment_on_alert(info_request, comment) mail_user( info_request.user, - subject: _("Somebody added a note to your FOI request - {{request_title}}", - request_title: info_request.title.html_safe) + subject: -> { + _( + "Somebody added a note to your FOI request - {{request_title}}", + request_title: info_request.title.html_safe + ) + } ) end @@ -189,8 +211,12 @@ def comment_on_alert_plural(info_request, count, earliest_unalerted_comment) mail_user( info_request.user, - subject: _("Some notes have been added to your FOI request - {{request_title}}", - request_title: info_request.title.html_safe) + subject: -> { + _( + "Some notes have been added to your FOI request - {{request_title}}", + request_title: info_request.title.html_safe + ) + } ) end diff --git a/app/mailers/survey_mailer.rb b/app/mailers/survey_mailer.rb index b49ba13ee8..bebefa3521 100644 --- a/app/mailers/survey_mailer.rb +++ b/app/mailers/survey_mailer.rb @@ -24,7 +24,9 @@ def survey_alert(info_request) mail_user( @user, - subject: _('A survey about your recent Freedom of Information request') + subject: -> { + _('A survey about your recent Freedom of Information request') + } ) end diff --git a/app/mailers/track_mailer.rb b/app/mailers/track_mailer.rb index 8c3f8677a7..d153e9bb27 100644 --- a/app/mailers/track_mailer.rb +++ b/app/mailers/track_mailer.rb @@ -31,8 +31,9 @@ def event_digest(user, email_about_things) mail_user( user, - subject: _("Your {{site_name}} email alert", - site_name: site_name.html_safe) + subject: -> { + _("Your {{site_name}} email alert", site_name: site_name.html_safe) + } ) end diff --git a/app/mailers/user_mailer.rb b/app/mailers/user_mailer.rb index 08abaab96d..e6b16bf0cf 100644 --- a/app/mailers/user_mailer.rb +++ b/app/mailers/user_mailer.rb @@ -10,7 +10,7 @@ def confirm_login(user, reasons, url) @name = user.name @url = url - mail_user(user, subject: reasons[:email_subject]) + mail_user(user, subject: -> { reasons[:email_subject] }) end def already_registered(user, reasons, url) @@ -18,7 +18,7 @@ def already_registered(user, reasons, url) @name = user.name @url = url - mail_user(user, subject: reasons[:email_subject]) + mail_user(user, subject: -> { reasons[:email_subject] }) end def changeemail_confirm(user, new_email, url) @@ -27,11 +27,13 @@ def changeemail_confirm(user, new_email, url) @old_email = user.email @new_email = new_email - mail_user( - new_email, - subject: _("Confirm your new email address on {{site_name}}", - site_name: site_name) + # Cannot send the user to mail_user - that would send to old_email. + # No problem if the current locale is the user's. + subject = _( + "Confirm your new email address on {{site_name}}", + site_name: site_name ) + mail_user(new_email, subject: -> { subject }) end def changeemail_already_used(old_email, new_email) @@ -39,10 +41,12 @@ def changeemail_already_used(old_email, new_email) @new_email = new_email user = User.find_by_email(@old_email) - mail_user( - new_email, - subject: _("Unable to change email address on {{site_name}}", - site_name: site_name) + # Cannot send the user to mail_user - that would send to old_email. + # No problem if the current locale is the user's. + subject = _( + "Unable to change email address on {{site_name}}", + site_name: site_name ) + mail_user(new_email, subject: -> { subject }) end end diff --git a/spec/fixtures/locale/es/app.po b/spec/fixtures/locale/es/app.po index 729a289d92..3e0e99710c 100644 --- a/spec/fixtures/locale/es/app.po +++ b/spec/fixtures/locale/es/app.po @@ -931,8 +931,8 @@ msgid "Dear {{public_body_name}}," msgstr "Estimado {{public_body_name}}," #: app/models/request_mailer.rb:87 -msgid "Delayed response to your FOI request - " -msgstr "Respuesta retrasada a tu solicitud de acceso a información - " +msgid "Delayed response to your FOI request - {{request_title}}" +msgstr "Respuesta retrasada a tu solicitud de acceso a información - {{request_title}}" #: app/models/info_request.rb:783 msgid "Delayed." @@ -1772,9 +1772,9 @@ msgstr "Nueva contraseña:" msgid "New password: (again)" msgstr "Nueva contraseña: (otra vez)" -#: app/models/request_mailer.rb:68 -msgid "New response to your FOI request - " -msgstr "Nueva respuesta a tu solicitud de información - " +#: app/mailers/request_mailer.rb:92 +msgid "New response to your FOI request - {{request_title}}" +msgstr "Nueva respuesta a tu solicitud de información - {{request_title}}" #: app/views/request/show_response.rhtml:60 msgid "New response to your request" @@ -2601,9 +2601,9 @@ msgstr "Solicitudes similares" msgid "Simple search" msgstr "Búsqueda básica" -#: app/models/request_mailer.rb:178 -msgid "Some notes have been added to your FOI request - " -msgstr "Nuevos comentarios en tu solicitud de acceso a información - " +#: app/mailers/request_mailer.rb:205 +msgid "Some notes have been added to your FOI request - {{request_title}}" +msgstr "Nuevos comentarios en tu solicitud de acceso a información - {{request_title}}" #: app/views/general/_advanced_search_tips.rhtml:29 msgid "Some of the information requested has been received" @@ -2617,9 +2617,9 @@ msgid "" "information has been provided. Everyone'll be exceedingly grateful." msgstr "Algunas personas que hicieron solicitudes no nos han hecho saber si tuvieron\néxito o no. Necesitamos tu ayuda –\nelije una de las solicitudes, léela, y háznos saber si se ha obtenido o no\nla información. Todos te estaremos agradecidos." -#: app/models/request_mailer.rb:169 -msgid "Somebody added a note to your FOI request - " -msgstr "Nuevo comentario en tu solicitud de acceso a información - " +#: app/models/request_mailer.rb:189 +msgid "Somebody added a note to your FOI request - {{request_title}}" +msgstr "Nuevo comentario en tu solicitud de acceso a información - {{request_title}}" #: app/views/user_mailer/changeemail_already_used.rhtml:1 msgid "" @@ -3883,8 +3883,8 @@ msgid "" msgstr "Sólo recibirás una respuesta a tu solicitud si continúas\ncon la aclaración." #: app/models/request_mailer.rb:106 -msgid "You're long overdue a response to your FOI request - " -msgstr "La respuesta a tu solicitud de información está muy retrasada - " +msgid "You're long overdue a response to your FOI request - {{request_title}}" +msgstr "La respuesta a tu solicitud de información está muy retrasada - {{request_title}}" #: app/controllers/user_controller.rb:476 msgid "You've now cleared your profile photo" @@ -4520,6 +4520,44 @@ msgstr "{{user}} (admin) hizo esta solicitud msgid "{{user}} made this {{law_used_full}} request" msgstr "{{user}} hizo esta solicitud de {{law_used_full}}" +#: app/mailers/notification_mailer.rb:88 +msgid "Your daily request summary from {{pro_site_name}}" +msgstr "*** Spanish missing *** {{pro_site_name}}" + +msgid "Your FOI request - {{request_title}} will be made public on {{site_name}} this week" +msgstr "*** Spanish missing *** {{request_title}} *** {{site_name}}" + +msgid "Your FOI request - {{request_title}} has been made public on {{site_name}}" +msgstr "*** Spanish missing *** {{request_title}} *** {{site_name}}" + +msgid "{{count}} request will be made public on {{site_name}} this week" +msgid_plural "{{count}} requests will be made public on {{site_name}} this week" +msgstr[0] "*** Spanish missing *** {{count}} *** {{site_name}}" +msgstr[1] "*** Spanish missings *** {{count}} *** {{site_name}}" + +msgid "{{count}} request has been made public on {{site_name}}" +msgid_plural "{{count}} requests have been made public on {{site_name}}" +msgstr[0] "*** Spanish missing *** {{count}} *** {{site_name}}" +msgstr[1] "*** Spanish missings *** {{count}} *** {{site_name}}" + +msgid "Action Required: Payment failed on {{pro_site_name}}" +msgstr "*** Spanish missing *** {{pro_site_name}}" + +msgid "Your batch request \"{{title}}\" has been sent" +msgstr "Tu solicitud en lote \"{{title}}\" ha sido enviada" + +msgid "Someone has updated the status of your request" +msgstr "Alguien ha actualizado el estado de tu solicitud" + +msgid "Clarify your FOI request - {{request_title}}" +msgstr "Clarifica tu solicitud de información - {{request_title}}" + +msgid "A survey about your recent Freedom of Information request" +msgstr "*** Spanish missing ***" + +msgid "Please update the status of your request - {{request_title}}", +msgstr "*** Spanish missing *** {{request_title}}" + msgid "sent" msgstr "expedido" diff --git a/spec/mailers/alaveteli_pro/embargo_mailer_spec.rb b/spec/mailers/alaveteli_pro/embargo_mailer_spec.rb index 0a2b2e9c97..c3f3406aab 100644 --- a/spec/mailers/alaveteli_pro/embargo_mailer_spec.rb +++ b/spec/mailers/alaveteli_pro/embargo_mailer_spec.rb @@ -121,6 +121,21 @@ expect(@message.subject).to eq expected_subject end + context "when the user does not use default locale" do + before do + pro_user.locale = 'es' + @message = AlaveteliPro::EmbargoMailer. + expiring_alert(pro_user, [expiring_1]). + message + end + + it "translates the subject" do + expect(@message.subject). to eq( + "*** Spanish missing *** 1 *** Alaveteli" + ) + end + end + it "sends the email to the user" do expect(@message.to).to eq [pro_user.email] end @@ -142,6 +157,21 @@ expect(@message.subject).to eq expected_subject end + context "when the user does not use default locale" do + before do + pro_user.locale = 'es' + @message = AlaveteliPro::EmbargoMailer. + expiring_alert(pro_user, [expiring_1, expiring_2]). + message + end + + it "translates the subject" do + expect(@message.subject). to eq( + "*** Spanish missings *** 2 *** Alaveteli" + ) + end + end + it "sends the email to the user" do expect(@message.to).to eq [pro_user.email] end @@ -245,6 +275,21 @@ expect(@message.subject).to eq expected end + context "when the user does not use default locale" do + before do + pro_user.locale = 'es' + @message = AlaveteliPro::EmbargoMailer. + expired_alert(pro_user, [expired_1]). + message + end + + it "translates the subject" do + expect(@message.subject). to eq( + "*** Spanish missing *** 1 *** Alaveteli" + ) + end + end + it "sends the email to the user" do expect(@message.to).to eq [pro_user.email] end @@ -266,6 +311,21 @@ expect(@message.subject).to eq expected end + context "when the user does not use default locale" do + before do + pro_user.locale = 'es' + @message = AlaveteliPro::EmbargoMailer. + expired_alert(pro_user, [expired_1, expired_2]). + message + end + + it "translates the subject" do + expect(@message.subject). to eq( + "*** Spanish missings *** 2 *** Alaveteli" + ) + end + end + it "sends the email to the user" do expect(@message.to).to eq [pro_user.email] end diff --git a/spec/mailers/alaveteli_pro/subscription_mailer_spec.rb b/spec/mailers/alaveteli_pro/subscription_mailer_spec.rb index 80c8511b89..582f7fa3b6 100644 --- a/spec/mailers/alaveteli_pro/subscription_mailer_spec.rb +++ b/spec/mailers/alaveteli_pro/subscription_mailer_spec.rb @@ -31,5 +31,16 @@ expect(subject.body.to_s).not_to match(/&laveteli Pro/) end end + + context "when the user does not use default locale" do + before do + user.locale = 'es' + end + + it "translates the subject" do + expect(subject.subject). + to eq "*** Spanish missing *** Alaveteli Professional" + end + end end end diff --git a/spec/mailers/info_request_batch_mailer_spec.rb b/spec/mailers/info_request_batch_mailer_spec.rb index 2fad5de39e..21a9488634 100644 --- a/spec/mailers/info_request_batch_mailer_spec.rb +++ b/spec/mailers/info_request_batch_mailer_spec.rb @@ -23,6 +23,22 @@ to eq('Your batch request "Apostrophe\'s" has been sent') end + context "when the user does not use default locale" do + before do + @user.locale = 'es' + @mail = InfoRequestBatchMailer.batch_sent( + @info_request_batch, + @unrequestable, + @user + ) + end + + it "translates the subject" do + expect(@mail.subject). + to eq "Tu solicitud en lote \"Example title\" ha sido enviada" + end + end + it 'renders the receiver email' do expect(@mail.to).to eq([@user.email]) end diff --git a/spec/mailers/notification_mailer_spec.rb b/spec/mailers/notification_mailer_spec.rb index b785845828..c5c3fe61a9 100644 --- a/spec/mailers/notification_mailer_spec.rb +++ b/spec/mailers/notification_mailer_spec.rb @@ -383,6 +383,18 @@ to eq("Your daily request summary from Alaveteli Professional") end + context "when the user does not use default locale" do + before do + user.locale = 'es' + end + + it "translates the subject" do + mail = NotificationMailer.daily_summary(user, all_notifications) + expect(mail.subject). + to eq("*** Spanish missing *** Alaveteli Professional") + end + end + it "matches the expected message" do mail = NotificationMailer.daily_summary(user, all_notifications) expected_message = load_file_fixture( @@ -455,6 +467,20 @@ end end + context "when the user does not use default locale" do + before do + info_request.title = "A request" + info_request.user.locale = 'es' + end + + it "translates the subject" do + mail = NotificationMailer.response_notification(notification) + expect(mail.subject).to eq( + "Nueva respuesta a tu solicitud de información - A request" + ) + end + end + it "sends the message to the right user" do mail = NotificationMailer.response_notification(notification) expect(mail.to).to eq [info_request.user.email] @@ -542,6 +568,19 @@ end end + context "when the user does not use default locale" do + before do + info_request.title = "A request" + info_request.user.locale = 'es' + end + + it "translates the subject" do + mail = NotificationMailer.embargo_expiring_notification(notification) + expect(mail.subject). + to eq("*** Spanish missing *** A request *** Alaveteli") + end + end + it "sends the message to the right user" do mail = NotificationMailer.embargo_expiring_notification(notification) expect(mail.to).to eq [info_request.user.email] @@ -612,6 +651,19 @@ end end + context "when the user does not use default locale" do + before do + info_request.title = "A request" + info_request.user.locale = 'es' + end + + it "translates the subject" do + mail = NotificationMailer.expire_embargo_notification(notification) + expect(mail.subject). + to eq("*** Spanish missing *** A request *** Alaveteli") + end + end + it 'sends the message to the right user' do mail = NotificationMailer.expire_embargo_notification(notification) expect(mail.to).to eq [info_request.user.email] @@ -678,6 +730,21 @@ end end + context "when the user does not use default locale" do + before do + info_request.title = "A request" + info_request.user.locale = 'es' + end + + it "translates the subject" do + mail = NotificationMailer.overdue_notification(notification) + expect(mail.subject). to eq( + "Respuesta retrasada a tu solicitud de acceso a información - "\ + "A request" + ) + end + end + it "sends the message to the right user" do mail = NotificationMailer.overdue_notification(notification) expect(mail.to).to eq [info_request.user.email] @@ -746,6 +813,21 @@ end end + context "when the user does not use default locale" do + before do + info_request.title = "A request" + info_request.user.locale = 'es' + end + + it "translates the subject" do + mail = NotificationMailer.very_overdue_notification(notification) + expect(mail.subject). to eq( + "La respuesta a tu solicitud de información está muy retrasada - "\ + "A request" + ) + end + end + it "sends the message to the right user" do mail = NotificationMailer.very_overdue_notification(notification) expect(mail.to).to eq [info_request.user.email] diff --git a/spec/mailers/request_mailer_spec.rb b/spec/mailers/request_mailer_spec.rb index 653db16fe0..0de4bd9b33 100644 --- a/spec/mailers/request_mailer_spec.rb +++ b/spec/mailers/request_mailer_spec.rb @@ -542,6 +542,18 @@ def sent_alert_params(request, type) expect(mail.subject).to eq('Someone has updated the status of your request') end + context "when the user does not use default locale" do + before do + info_request.user.locale = 'es' + end + + it "translates the subject" do + expect(mail.subject).to eq( + 'Alguien ha actualizado el estado de tu solicitud' + ) + end + end + it 'should tell them what status was picked' do expect(mail.body).to match(/"refused."/) end @@ -603,6 +615,23 @@ def sent_alert_params(request, type) expect(mail.subject).to eq "New response to your FOI request - Here's a request" end + context "when the user does not use default locale" do + before do + info_request.title = "A request" + info_request.user.locale = 'es' + end + + it "translates the subject" do + mail = RequestMailer.new_response( + info_request, + FactoryBot.create(:incoming_message) + ) + expect(mail.subject).to eq( + "Nueva respuesta a tu solicitud de información - A request" + ) + end + end + it 'should send pro users a signin link' do pro_user = FactoryBot.create(:pro_user) info_request = FactoryBot.create(:embargoed_request, user: pro_user) @@ -640,6 +669,10 @@ def sent_alert_params(request, type) mail = deliveries[0] expect(mail.body).to match(/To let everyone know/) expect(mail.to_addrs.first.to_s).to eq(info_request.user.email) + expect(mail.subject).to eq( + "Please update the status of your request - "\ + "Why do you have & such a fancy dog?" + ) mail.body.to_s =~ /(http:\/\/.*)/ mail_url = $1 @@ -654,6 +687,29 @@ def sent_alert_params(request, type) # Split on %23 as the redirect is URL encoded expect(mail_url.split('%23').last).to eq('describe_state_form_1') end + + context "when the user does not use default locale" do + before do + user = users(:bob_smith_user) + @old_locale = user.locale + user.locale = 'es' + user.save + RequestMailer.alert_new_response_reminders + end + + after do + user = users(:bob_smith_user) + user.locale = @old_locale + user.save + end + + it "translates the subject" do + expect(ActionMailer::Base.deliveries[0].subject).to eq( + "*** Spanish missing *** "\ + "Why do you have & such a fancy dog?" + ) + end + end end describe "requires_admin" do @@ -733,6 +789,21 @@ def kitten_mails expect(mail.subject).to eq "Delayed response to your FOI request - Here's a request" end + context "when the user does not use default locale" do + before do + @info_request = FactoryBot.create(:info_request, title: "A request") + @info_request.user.locale = 'es' + @mail = RequestMailer.overdue_alert(@info_request, @info_request.user) + end + + it "translates the subject" do + expect(@mail.subject).to eq( + "Respuesta retrasada a tu solicitud de acceso a información - "\ + "A request" + ) + end + end + it "sends an overdue alert mail to request creators" do travel_to(31.days.from_now) do RequestMailer.alert_overdue_requests @@ -847,6 +918,24 @@ def kitten_mails "to your FOI request - Here's a request" end + context "when the user does not use default locale" do + before do + @info_request = FactoryBot.create(:info_request, title: "A request") + @info_request.user.locale = 'es' + @mail = RequestMailer.very_overdue_alert( + @info_request, + @info_request.user + ) + end + + it "translates the subject" do + expect(@mail.subject).to eq( + "La respuesta a tu solicitud de información está muy retrasada - "\ + "A request" + ) + end + end + it "sends a very overdue alert mail to creators of very overdue requests" do travel_to(Time.now + 61.days) do RequestMailer.alert_overdue_requests @@ -902,6 +991,23 @@ def kitten_mails mail = RequestMailer.not_clarified_alert(FactoryBot.create(:info_request, title: "Here's a request"), FactoryBot.create(:incoming_message)) expect(mail.subject).to eq "Clarify your FOI request - Here's a request" end + + context "when the user does not use default locale" do + before do + info_request = FactoryBot.create(:info_request, title: "A request") + info_request.user.locale = 'es' + @mail = RequestMailer.not_clarified_alert( + info_request, + FactoryBot.create(:incoming_message) + ) + end + + it "translates the subject" do + expect(@mail.subject).to eq( + "Clarifica tu solicitud de información - A request" + ) + end + end end describe "comment_on_alert" do @@ -909,6 +1015,24 @@ def kitten_mails mail = RequestMailer.comment_on_alert(FactoryBot.create(:info_request, title: "Here's a request"), FactoryBot.create(:comment)) expect(mail.subject).to eq "Somebody added a note to your FOI request - Here's a request" end + + context "when the user does not use default locale" do + before do + info_request = FactoryBot.create(:info_request, title: "A request") + info_request.user.locale = 'es' + @mail = RequestMailer.comment_on_alert( + info_request, + FactoryBot.create(:comment) + ) + end + + it "translates the subject" do + expect(@mail.subject).to eq( + "Nuevo comentario en tu solicitud de acceso a información - "\ + "A request" + ) + end + end end describe "comment_on_alert_plural" do @@ -916,6 +1040,25 @@ def kitten_mails mail = RequestMailer.comment_on_alert_plural(FactoryBot.create(:info_request, title: "Here's a request"), 2, FactoryBot.create(:comment)) expect(mail.subject).to eq "Some notes have been added to your FOI request - Here's a request" end + + context "when the user does not use default locale" do + before do + info_request = FactoryBot.create(:info_request, title: "A request") + info_request.user.locale = 'es' + @mail = RequestMailer.comment_on_alert_plural( + info_request, + 2, + FactoryBot.create(:comment) + ) + end + + it "translates the subject" do + expect(@mail.subject).to eq( + "Nuevos comentarios en tu solicitud de acceso a información - "\ + "A request" + ) + end + end end describe "clarification required alerts" do diff --git a/spec/mailers/survey_mailer_spec.rb b/spec/mailers/survey_mailer_spec.rb index 80dc47046f..f72bd8ca47 100644 --- a/spec/mailers/survey_mailer_spec.rb +++ b/spec/mailers/survey_mailer_spec.rb @@ -26,12 +26,37 @@ def get_surveyable_request(user = nil) expect(ActionMailer::Base.deliveries.size).to eq(1) end + it "sends a mail with correct subject" do + info_request = get_surveyable_request + SurveyMailer.alert_survey + mail = ActionMailer::Base.deliveries.first + expect(mail.subject). to eq( + "A survey about your recent Freedom of Information request" + ) + end + it 'records the sending of the alert' do info_request = get_surveyable_request SurveyMailer.alert_survey expect(info_request.user.user_info_request_sent_alerts.size). to eq(1) end + + context "when the user does not use default locale" do + before do + @info_request = get_surveyable_request( + FactoryBot.create(:user, locale: 'es') + ) + SurveyMailer.alert_survey + end + + it "translates the subject" do + mail = ActionMailer::Base.deliveries.first + expect(mail.subject). to eq( + "*** Spanish missing ***" + ) + end + end end context 'when a user has made multiple qualifying requests' do diff --git a/spec/mailers/track_mailer_spec.rb b/spec/mailers/track_mailer_spec.rb index c7e8c62c9a..f4e191ea6c 100644 --- a/spec/mailers/track_mailer_spec.rb +++ b/spec/mailers/track_mailer_spec.rb @@ -189,7 +189,8 @@ ActionMailer::Base.deliveries = [] @user = mock_model(User, name_and_email: MailHandler.address_from_name_and_email('Tippy Test', 'tippy@localhost'), - url_name: 'tippy_test' + url_name: 'tippy_test', + locale: 'es' ) TrackMailer.event_digest(@user, []).deliver_now # no items in it email for minimal test end @@ -216,8 +217,14 @@ deliveries = ActionMailer::Base.deliveries expect(deliveries.size).to eq(1) mail = deliveries[0] + expect(mail.subject).to eq "Tu alerta en L'information" + end - expect(mail.subject).to eq "Your L'information email alert" + it "translates the subject for a user with non-default locale" do + # Yes, this is indeed just the same test as above. We simply give the + # user a non-default locale in the "before". Use let bindings instead? + expect(ActionMailer::Base.deliveries[0].subject). + to eq "Tu alerta en L'information" end it "does not alert about embargoed requests" do From 7e08c2d319033fe8153218e495a2b7aee6e7eeaf Mon Sep 17 00:00:00 2001 From: Graeme Porteous Date: Mon, 6 Jan 2025 12:59:16 +0000 Subject: [PATCH 2/2] Update changelog --- doc/CHANGES.md | 1 + 1 file changed, 1 insertion(+) diff --git a/doc/CHANGES.md b/doc/CHANGES.md index e15c8c18b0..7901287661 100644 --- a/doc/CHANGES.md +++ b/doc/CHANGES.md @@ -2,6 +2,7 @@ ## Highlighted Features +* Localise alert email subjects in the receiver's language (Anders Lindeberg) * Remove deprecated Google Chart from request game (Gareth Rees) * Migrated from Stripe Plans to Stripe Prices (Graeme Porteous) * Change notes so that records tagged with `name:value` will be associated with