57 lines
1.3 KiB
Ruby
57 lines
1.3 KiB
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
require 'spec_helper'
|
||
|
|
||
|
RSpec.describe JiraConnect::BranchesController do
|
||
|
describe '#new' do
|
||
|
context 'when logged in' do
|
||
|
let_it_be(:user) { create(:user) }
|
||
|
|
||
|
before do
|
||
|
sign_in(user)
|
||
|
end
|
||
|
|
||
|
it 'assigns the suggested branch name' do
|
||
|
get :new, params: { issue_key: 'ACME-123', issue_summary: 'My Issue !@#$%' }
|
||
|
|
||
|
expect(response).to be_successful
|
||
|
expect(assigns(:branch_name)).to eq('ACME-123-my-issue')
|
||
|
end
|
||
|
|
||
|
it 'ignores missing summary' do
|
||
|
get :new, params: { issue_key: 'ACME-123' }
|
||
|
|
||
|
expect(response).to be_successful
|
||
|
expect(assigns(:branch_name)).to eq('ACME-123')
|
||
|
end
|
||
|
|
||
|
it 'does not set a branch name if key is not passed' do
|
||
|
get :new, params: { issue_summary: 'My issue' }
|
||
|
|
||
|
expect(response).to be_successful
|
||
|
expect(assigns(:branch_name)).to be_nil
|
||
|
end
|
||
|
|
||
|
context 'when feature flag is disabled' do
|
||
|
before do
|
||
|
stub_feature_flags(jira_connect_create_branch: false)
|
||
|
end
|
||
|
|
||
|
it 'renders a 404 error' do
|
||
|
get :new
|
||
|
|
||
|
expect(response).to be_not_found
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context 'when not logged in' do
|
||
|
it 'redirects to the login page' do
|
||
|
get :new
|
||
|
|
||
|
expect(response).to redirect_to(new_user_session_path)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|