From 0115079b107f3e4517b38567328cb5c83f537143 Mon Sep 17 00:00:00 2001 From: Eric Date: Wed, 3 Jan 2024 23:39:07 +0100 Subject: [PATCH 1/2] Grape::Deprecator's Behavior is set to raise in test Fix multiple specs --- docker-compose.yml | 1 + spec/grape/api_spec.rb | 2 +- spec/grape/dsl/inside_route_spec.rb | 18 ------------- spec/grape/endpoint_spec.rb | 2 +- spec/grape/validations/params_scope_spec.rb | 2 +- .../validations/validators/values_spec.rb | 26 +++++++++---------- spec/integration/multi_xml/xml_spec.rb | 2 +- spec/spec_helper.rb | 2 ++ 8 files changed, 20 insertions(+), 35 deletions(-) diff --git a/docker-compose.yml b/docker-compose.yml index 2b293708b1..5ee62348f0 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -12,6 +12,7 @@ services: - RUBY_VERSION=${RUBY_VERSION:-3} stdin_open: true tty: true + platform: linux/amd64 volumes: - .:/var/grape - gems:/usr/local/bundle diff --git a/spec/grape/api_spec.rb b/spec/grape/api_spec.rb index 8c9d876034..243c6cb9ed 100644 --- a/spec/grape/api_spec.rb +++ b/spec/grape/api_spec.rb @@ -1239,7 +1239,7 @@ class DummyFormatClass test_file.write file_content test_file.rewind - subject.get('/file') { file test_file } + subject.get('/file') { stream test_file } get '/file' expect(last_response.headers[Rack::CONTENT_LENGTH]).to eq('25') expect(last_response.headers[Rack::CONTENT_TYPE]).to eq('text/plain') diff --git a/spec/grape/dsl/inside_route_spec.rb b/spec/grape/dsl/inside_route_spec.rb index 931382e48c..7c6d752362 100644 --- a/spec/grape/dsl/inside_route_spec.rb +++ b/spec/grape/dsl/inside_route_spec.rb @@ -209,13 +209,7 @@ def initialize it 'emits a warning that this method is deprecated' do expect(Grape.deprecator).to receive(:warn).with(/Use sendfile or stream/) - - subject.file file_path - end - - it 'forwards the call to sendfile' do expect(subject).to receive(:sendfile).with(file_path) - subject.file file_path end end @@ -225,13 +219,7 @@ def initialize it 'emits a warning that this method is deprecated' do expect(Grape.deprecator).to receive(:warn).with(/Use stream to use a Stream object/) - - subject.file file_object - end - - it 'forwards the call to stream' do expect(subject).to receive(:stream).with(file_object) - subject.file file_object end end @@ -240,13 +228,7 @@ def initialize describe 'get' do it 'emits a warning that this method is deprecated' do expect(Grape.deprecator).to receive(:warn).with(/Use sendfile or stream/) - - subject.file - end - - it 'fowards call to sendfile' do expect(subject).to receive(:sendfile) - subject.file end end diff --git a/spec/grape/endpoint_spec.rb b/spec/grape/endpoint_spec.rb index 46a17a2b77..94d0443c37 100644 --- a/spec/grape/endpoint_spec.rb +++ b/spec/grape/endpoint_spec.rb @@ -979,7 +979,7 @@ def memoized context 'binary' do before do subject.get do - file FileStreamer.new(__FILE__) + stream FileStreamer.new(__FILE__) end end diff --git a/spec/grape/validations/params_scope_spec.rb b/spec/grape/validations/params_scope_spec.rb index 05fa9c265a..71caa267d0 100644 --- a/spec/grape/validations/params_scope_spec.rb +++ b/spec/grape/validations/params_scope_spec.rb @@ -179,7 +179,7 @@ def initialize(value) end it 'allows the proc to pass validation without checking in except' do - subject.params { requires :numbers, type: Integer, values: { except: -> { [0, 1, 2] } } } + subject.params { requires :numbers, type: Integer, except_values: -> { [0, 1, 2] } } subject.post('/required') { 'coercion with proc works' } post '/required', numbers: '10' diff --git a/spec/grape/validations/validators/values_spec.rb b/spec/grape/validations/validators/values_spec.rb index 5d8daab914..4780829a10 100644 --- a/spec/grape/validations/validators/values_spec.rb +++ b/spec/grape/validations/validators/values_spec.rb @@ -63,17 +63,17 @@ def even?(value) end params do - requires :type, values: { except: ValuesModel.excepts, except_message: 'value is on exclusions list', message: 'default exclude message' } + requires :type, except_values: { value: ValuesModel.excepts, message: 'value is on exclusions list' }, default: 'default exclude message' end get '/exclude/exclude_message' params do - requires :type, values: { except: -> { ValuesModel.excepts }, except_message: 'value is on exclusions list' } + requires :type, except_values: { value: -> { ValuesModel.excepts }, message: 'value is on exclusions list' } end get '/exclude/lambda/exclude_message' params do - requires :type, values: { except: ValuesModel.excepts, message: 'default exclude message' } + requires :type, except_values: { value: ValuesModel.excepts, message: 'default exclude message' } end get '/exclude/fallback_message' end @@ -105,7 +105,7 @@ def even?(value) end params do - optional :type, values: { except: ValuesModel.excepts }, default: 'valid-type2' + optional :type, except_values: ValuesModel.excepts, default: 'valid-type2' end get '/default/except' do { type: params[:type] } @@ -187,42 +187,42 @@ def even?(value) get '/optional_with_required_values' params do - requires :type, values: { except: ValuesModel.excepts } + requires :type, except_values: ValuesModel.excepts end get '/except/exclusive' do { type: params[:type] } end params do - requires :type, type: String, values: { except: ValuesModel.excepts } + requires :type, type: String, except_values: ValuesModel.excepts end get '/except/exclusive/type' do { type: params[:type] } end params do - requires :type, values: { except: -> { ValuesModel.excepts } } + requires :type, except_values: ValuesModel.excepts end get '/except/exclusive/lambda' do { type: params[:type] } end params do - requires :type, type: String, values: { except: -> { ValuesModel.excepts } } + requires :type, type: String, except_values: -> { ValuesModel.excepts } end get '/except/exclusive/lambda/type' do { type: params[:type] } end params do - requires :type, type: Integer, values: { except: -> { [3, 4, 5] } } + requires :type, type: Integer, except_values: -> { [3, 4, 5] } end get '/except/exclusive/lambda/coercion' do { type: params[:type] } end params do - requires :type, type: Integer, values: { value: 1..5, except: [3] } + requires :type, type: Integer, values: 1..5, except_values: [3] end get '/mixed/value/except' do { type: params[:type] } @@ -234,14 +234,14 @@ def even?(value) put '/optional_with_array_of_string_values' params do - requires :type, values: { proc: ->(v) { ValuesModel.include? v } } + requires :type, values: ->(v) { ValuesModel.include? v } end get '/proc' do { type: params[:type] } end params do - requires :type, values: { proc: ->(v) { ValuesModel.include? v }, message: 'failed check' } + requires :type, values: { value: ->(v) { ValuesModel.include? v }, message: 'failed check' } end get '/proc/message' @@ -520,7 +520,7 @@ def even?(value) it 'raises IncompatibleOptionValues when except contains a value that is not a kind of the type' do subject = Class.new(Grape::API) expect do - subject.params { requires :type, values: { except: [10.5, 11] }, type: Integer } + subject.params { requires :type, except_values: [10.5, 11], type: Integer } end.to raise_error Grape::Exceptions::IncompatibleOptionValues end diff --git a/spec/integration/multi_xml/xml_spec.rb b/spec/integration/multi_xml/xml_spec.rb index 54d918e558..9dc4b5094e 100644 --- a/spec/integration/multi_xml/xml_spec.rb +++ b/spec/integration/multi_xml/xml_spec.rb @@ -1,6 +1,6 @@ # frozen_string_literal: true -describe Grape::Xml do +describe Grape::Xml, if: defined?(MultiXml) do it 'uses multi_xml' do expect(described_class).to eq(::MultiXml) end diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 1a2581ae75..af3ff82566 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -10,6 +10,8 @@ require 'grape' +Grape.deprecator.behavior = :raise + %w[config support].each do |dir| Dir["#{File.dirname(__FILE__)}/#{dir}/**/*.rb"].sort.each do |file| require file From de18dd1133cd74584f2fbe7e0dd4a36e8a251ba5 Mon Sep 17 00:00:00 2001 From: Eric Date: Wed, 3 Jan 2024 23:44:48 +0100 Subject: [PATCH 2/2] Add CHANGELOG.md Revert docker-compose.yml --- CHANGELOG.md | 1 + docker-compose.yml | 1 - 2 files changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 57237c82c8..43ff91251f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -12,6 +12,7 @@ * [#2395](https://github.com/ruby-grape/grape/pull/2395): Set `max-age` to 0 when `cookies.delete` - [@ericproulx](https://github.com/ericproulx). * [#2397](https://github.com/ruby-grape/grape/pull/2397): Add support for ruby 3.3 - [@ericproulx](https://github.com/ericproulx). * [#2399](https://github.com/ruby-grape/grape/pull/2399): Update `rubocop` to 1.59.0, `rubocop-performance` to 1.20.1 and `rubocop-rspec` to 2.25.0 - [@ericproulx](https://github.com/ericproulx). +* [#2402](https://github.com/ruby-grape/grape/pull/2402): Grape::Deprecations will be raised when running specs - [@ericproulx](https://github.com/ericproulx). * Your contribution here. #### Fixes diff --git a/docker-compose.yml b/docker-compose.yml index 5ee62348f0..2b293708b1 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -12,7 +12,6 @@ services: - RUBY_VERSION=${RUBY_VERSION:-3} stdin_open: true tty: true - platform: linux/amd64 volumes: - .:/var/grape - gems:/usr/local/bundle