From f7c01d0ddc59a7c2316b9644f48fadf281f64c98 Mon Sep 17 00:00:00 2001 From: Joel Sugarman Date: Tue, 7 Jan 2025 15:01:43 +0000 Subject: [PATCH] AP-5659: Freeze string literals and use unary `+` for mutable strings Handle deprecation notices warning of ruby 4.0 intention to default string literals to be frozen/immutable. ```shell /Users/joel.sugarman/github/ministryofjustice/laa-apply-for-legal-aid/app/helpers/hash_format_helper.rb:23: warning: literal string will be frozen in the future (run with --debug-frozen-string-literal for more information) ``` --- app/helpers/hash_format_helper.rb | 6 ++++-- app/helpers/language_switcher_helper.rb | 4 +++- features/support/steps_helper.rb | 2 +- 3 files changed, 8 insertions(+), 4 deletions(-) diff --git a/app/helpers/hash_format_helper.rb b/app/helpers/hash_format_helper.rb index d22e6e53c6..cfa8808b2f 100644 --- a/app/helpers/hash_format_helper.rb +++ b/app/helpers/hash_format_helper.rb @@ -1,3 +1,5 @@ +# frozen_string_literal: true + module HashFormatHelper # These methods add classes to the HTML structure def format_hash(hash, html = "") @@ -19,7 +21,7 @@ def format_hash(hash, html = "") def build_dl_array(key, value) content_tag(:dl, class: "govuk-body kvp govuk-!-margin-bottom-0") do - dl_contents = "" + dl_contents = +"" dl_contents << content_tag(:dt, standardize_key(key)) value.each do |val| dl_contents << if val.is_a?(Hash) @@ -34,7 +36,7 @@ def build_dl_array(key, value) def build_dl(key, value) content_tag(:dl, class: "govuk-body kvp govuk-!-margin-bottom-0") do - dl_contents = "" + dl_contents = +"" dl_contents << content_tag(:dt, standardize_key(key)) dl_contents << if standard_type?(value) content_tag(:dd, value.to_s.capitalize) diff --git a/app/helpers/language_switcher_helper.rb b/app/helpers/language_switcher_helper.rb index 50daaf9d7f..b4a46aaeb4 100644 --- a/app/helpers/language_switcher_helper.rb +++ b/app/helpers/language_switcher_helper.rb @@ -1,6 +1,8 @@ +# frozen_string_literal: true + module LanguageSwitcherHelper def language_links - links = "" + links = +"" I18n.available_locales.each do |locale| link = I18n.locale == locale ? t("generic.#{locale}") : govuk_link_to(t("generic.#{locale}"), url_for(locale:)) diff --git a/features/support/steps_helper.rb b/features/support/steps_helper.rb index 7cafdd6a97..cf494f35fe 100644 --- a/features/support/steps_helper.rb +++ b/features/support/steps_helper.rb @@ -33,7 +33,7 @@ end Then("I choose the {string} frequency for {string}") do |frequency, field| - parts = [field, "frequency", frequency] + parts = [field, +"frequency", frequency] parts.each(&:downcase!) field_id = parts.join(" ").gsub(/\s+/, "-") id = find("input[id*=#{field_id}", visible: false)[:id]