148 lines
4 KiB
Ruby
148 lines
4 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe Projects::EnvironmentsController do
|
|
include ApiHelpers
|
|
|
|
let(:environment) { create(:environment) }
|
|
let(:project) { environment.project }
|
|
let(:user) { create(:user) }
|
|
|
|
before do
|
|
project.team << [user, :master]
|
|
|
|
sign_in(user)
|
|
end
|
|
|
|
describe 'GET index' do
|
|
context 'when standardrequest has been made' do
|
|
it 'responds with status code 200' do
|
|
get :index, environment_params
|
|
|
|
expect(response).to be_ok
|
|
end
|
|
end
|
|
|
|
context 'when requesting JSON response' do
|
|
it 'responds with correct JSON' do
|
|
get :index, environment_params(format: :json)
|
|
|
|
first_environment = json_response.first
|
|
|
|
expect(first_environment).not_to be_empty
|
|
expect(first_environment['name']). to eq environment.name
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'GET show' do
|
|
context 'with valid id' do
|
|
it 'responds with a status code 200' do
|
|
get :show, environment_params
|
|
|
|
expect(response).to be_ok
|
|
end
|
|
end
|
|
|
|
context 'with invalid id' do
|
|
it 'responds with a status code 404' do
|
|
params = environment_params
|
|
params[:id] = 12345
|
|
get :show, params
|
|
|
|
expect(response).to have_http_status(404)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'GET edit' do
|
|
it 'responds with a status code 200' do
|
|
get :edit, environment_params
|
|
|
|
expect(response).to be_ok
|
|
end
|
|
end
|
|
|
|
describe 'PATCH #update' do
|
|
it 'responds with a 302' do
|
|
patch_params = environment_params.merge(environment: { external_url: 'https://git.gitlab.com' })
|
|
patch :update, patch_params
|
|
|
|
expect(response).to have_http_status(302)
|
|
end
|
|
end
|
|
|
|
describe 'GET #terminal' do
|
|
context 'with valid id' do
|
|
it 'responds with a status code 200' do
|
|
get :terminal, environment_params
|
|
|
|
expect(response).to have_http_status(200)
|
|
end
|
|
|
|
it 'loads the terminals for the enviroment' do
|
|
expect_any_instance_of(Environment).to receive(:terminals)
|
|
|
|
get :terminal, environment_params
|
|
end
|
|
end
|
|
|
|
context 'with invalid id' do
|
|
it 'responds with a status code 404' do
|
|
get :terminal, environment_params(id: 666)
|
|
|
|
expect(response).to have_http_status(404)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'GET #terminal_websocket_authorize' do
|
|
context 'with valid workhorse signature' do
|
|
before do
|
|
allow(Gitlab::Workhorse).to receive(:verify_api_request!).and_return(nil)
|
|
end
|
|
|
|
context 'and valid id' do
|
|
it 'returns the first terminal for the environment' do
|
|
expect_any_instance_of(Environment).
|
|
to receive(:terminals).
|
|
and_return([:fake_terminal])
|
|
|
|
expect(Gitlab::Workhorse).
|
|
to receive(:terminal_websocket).
|
|
with(:fake_terminal).
|
|
and_return(workhorse: :response)
|
|
|
|
get :terminal_websocket_authorize, environment_params
|
|
|
|
expect(response).to have_http_status(200)
|
|
expect(response.headers["Content-Type"]).to eq(Gitlab::Workhorse::INTERNAL_API_CONTENT_TYPE)
|
|
expect(response.body).to eq('{"workhorse":"response"}')
|
|
end
|
|
end
|
|
|
|
context 'and invalid id' do
|
|
it 'returns 404' do
|
|
get :terminal_websocket_authorize, environment_params(id: 666)
|
|
|
|
expect(response).to have_http_status(404)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with invalid workhorse signature' do
|
|
it 'aborts with an exception' do
|
|
allow(Gitlab::Workhorse).to receive(:verify_api_request!).and_raise(JWT::DecodeError)
|
|
|
|
expect { get :terminal_websocket_authorize, environment_params }.to raise_error(JWT::DecodeError)
|
|
# controller tests don't set the response status correctly. It's enough
|
|
# to check that the action raised an exception
|
|
end
|
|
end
|
|
end
|
|
|
|
def environment_params(opts = {})
|
|
opts.reverse_merge(namespace_id: project.namespace,
|
|
project_id: project,
|
|
id: environment.id)
|
|
end
|
|
end
|