From 2555efc0f32939619477ff8c1155cc015855966b Mon Sep 17 00:00:00 2001 From: chaadow Date: Sat, 15 Jun 2024 01:39:48 +0100 Subject: [PATCH] Fix frozen string literal issues --- .github/workflows/ci.yml | 20 +++++++++++++++++-- Gemfile | 2 +- .../lambda/create_event_source_mapping.rb | 2 +- .../aws/requests/lambda/create_function.rb | 2 +- .../lambda/get_event_source_mapping.rb | 2 +- lib/fog/aws/requests/lambda/get_policy.rb | 2 +- lib/fog/aws/requests/lambda/invoke.rb | 4 ++-- .../lambda/update_event_source_mapping.rb | 2 +- lib/fog/aws/requests/storage/acl_utils.rb | 2 +- lib/fog/aws/requests/storage/cors_utils.rb | 2 +- tests/requests/lambda/helper.rb | 2 +- tests/requests/storage/object_tests.rb | 2 +- 12 files changed, 30 insertions(+), 14 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index f232d7bcac..9c4e45612d 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -12,5 +12,21 @@ permissions: contents: read jobs: - Shared: - uses: fog/.github/.github/workflows/ci.yml@v1.4.0 + test: + + runs-on: ubuntu-latest + + strategy: + matrix: + ruby-version: ['3.0', '3.1', '3.2', '3.3', 'head'] + continue-on-error: ${{ matrix.ruby-version == 'head' }} + + steps: + - uses: actions/checkout@v4 + - name: Set up Ruby + uses: ruby/setup-ruby@v1 + with: + ruby-version: ${{ matrix.ruby-version }} + bundler-cache: true # runs 'bundle install' and caches installed gems automatically + - name: Run tests + run: bundle exec rake RUBYOPT="--enable-frozen-string-literal" diff --git a/Gemfile b/Gemfile index e6a28da3f9..0150eacb6e 100644 --- a/Gemfile +++ b/Gemfile @@ -12,6 +12,6 @@ group :test, :default do end group :test do - gem "simplecov" + gem "simplecov", '~> 0.22.0' gem "codeclimate-test-reporter", "~> 1.0.0" end diff --git a/lib/fog/aws/requests/lambda/create_event_source_mapping.rb b/lib/fog/aws/requests/lambda/create_event_source_mapping.rb index 99a281ace2..cdf6ca3c47 100644 --- a/lib/fog/aws/requests/lambda/create_event_source_mapping.rb +++ b/lib/fog/aws/requests/lambda/create_event_source_mapping.rb @@ -56,7 +56,7 @@ def create_event_source_mapping(params={}) function = self.get_function_configuration('FunctionName' => function_name).body unless event_source_arn - message = "ValidationException => " + message = +"ValidationException => " message << "'eventSourceArn' cannot be blank" raise Fog::AWS::Lambda::Error, message end diff --git a/lib/fog/aws/requests/lambda/create_function.rb b/lib/fog/aws/requests/lambda/create_function.rb index 9dfaecfb20..e825fec6ca 100644 --- a/lib/fog/aws/requests/lambda/create_function.rb +++ b/lib/fog/aws/requests/lambda/create_function.rb @@ -109,7 +109,7 @@ def create_function(params={}) end if !function.empty? - message = "ResourceConflictException => " + message = +"ResourceConflictException => " message << "Function already exist: #{function_name}" raise Fog::AWS::Lambda::Error, message end diff --git a/lib/fog/aws/requests/lambda/get_event_source_mapping.rb b/lib/fog/aws/requests/lambda/get_event_source_mapping.rb index bc0bd879cd..cd59671420 100644 --- a/lib/fog/aws/requests/lambda/get_event_source_mapping.rb +++ b/lib/fog/aws/requests/lambda/get_event_source_mapping.rb @@ -33,7 +33,7 @@ def get_event_source_mapping(params={}) mapping_id = params.delete('UUID') unless mapping = self.data[:event_source_mappings][mapping_id] - message = 'ResourceNotFoundException => ' + message = +'ResourceNotFoundException => ' message << 'The resource you requested does not exist.' raise Fog::AWS::Lambda::Error, message end diff --git a/lib/fog/aws/requests/lambda/get_policy.rb b/lib/fog/aws/requests/lambda/get_policy.rb index bebc57406c..68f0a006d2 100644 --- a/lib/fog/aws/requests/lambda/get_policy.rb +++ b/lib/fog/aws/requests/lambda/get_policy.rb @@ -31,7 +31,7 @@ def get_policy(params={}) statements = self.data[:permissions][function_arn] || [] if statements.empty? - message = "ResourceNotFoundException => " + message = +"ResourceNotFoundException => " message << "The resource you requested does not exist." raise Fog::AWS::Lambda::Error, message end diff --git a/lib/fog/aws/requests/lambda/invoke.rb b/lib/fog/aws/requests/lambda/invoke.rb index 55be43828b..d857db998e 100644 --- a/lib/fog/aws/requests/lambda/invoke.rb +++ b/lib/fog/aws/requests/lambda/invoke.rb @@ -46,7 +46,7 @@ def invoke(params={}) response.body = '' unless function_id = params.delete('FunctionName') - message = 'AccessDeniedException => ' + message = +'AccessDeniedException => ' message << 'Unable to determine service/operation name to be authorized' raise Fog::AWS::Lambda::Error, message end @@ -63,7 +63,7 @@ def invoke(params={}) end if payload - message = "payload parameter is ignored since we are not really " + message = +"payload parameter is ignored since we are not really " message << "invoking a function [light_black](#{caller.first})[/]" Fog::Logger.warning message end diff --git a/lib/fog/aws/requests/lambda/update_event_source_mapping.rb b/lib/fog/aws/requests/lambda/update_event_source_mapping.rb index 65a67d1b2b..5e32575b93 100644 --- a/lib/fog/aws/requests/lambda/update_event_source_mapping.rb +++ b/lib/fog/aws/requests/lambda/update_event_source_mapping.rb @@ -47,7 +47,7 @@ def update_event_source_mapping(params={}) mapping = self.data[:event_source_mappings][mapping_id] unless mapping - message = 'ResourceNotFoundException => ' + message = +'ResourceNotFoundException => ' message << 'The resource you requested does not exist.' raise Fog::AWS::Lambda::Error, message end diff --git a/lib/fog/aws/requests/storage/acl_utils.rb b/lib/fog/aws/requests/storage/acl_utils.rb index 84a0339200..1e82697b30 100644 --- a/lib/fog/aws/requests/storage/acl_utils.rb +++ b/lib/fog/aws/requests/storage/acl_utils.rb @@ -5,7 +5,7 @@ class Storage private def self.hash_to_acl(acl) - data = "\n" + data = +"\n" if acl['Owner'] && (acl['Owner']['ID'] || acl['Owner']['DisplayName']) data << " \n" diff --git a/lib/fog/aws/requests/storage/cors_utils.rb b/lib/fog/aws/requests/storage/cors_utils.rb index 35cc38bc77..f8c8f8bdff 100644 --- a/lib/fog/aws/requests/storage/cors_utils.rb +++ b/lib/fog/aws/requests/storage/cors_utils.rb @@ -6,7 +6,7 @@ class Storage private def self.hash_to_cors(cors) - data = "\n" + data = +"\n" [cors['CORSConfiguration']].flatten.compact.each do |rule| data << " \n" diff --git a/tests/requests/lambda/helper.rb b/tests/requests/lambda/helper.rb index 733714c450..aea43f1d79 100644 --- a/tests/requests/lambda/helper.rb +++ b/tests/requests/lambda/helper.rb @@ -65,7 +65,7 @@ module Formats DELETE_EVENT_SOURCE_MAPPING = GET_EVENT_SOURCE_MAPPING def self.zip(data, filename='index.js') - data_io = Zip::OutputStream.write_buffer do |zio| + data_io = Zip::OutputStream.write_buffer(StringIO.new) do |zio| zio.put_next_entry(filename) zio.write(data) end diff --git a/tests/requests/storage/object_tests.rb b/tests/requests/storage/object_tests.rb index 053112163b..cf6de76060 100644 --- a/tests/requests/storage/object_tests.rb +++ b/tests/requests/storage/object_tests.rb @@ -36,7 +36,7 @@ end tests("#get_object('#{@directory.identity}', 'fog_object', &block)").returns(lorem_file.read) do - data = '' + data = +'' Fog::Storage[:aws].get_object(@directory.identity, 'fog_object') do |chunk, remaining_bytes, total_bytes| data << chunk end