193 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			193 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
# frozen_string_literal: true
 | 
						|
 | 
						|
require 'rails_helper'
 | 
						|
 | 
						|
describe Settings::ApplicationsController do
 | 
						|
  render_views
 | 
						|
 | 
						|
  let!(:user) { Fabricate(:user) }
 | 
						|
  let!(:app) { Fabricate(:application, owner: user) }
 | 
						|
 | 
						|
  before do
 | 
						|
    sign_in user, scope: :user
 | 
						|
  end
 | 
						|
 | 
						|
  describe 'GET #index' do
 | 
						|
    before do
 | 
						|
      Fabricate(:application)
 | 
						|
      get :index
 | 
						|
    end
 | 
						|
 | 
						|
    it 'returns http success' do
 | 
						|
      expect(response).to have_http_status(200)
 | 
						|
    end
 | 
						|
 | 
						|
    it 'returns private cache control headers' do
 | 
						|
      expect(response.headers['Cache-Control']).to include('private, no-store')
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  describe 'GET #show' do
 | 
						|
    it 'returns http success' do
 | 
						|
      get :show, params: { id: app.id }
 | 
						|
      expect(response).to have_http_status(200)
 | 
						|
      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 }
 | 
						|
      expect(response).to have_http_status 404
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  describe 'GET #new' do
 | 
						|
    it 'returns http success' do
 | 
						|
      get :new
 | 
						|
      expect(response).to have_http_status(200)
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  describe 'POST #create' do
 | 
						|
    context 'when success (passed scopes as a String)' do
 | 
						|
      def call_create
 | 
						|
        post :create, params: {
 | 
						|
          doorkeeper_application: {
 | 
						|
            name: 'My New App',
 | 
						|
            redirect_uri: 'urn:ietf:wg:oauth:2.0:oob',
 | 
						|
            website: 'http://google.com',
 | 
						|
            scopes: 'read write follow',
 | 
						|
          },
 | 
						|
        }
 | 
						|
        response
 | 
						|
      end
 | 
						|
 | 
						|
      it 'creates an entry in the database' do
 | 
						|
        expect { call_create }.to change(Doorkeeper::Application, :count)
 | 
						|
      end
 | 
						|
 | 
						|
      it 'redirects back to applications page' do
 | 
						|
        expect(call_create).to redirect_to(settings_applications_path)
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    context 'when success (passed scopes as an Array)' do
 | 
						|
      def call_create
 | 
						|
        post :create, params: {
 | 
						|
          doorkeeper_application: {
 | 
						|
            name: 'My New App',
 | 
						|
            redirect_uri: 'urn:ietf:wg:oauth:2.0:oob',
 | 
						|
            website: 'http://google.com',
 | 
						|
            scopes: %w(read write follow),
 | 
						|
          },
 | 
						|
        }
 | 
						|
        response
 | 
						|
      end
 | 
						|
 | 
						|
      it 'creates an entry in the database' do
 | 
						|
        expect { call_create }.to change(Doorkeeper::Application, :count)
 | 
						|
      end
 | 
						|
 | 
						|
      it 'redirects back to applications page' do
 | 
						|
        expect(call_create).to redirect_to(settings_applications_path)
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    context 'with failure request' do
 | 
						|
      before do
 | 
						|
        post :create, params: {
 | 
						|
          doorkeeper_application: {
 | 
						|
            name: '',
 | 
						|
            redirect_uri: '',
 | 
						|
            website: '',
 | 
						|
            scopes: [],
 | 
						|
          },
 | 
						|
        }
 | 
						|
      end
 | 
						|
 | 
						|
      it 'returns http success' do
 | 
						|
        expect(response).to have_http_status(200)
 | 
						|
      end
 | 
						|
 | 
						|
      it 'renders form again' do
 | 
						|
        expect(response).to render_template(:new)
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  describe 'PATCH #update' do
 | 
						|
    context 'when success' do
 | 
						|
      let(:opts) do
 | 
						|
        {
 | 
						|
          website: 'https://foo.bar/',
 | 
						|
        }
 | 
						|
      end
 | 
						|
 | 
						|
      def call_update
 | 
						|
        patch :update, params: {
 | 
						|
          id: app.id,
 | 
						|
          doorkeeper_application: opts,
 | 
						|
        }
 | 
						|
        response
 | 
						|
      end
 | 
						|
 | 
						|
      it 'updates existing application' do
 | 
						|
        call_update
 | 
						|
        expect(app.reload.website).to eql(opts[:website])
 | 
						|
      end
 | 
						|
 | 
						|
      it 'redirects back to applications page' do
 | 
						|
        expect(call_update).to redirect_to(settings_application_path(app))
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    context 'with failure request' do
 | 
						|
      before do
 | 
						|
        patch :update, params: {
 | 
						|
          id: app.id,
 | 
						|
          doorkeeper_application: {
 | 
						|
            name: '',
 | 
						|
            redirect_uri: '',
 | 
						|
            website: '',
 | 
						|
            scopes: [],
 | 
						|
          },
 | 
						|
        }
 | 
						|
      end
 | 
						|
 | 
						|
      it 'returns http success' do
 | 
						|
        expect(response).to have_http_status(200)
 | 
						|
      end
 | 
						|
 | 
						|
      it 'renders form again' do
 | 
						|
        expect(response).to render_template(:show)
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  describe 'destroy' do
 | 
						|
    before do
 | 
						|
      post :destroy, params: { id: app.id }
 | 
						|
    end
 | 
						|
 | 
						|
    it 'redirects back to applications page' do
 | 
						|
      expect(response).to redirect_to(settings_applications_path)
 | 
						|
    end
 | 
						|
 | 
						|
    it 'removes the app' do
 | 
						|
      expect(Doorkeeper::Application.find_by(id: app.id)).to be_nil
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  describe 'regenerate' do
 | 
						|
    let(:token) { user.token_for_app(app) }
 | 
						|
 | 
						|
    it 'creates new token' do
 | 
						|
      expect(token).to_not be_nil
 | 
						|
      post :regenerate, params: { id: app.id }
 | 
						|
 | 
						|
      expect(user.token_for_app(app)).to_not eql(token)
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |