3

Rack::Test でカスタム ヘッダーを送信しようとして、約 2 日間成功しませんでした。アプリにヘッダーを送信できません。同様のコードを使用したネットで多くの例を見つけました-メソッド(アドレス、ボディ、ヘッダー)、しかし私にとってはまったく機能しません。

ruby 2.5.1p57 (2018-03-29 リビジョン 63029) [x86_64-linux]

# grep rack  Gemfile.lock
    rack (2.0.4)
    rack-protection (2.0.1)
      rack
    rack-test (1.0.0)
      rack (>= 1.0, < 3)
      rack-protection (>= 1.5.0)
      rack (~> 2.0)
      rack-protection (= 2.0.1)
  rack-test

アプリ内のコード (sinatra):

$log = Logger.new STDERR
class MyApi < Sinatra::Application
  before do
    $log.debug{ "Headers: #{ headers.keys.inspect }" }
  end
  get '/offers' do
    #... some code
  end
  post '/offers' do
    # .. some another code
  end
end

仕様/api_spec.rb

RSpec.describe MyApi, '/offers' do
  include Rack::Test::Methods
  def app
    MyApi
  end

  context 'авторизация' do
    it 'правильная - get с токеном' do
      get '/offers', nil, {
        'X-Auth' => 'some key'
      }
      $log.debug{ "ENV was: '#{ last_request.env.keys }'" }
    end
    it 'правильная - post с токеном' do
      post '/offers', '', {
        'Content-Type' => 'application/json; charset: utf-8',
        'X-Auth' => 'some long key'
      }
    end
  end
end

出力には両方のテストが含まれます。

Headers: ["Content-Type"]
...
ENV was: '["rack.version", "rack.input", "rack.errors",
"rack.multithread", "rack.multiprocess", "rack.run_once", 
"REQUEST_METHOD", "SERVER_NAME", "SERVER_PORT", "QUERY_STRING", 
"PATH_INFO", "rack.url_scheme", "HTTPS", "SCRIPT_NAME", "CONTENT_LENGTH", 
"rack.test", "REMOTE_ADDR", "X-Auth", "HTTP_HOST", "HTTP_COOKIE", 
"sinatra.commonlogger", "rack.logger", "rack.request.query_string", 
"rack.request.query_hash"]'
4

2 に答える 2