Commit 30b88c78 authored by Laura Montemayor's avatar Laura Montemayor Committed by lauraMon

Applies some feedback and adds docs

 * Updates description for some specs
 * Adds an expectation
 * Updates lint.md docs
parent 4308e5cc
...@@ -36,7 +36,20 @@ Example responses: ...@@ -36,7 +36,20 @@ Example responses:
```json ```json
{ {
"status": "valid", "status": "valid",
"errors": [] "errors": [],
"warnings": []
}
```
- Valid content with warnings:
```json
{
"status": "valid",
"errors": [],
"warnings": ["jobs:job may allow multiple pipelines to run for a single action due to
`rules:when` clause with no `workflow:rules` - read more:
https://docs.gitlab.com/ee/ci/troubleshooting.html#pipeline-warnings"]
} }
``` ```
...@@ -47,7 +60,8 @@ Example responses: ...@@ -47,7 +60,8 @@ Example responses:
"status": "invalid", "status": "invalid",
"errors": [ "errors": [
"variables config should be a hash of key value pairs" "variables config should be a hash of key value pairs"
] ],
"warnings": []
} }
``` ```
......
...@@ -9,7 +9,7 @@ RSpec.describe API::Lint do ...@@ -9,7 +9,7 @@ RSpec.describe API::Lint do
File.read(Rails.root.join('spec/support/gitlab_stubs/gitlab_ci.yml')) File.read(Rails.root.join('spec/support/gitlab_stubs/gitlab_ci.yml'))
end end
it 'passes validation without warnings' do it 'passes validation without warnings or errors' do
post api('/ci/lint'), params: { content: yaml_content } post api('/ci/lint'), params: { content: yaml_content }
expect(response).to have_gitlab_http_status(:ok) expect(response).to have_gitlab_http_status(:ok)
...@@ -30,10 +30,11 @@ RSpec.describe API::Lint do ...@@ -30,10 +30,11 @@ RSpec.describe API::Lint do
context 'with valid .gitlab-ci.yaml with warnings' do context 'with valid .gitlab-ci.yaml with warnings' do
let(:yaml_content) { { job: { script: 'ls', rules: [{ when: 'always' }] } }.to_yaml } let(:yaml_content) { { job: { script: 'ls', rules: [{ when: 'always' }] } }.to_yaml }
it 'passes validation but raises a warning' do it 'passes validation but returns warnings' do
post api('/ci/lint'), params: { content: yaml_content } post api('/ci/lint'), params: { content: yaml_content }
expect(response).to have_gitlab_http_status(:ok) expect(response).to have_gitlab_http_status(:ok)
expect(json_response['status']).to eq('valid')
expect(json_response['warnings']).not_to be_empty expect(json_response['warnings']).not_to be_empty
expect(json_response['status']).to eq('valid') expect(json_response['status']).to eq('valid')
expect(json_response['errors']).to eq([]) expect(json_response['errors']).to eq([])
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment