2023-02-22 09:55:31 +09:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-08-23 01:33:57 +09:00
|
|
|
require 'rails_helper'
|
|
|
|
|
2024-09-04 14:12:25 +09:00
|
|
|
RSpec.describe Settings::ApplicationsController do
|
2017-08-23 01:33:57 +09:00
|
|
|
render_views
|
2017-11-17 10:52:30 +09:00
|
|
|
|
2017-08-23 01:33:57 +09:00
|
|
|
let!(:user) { Fabricate(:user) }
|
|
|
|
let!(:app) { Fabricate(:application, owner: user) }
|
2017-11-17 10:52:30 +09:00
|
|
|
|
2017-08-23 01:33:57 +09:00
|
|
|
before do
|
|
|
|
sign_in user, scope: :user
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'GET #index' do
|
2023-04-19 23:07:29 +09:00
|
|
|
before do
|
|
|
|
Fabricate(:application)
|
2017-08-23 01:33:57 +09:00
|
|
|
get :index
|
2023-04-19 23:07:29 +09:00
|
|
|
end
|
|
|
|
|
2023-11-11 00:13:42 +09:00
|
|
|
it 'returns http success with private cache control headers', :aggregate_failures do
|
2018-04-22 04:35:07 +09:00
|
|
|
expect(response).to have_http_status(200)
|
2023-04-19 23:07:29 +09:00
|
|
|
expect(response.headers['Cache-Control']).to include('private, no-store')
|
2017-08-23 01:33:57 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'GET #show' do
|
|
|
|
it 'returns http success' do
|
|
|
|
get :show, params: { id: app.id }
|
2018-04-22 04:35:07 +09:00
|
|
|
expect(response).to have_http_status(200)
|
2017-08-23 01:33:57 +09:00
|
|
|
expect(assigns[:application]).to eql(app)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns 404 if you dont own app' do
|
|
|
|
app.update!(owner: nil)
|
|
|
|
|
|
|
|
get :show, params: { id: app.id }
|
2023-02-20 11:16:40 +09:00
|
|
|
expect(response).to have_http_status 404
|
2017-08-23 01:33:57 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'GET #new' do
|
2023-02-18 11:26:20 +09:00
|
|
|
it 'returns http success' do
|
2017-08-23 01:33:57 +09:00
|
|
|
get :new
|
2018-04-22 04:35:07 +09:00
|
|
|
expect(response).to have_http_status(200)
|
2017-08-23 01:33:57 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'POST #create' do
|
2023-05-04 12:49:08 +09:00
|
|
|
context 'when success (passed scopes as a String)' do
|
2023-11-11 00:13:42 +09:00
|
|
|
subject do
|
2017-08-23 01:33:57 +09:00
|
|
|
post :create, params: {
|
2018-10-05 00:38:04 +09:00
|
|
|
doorkeeper_application: {
|
|
|
|
name: 'My New App',
|
|
|
|
redirect_uri: 'urn:ietf:wg:oauth:2.0:oob',
|
|
|
|
website: 'http://google.com',
|
2023-02-18 23:33:41 +09:00
|
|
|
scopes: 'read write follow',
|
|
|
|
},
|
2018-10-05 00:38:04 +09:00
|
|
|
}
|
2017-08-23 01:33:57 +09:00
|
|
|
end
|
|
|
|
|
2023-11-11 00:13:42 +09:00
|
|
|
it 'creates an entry in the database', :aggregate_failures do
|
|
|
|
expect { subject }.to change(Doorkeeper::Application, :count)
|
|
|
|
expect(response).to redirect_to(settings_applications_path)
|
2017-08-23 22:16:20 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 12:49:08 +09:00
|
|
|
context 'when success (passed scopes as an Array)' do
|
2023-11-11 00:13:42 +09:00
|
|
|
subject do
|
2017-08-23 22:16:20 +09:00
|
|
|
post :create, params: {
|
2018-10-05 00:38:04 +09:00
|
|
|
doorkeeper_application: {
|
|
|
|
name: 'My New App',
|
|
|
|
redirect_uri: 'urn:ietf:wg:oauth:2.0:oob',
|
|
|
|
website: 'http://google.com',
|
2023-02-20 14:14:10 +09:00
|
|
|
scopes: %w(read write follow),
|
2023-02-18 23:33:41 +09:00
|
|
|
},
|
2018-10-05 00:38:04 +09:00
|
|
|
}
|
2017-08-23 22:16:20 +09:00
|
|
|
end
|
|
|
|
|
2023-11-11 00:13:42 +09:00
|
|
|
it 'creates an entry in the database', :aggregate_failures do
|
|
|
|
expect { subject }.to change(Doorkeeper::Application, :count)
|
|
|
|
expect(response).to redirect_to(settings_applications_path)
|
2017-08-23 01:33:57 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 12:49:08 +09:00
|
|
|
context 'with failure request' do
|
2017-08-23 01:33:57 +09:00
|
|
|
before do
|
|
|
|
post :create, params: {
|
2018-10-05 00:38:04 +09:00
|
|
|
doorkeeper_application: {
|
|
|
|
name: '',
|
|
|
|
redirect_uri: '',
|
|
|
|
website: '',
|
2023-02-18 23:33:41 +09:00
|
|
|
scopes: [],
|
|
|
|
},
|
2018-10-05 00:38:04 +09:00
|
|
|
}
|
2017-08-23 01:33:57 +09:00
|
|
|
end
|
|
|
|
|
2023-11-11 00:13:42 +09:00
|
|
|
it 'returns http success and renders form', :aggregate_failures do
|
2018-04-22 04:35:07 +09:00
|
|
|
expect(response).to have_http_status(200)
|
2017-08-23 01:33:57 +09:00
|
|
|
expect(response).to render_template(:new)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-11-17 10:52:30 +09:00
|
|
|
|
2017-08-23 01:33:57 +09:00
|
|
|
describe 'PATCH #update' do
|
2023-05-04 12:49:08 +09:00
|
|
|
context 'when success' do
|
2023-11-11 00:13:42 +09:00
|
|
|
subject do
|
2017-08-23 01:33:57 +09:00
|
|
|
patch :update, params: {
|
2018-10-05 00:38:04 +09:00
|
|
|
id: app.id,
|
2023-02-18 23:33:41 +09:00
|
|
|
doorkeeper_application: opts,
|
2018-10-05 00:38:04 +09:00
|
|
|
}
|
2017-08-23 01:33:57 +09:00
|
|
|
response
|
|
|
|
end
|
|
|
|
|
2023-11-11 00:13:42 +09:00
|
|
|
let(:opts) do
|
|
|
|
{
|
|
|
|
website: 'https://foo.bar/',
|
|
|
|
}
|
2017-08-23 01:33:57 +09:00
|
|
|
end
|
2017-11-17 10:52:30 +09:00
|
|
|
|
2023-11-11 00:13:42 +09:00
|
|
|
it 'updates existing application' do
|
|
|
|
subject
|
|
|
|
|
|
|
|
expect(app.reload.website).to eql(opts[:website])
|
|
|
|
expect(response).to redirect_to(settings_application_path(app))
|
2017-08-23 01:33:57 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 12:49:08 +09:00
|
|
|
context 'with failure request' do
|
2017-08-23 01:33:57 +09:00
|
|
|
before do
|
|
|
|
patch :update, params: {
|
2018-10-05 00:38:04 +09:00
|
|
|
id: app.id,
|
|
|
|
doorkeeper_application: {
|
|
|
|
name: '',
|
|
|
|
redirect_uri: '',
|
|
|
|
website: '',
|
2023-02-18 23:33:41 +09:00
|
|
|
scopes: [],
|
|
|
|
},
|
2018-10-05 00:38:04 +09:00
|
|
|
}
|
2017-08-23 01:33:57 +09:00
|
|
|
end
|
|
|
|
|
2023-11-11 00:13:42 +09:00
|
|
|
it 'returns http success and renders form', :aggregate_failures do
|
2018-04-22 04:35:07 +09:00
|
|
|
expect(response).to have_http_status(200)
|
2017-08-23 01:33:57 +09:00
|
|
|
expect(response).to render_template(:show)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'destroy' do
|
2024-07-04 23:11:28 +09:00
|
|
|
let(:redis_pipeline_stub) { instance_double(Redis::Namespace, publish: nil) }
|
|
|
|
let!(:access_token) { Fabricate(:accessible_access_token, application: app) }
|
|
|
|
|
2017-08-23 01:33:57 +09:00
|
|
|
before do
|
2024-07-04 23:11:28 +09:00
|
|
|
allow(redis).to receive(:pipelined).and_yield(redis_pipeline_stub)
|
2017-08-23 01:33:57 +09:00
|
|
|
post :destroy, params: { id: app.id }
|
|
|
|
end
|
|
|
|
|
2024-07-04 23:11:28 +09:00
|
|
|
it 'redirects back to applications page removes the app' do
|
2017-08-23 01:33:57 +09:00
|
|
|
expect(response).to redirect_to(settings_applications_path)
|
|
|
|
expect(Doorkeeper::Application.find_by(id: app.id)).to be_nil
|
|
|
|
end
|
2024-07-04 23:11:28 +09:00
|
|
|
|
|
|
|
it 'sends a session kill payload to the streaming server' do
|
|
|
|
expect(redis_pipeline_stub).to have_received(:publish).with("timeline:access_token:#{access_token.id}", '{"event":"kill"}')
|
|
|
|
end
|
2017-08-23 01:33:57 +09:00
|
|
|
end
|
|
|
|
|
|
|
|
describe 'regenerate' do
|
|
|
|
let(:token) { user.token_for_app(app) }
|
2023-02-19 07:10:19 +09:00
|
|
|
|
2023-05-23 23:40:21 +09:00
|
|
|
it 'creates new token' do
|
2017-08-23 01:33:57 +09:00
|
|
|
expect(token).to_not be_nil
|
2017-08-23 07:59:35 +09:00
|
|
|
post :regenerate, params: { id: app.id }
|
2017-08-23 01:33:57 +09:00
|
|
|
|
|
|
|
expect(user.token_for_app(app)).to_not eql(token)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|