diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2022-11-17 14:33:21 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2022-11-17 14:33:21 +0300 |
commit | 7021455bd1ed7b125c55eb1b33c5a01f2bc55ee0 (patch) | |
tree | 5bdc2229f5198d516781f8d24eace62fc7e589e9 /spec/initializers/sawyer_patch_spec.rb | |
parent | 185b095e93520f96e9cfc31d9c3e69b498cdab7c (diff) |
Add latest changes from gitlab-org/gitlab@15-6-stable-eev15.6.0-rc42
Diffstat (limited to 'spec/initializers/sawyer_patch_spec.rb')
-rw-r--r-- | spec/initializers/sawyer_patch_spec.rb | 70 |
1 files changed, 14 insertions, 56 deletions
diff --git a/spec/initializers/sawyer_patch_spec.rb b/spec/initializers/sawyer_patch_spec.rb index b3c10e63460..9fcdc9583aa 100644 --- a/spec/initializers/sawyer_patch_spec.rb +++ b/spec/initializers/sawyer_patch_spec.rb @@ -1,36 +1,33 @@ # frozen_string_literal: true + require 'spec_helper' require 'sawyer' require_relative '../../config/initializers/sawyer_patch' RSpec.describe 'sawyer_patch' do - it 'raises error when acessing a method that overlaps a Ruby method' do + it 'raises error when acessing Sawyer Resource dynamic methods' do sawyer_resource = Sawyer::Resource.new( Sawyer::Agent.new(''), { to_s: 'Overriding method', + nil?: 'value', + login: 'Login', user: { to_s: 'Overriding method', name: 'User name' } } ) - error_message = 'Sawyer method "to_s" overlaps Ruby method. Convert to a hash to access the attribute.' - expect { sawyer_resource.to_s }.to raise_error(Sawyer::Error, error_message) - expect { sawyer_resource.to_s? }.to raise_error(Sawyer::Error, error_message) - expect { sawyer_resource.to_s = 'new value' }.to raise_error(Sawyer::Error, error_message) - expect { sawyer_resource.user.to_s }.to raise_error(Sawyer::Error, error_message) - expect(sawyer_resource.user.name).to eq('User name') - end - - it 'raises error when acessing a boolean method that overlaps a Ruby method' do - sawyer_resource = Sawyer::Resource.new( - Sawyer::Agent.new(''), - { - nil?: 'value' - } - ) - + expect { sawyer_resource.to_s }.to raise_error(Sawyer::Error) + expect { sawyer_resource.to_s? }.to raise_error(Sawyer::Error) + expect { sawyer_resource.to_s = 'new value' }.to raise_error(Sawyer::Error) expect { sawyer_resource.nil? }.to raise_error(Sawyer::Error) + expect { sawyer_resource.user.to_s }.to raise_error(Sawyer::Error) + expect { sawyer_resource.login }.to raise_error(Sawyer::Error) + expect { sawyer_resource.login? }.to raise_error(Sawyer::Error) + expect { sawyer_resource.login = 'New value' }.to raise_error(Sawyer::Error) + expect { sawyer_resource.user.name }.to raise_error(Sawyer::Error) + expect { sawyer_resource.user.name? }.to raise_error(Sawyer::Error) + expect { sawyer_resource.user.name = 'New value' }.to raise_error(Sawyer::Error) end it 'raises error when acessing a method that expects an argument' do @@ -45,47 +42,8 @@ RSpec.describe 'sawyer_patch' do } ) - expect(sawyer_resource.user).to eq('value') - expect { sawyer_resource.user = 'New user' }.to raise_error(ArgumentError) expect { sawyer_resource == true }.to raise_error(ArgumentError) expect { sawyer_resource != true }.to raise_error(ArgumentError) expect { sawyer_resource + 1 }.to raise_error(ArgumentError) end - - it 'does not raise error if is not an overlapping method' do - sawyer_resource = Sawyer::Resource.new( - Sawyer::Agent.new(''), - { - count_total: 1, - user: { name: 'User name' } - } - ) - - expect(sawyer_resource.count_total).to eq(1) - expect(sawyer_resource.count_total?).to eq(true) - expect(sawyer_resource.count_total + 1).to eq(2) - sawyer_resource.count_total = 3 - expect(sawyer_resource.count_total).to eq(3) - expect(sawyer_resource.user.name).to eq('User name') - end - - it 'logs when a sawyer resource dynamic method is called' do - sawyer_resource = Sawyer::Resource.new( - Sawyer::Agent.new(''), - { - count_total: 1, - user: { name: 'User name' } - } - ) - expected_attributes = [] - allow(Gitlab::Import::Logger).to receive(:warn) do |params| - expected_attributes.push(params[:attribute]) - end - - sawyer_resource.count_total - sawyer_resource.user - sawyer_resource.user.name - - expect(expected_attributes).to match_array(%i[count_total user user name]) - end end |