2020-11-24 15:15:51 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe Oauth::Jira::AuthorizationsController do
|
|
|
|
describe 'GET new' do
|
|
|
|
it 'redirects to OAuth authorization with correct params' do
|
2021-06-08 01:23:25 +05:30
|
|
|
get :new, params: { client_id: 'client-123', scope: 'foo', redirect_uri: 'http://example.com/' }
|
2020-11-24 15:15:51 +05:30
|
|
|
|
|
|
|
expect(response).to redirect_to(oauth_authorization_url(client_id: 'client-123',
|
|
|
|
response_type: 'code',
|
2021-06-08 01:23:25 +05:30
|
|
|
scope: 'foo',
|
|
|
|
redirect_uri: oauth_jira_callback_url))
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'replaces the GitHub "repo" scope with "api"' do
|
|
|
|
get :new, params: { client_id: 'client-123', scope: 'repo', redirect_uri: 'http://example.com/' }
|
|
|
|
|
|
|
|
expect(response).to redirect_to(oauth_authorization_url(client_id: 'client-123',
|
|
|
|
response_type: 'code',
|
|
|
|
scope: 'api',
|
2020-11-24 15:15:51 +05:30
|
|
|
redirect_uri: oauth_jira_callback_url))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'GET callback' do
|
|
|
|
it 'redirects to redirect_uri on session with code param' do
|
|
|
|
session['redirect_uri'] = 'http://example.com'
|
|
|
|
|
|
|
|
get :callback, params: { code: 'hash-123' }
|
|
|
|
|
|
|
|
expect(response).to redirect_to('http://example.com?code=hash-123')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'redirects to redirect_uri on session with code param preserving existing query' do
|
|
|
|
session['redirect_uri'] = 'http://example.com?foo=bar'
|
|
|
|
|
|
|
|
get :callback, params: { code: 'hash-123' }
|
|
|
|
|
|
|
|
expect(response).to redirect_to('http://example.com?foo=bar&code=hash-123')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'POST access_token' do
|
|
|
|
it 'returns oauth params in a format Jira expects' do
|
|
|
|
expect_any_instance_of(Doorkeeper::Request::AuthorizationCode).to receive(:authorize) do
|
|
|
|
double(status: :ok, body: { 'access_token' => 'fake-123', 'scope' => 'foo', 'token_type' => 'bar' })
|
|
|
|
end
|
|
|
|
|
|
|
|
post :access_token, params: { code: 'code-123', client_id: 'client-123', client_secret: 'secret-123' }
|
|
|
|
|
|
|
|
expect(response.body).to eq('access_token=fake-123&scope=foo&token_type=bar')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|