LINE loginの機能をruby on railsで実装しました。現在は、そのテストをrspecとwebmock(Line loginの外部APIを使用するため)を使って行なっております。
↓以下のエラー文が表示され、うまく解決できません。ググってみたところsslに関連したエラーのようですがsslについてよくわかっておらず解決できません
error
11) LineLoginsController POST #callback line login when line_account is already registered in DB when user is already registered in DB redirects to the show_shifts_user_path 2 Failure/Error: stub_request(:post, 'https://api.line.me/v2/oauth/accessToken') 3 Net::HTTPBadResponse: 4 wrong status line: "{" 5 #./spec/controllers/line_logins_controller_spec.rb:43:in `block (3 levels) in <top (required)>'
↓以下がrspecデータです。一部省略しています。
line_logins_controller_spec.rb
1require 'spec_helper' 2require 'webmock' 3include WebMock::API 4WebMock.enable! 5 6AUTHORIZATION_CODE_RESPONSE = <<-EOS.freeze 7{ 8 "code":"b591dfd32eacc791df", 9 "state":"123abc", 10} 11EOS 12 13ACCESS_TOKEN_RESPONSE = <<-EOS.freeze 14{ 15 "scope":"P", 16 "access_token":"bNl4YEFPI/hjFWhTqexp4MuEw5YPs7qhr6dJDXKwNPuLka...", 17 "token_type":"Bearer", 18 "expires_in":2591977, 19 "refresh_token":"8iFFRdyxNVNLWYeteMMJ" 20} 21EOS 22 23PROFILES_CONTENT = <<-EOS.freeze 24{ 25 "displayName":"BOT API1", 26 "userId":"u206d25c2ea6bd87c17655609a1c37cb8", 27 "pictureUrl":nil, 28 "statusMessage":"Hello, LINE!" 29} 30EOS 31 32WebMock.allow_net_connect! 33 34RSpec.describe LineLoginsController, type: :controller do 35 describe 'POST #callback line login' do 36 let!(:fixed_user) { create(:fixed_user) } 37 let!(:line_account) { create(:line_account) } 38 before(:each) do 39 fixed_user.confirm 40 stub_request(:post, 'https://api.line.me/v2/oauth/accessToken') #line43 <--ここでエラー発生 41 .to_return (body = ACCESS_TOKEN_RESPONSE, status = 200) 42 stub_request(:post, 'https://api.line.me/v2/profile') 43 .with( headers: { 'Authorization' => "Bearer #{ACCESS_TOKEN_RESPONSE.access_token}" }) 44 .to_return (body = PROFILES_CONTENT, status = 200) 45 end 46 47 context 'when line_account is already registered in DB' do 48 context 'when user is already registered in DB' do 49 it 'redirects to the show_shifts_user_path' do 50 post :callback, params: AUTHORIZATION_CODE_RESPONSE 51 expect(response).to redirect_to "/users/#{fixed_user.id}/show_shifts_today_of" 52 end 53 end 54 end 55 end 56end
**追記
エラー部分のrubyコードを下に書きました
def receive_access_token_from response = line_api_client.post do |req| req.url '/v2/oauth/accessToken' req.headers['Content-Type'] = 'application/x-www-form-urlencoded' req.params = { grant_type: 'authorization_code', client_id: ENV['CHANNEL_ID_FOR_LINE_LOGIN'], client_secret: ENV['CHANNEL_SECRET_FOR_LINE_LOGIN'], code: params[:code], redirect_uri: "#{ENV['HEROKU_ROOT']}/line_logins/callback" } end hash = JSON.parse(response.body) @access_token = hash['access_token'] end
このエラーの解決方法をどなたかわかりませんでしょうか?
あなたの回答
tips
プレビュー