From ca1f5ede8456b0c433699fc73931ad39b5571f97 Mon Sep 17 00:00:00 2001 From: Katarzyna Kobierska Date: Wed, 24 Aug 2016 11:42:48 +0200 Subject: Move lint to api from ci/api --- spec/requests/api/lint_spec.rb | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 spec/requests/api/lint_spec.rb (limited to 'spec/requests/api/lint_spec.rb') diff --git a/spec/requests/api/lint_spec.rb b/spec/requests/api/lint_spec.rb new file mode 100644 index 00000000000..9de9c90a4aa --- /dev/null +++ b/spec/requests/api/lint_spec.rb @@ -0,0 +1,41 @@ +require 'spec_helper' + +describe API::API do + include ApiHelpers + + let(:user) { create(:user) } + let(:yaml_content) do + File.read(Rails.root.join('spec/support/gitlab_stubs/gitlab_ci.yml')) + end + + describe 'POST /lint' do + context 'with valid .gitlab-ci.yaml content' do + context 'authorized user' do + it 'validate content' do + post api('/lint'), { content: yaml_content } + + expect(response).to have_http_status(200) + expect(json_response).to be_an Hash + expect(json_response['status']).to eq('valid') + end + end + end + + context 'with invalid .gitlab_ci.yml content' do + it 'validate content' do + post api('/lint'), { content: 'invalid content' } + + expect(response).to have_http_status(200) + expect(json_response['status']).to eq('invalid') + end + end + + context 'no content parameters' do + it 'shows error message' do + post api('/lint') + + expect(response).to have_http_status(400) + end + end + end +end -- cgit v1.2.3