Commit 46898c40 authored by Regis's avatar Regis

working on tests

parent bd0e6936
...@@ -47,7 +47,7 @@ ...@@ -47,7 +47,7 @@
> >
</path> </path>
</svg> </svg>
<span>{{action.name}}</span> <span title="Manual build">{{action.name}}</span>
</a> </a>
</li> </li>
</ul> </ul>
......
...@@ -35,7 +35,7 @@ ...@@ -35,7 +35,7 @@
gl.PipelineStore = class { gl.PipelineStore = class {
fetchDataLoop(Vue, pageNum, url) { fetchDataLoop(Vue, pageNum, url) {
Vue.activeResources = 0; Vue.activeResources = 0;
const updateNumberOfPipelines = (total, running) => { const updatePipelineNums = (total, running) => {
document.querySelector('.js-totalbuilds-count').innerHTML = total; document.querySelector('.js-totalbuilds-count').innerHTML = total;
document.querySelector('.js-running-count').innerHTML = running; document.querySelector('.js-running-count').innerHTML = running;
}; };
...@@ -55,7 +55,7 @@ ...@@ -55,7 +55,7 @@
Vue.set(this, 'updatedAt', res.updated_at); Vue.set(this, 'updatedAt', res.updated_at);
Vue.set(this, 'pipelines', res.pipelines); Vue.set(this, 'pipelines', res.pipelines);
Vue.set(this, 'count', res.count); Vue.set(this, 'count', res.count);
updateNumberOfPipelines(this.count.all, this.count.running_or_pending); updatePipelineNums(this.count.all, this.count.running_or_pending);
this.pageRequest = false; this.pageRequest = false;
Vue.activeResources -= 1; Vue.activeResources -= 1;
}, () => new Flash( }, () => new Flash(
...@@ -70,7 +70,7 @@ ...@@ -70,7 +70,7 @@
Vue.set(this, 'updatedAt', res.updated_at); Vue.set(this, 'updatedAt', res.updated_at);
Vue.set(this, 'pipelines', p.updatePipelines(res)); Vue.set(this, 'pipelines', p.updatePipelines(res));
Vue.set(this, 'count', res.count); Vue.set(this, 'count', res.count);
updateNumberOfPipelines(this.count.all, this.count.running_or_pending); updatePipelineNums(this.count.all, this.count.running_or_pending);
Vue.activeResources -= 1; Vue.activeResources -= 1;
}, () => new Flash( }, () => new Flash(
'Something went wrong on our end.' 'Something went wrong on our end.'
......
...@@ -16,13 +16,25 @@ describe "Pipelines", feature: true, js: true do ...@@ -16,13 +16,25 @@ describe "Pipelines", feature: true, js: true do
describe 'GET /:project/pipelines', feature: true, js: true do describe 'GET /:project/pipelines', feature: true, js: true do
include WaitForVueResource include WaitForVueResource
let!(:pipeline) { create(:ci_empty_pipeline, project: project, ref: 'master', status: 'running') } let!(:pipeline) do
create(
:ci_empty_pipeline,
project: project,
ref: 'master',
status: 'running'
)
end
[:pipelines].each do |scope| [:pipelines].each do |scope|
context "displaying #{scope}" do context "displaying #{scope}" do
let(:project) { create(:project) } let(:project) { create(:project) }
before { visit namespace_project_pipelines_path(project.namespace, project, scope: scope) } before do
visit namespace_project_pipelines_path(
project.namespace, project,
scope: scope
)
end
it do it do
wait_for_vue_resource wait_for_vue_resource
...@@ -35,20 +47,29 @@ describe "Pipelines", feature: true, js: true do ...@@ -35,20 +47,29 @@ describe "Pipelines", feature: true, js: true do
context "displaying #{scope}" do context "displaying #{scope}" do
let(:project) { create(:project) } let(:project) { create(:project) }
before { visit namespace_project_pipelines_path(project.namespace, project, scope: scope) } before do
visit namespace_project_pipelines_path(
project.namespace,
project, scope: scope
)
end
it { expect(page).to have_content(pipeline.short_sha) } it { expect(page).to have_content(pipeline.short_sha) }
end end
end end
context 'anonymous access' do context 'anonymous access' do
before { visit namespace_project_pipelines_path(project.namespace, project) } before do
visit namespace_project_pipelines_path(project.namespace, project)
end
it { expect(page).to have_http_status(:success) } it { expect(page).to have_http_status(:success) }
end end
context 'cancelable pipeline' do context 'cancelable pipeline' do
let!(:build) { create(:ci_build, pipeline: pipeline, stage: 'test', commands: 'test') } let!(:build) do
create(:ci_build, pipeline: pipeline, stage: 'test', commands: 'test')
end
before do before do
build.run build.run
...@@ -84,7 +105,9 @@ describe "Pipelines", feature: true, js: true do ...@@ -84,7 +105,9 @@ describe "Pipelines", feature: true, js: true do
end end
context 'retryable pipelines' do context 'retryable pipelines' do
let!(:build) { create(:ci_build, pipeline: pipeline, stage: 'test', commands: 'test') } let!(:build) do
create(:ci_build, pipeline: pipeline, stage: 'test', commands: 'test')
end
before do before do
build.drop build.drop
...@@ -103,9 +126,20 @@ describe "Pipelines", feature: true, js: true do ...@@ -103,9 +126,20 @@ describe "Pipelines", feature: true, js: true do
end end
context 'with manual actions' do context 'with manual actions' do
let!(:manual) { create(:ci_build, :manual, pipeline: pipeline, name: 'manual build', stage: 'test', commands: 'test') } let!(:manual) do
create(
:ci_build,
:manual,
pipeline: pipeline,
name: 'manual build',
stage: 'test',
commands: 'test'
)
end
before { visit namespace_project_pipelines_path(project.namespace, project) } before do
visit namespace_project_pipelines_path(project.namespace, project)
end
it do it do
wait_for_vue_resource wait_for_vue_resource
...@@ -127,7 +161,14 @@ describe "Pipelines", feature: true, js: true do ...@@ -127,7 +161,14 @@ describe "Pipelines", feature: true, js: true do
context 'for generic statuses' do context 'for generic statuses' do
context 'when running' do context 'when running' do
let!(:running) { create(:generic_commit_status, status: 'running', pipeline: pipeline, stage: 'test') } let!(:running) do
create(
:generic_commit_status,
status: 'running',
pipeline: pipeline,
stage: 'test'
)
end
before do before do
visit namespace_project_pipelines_path(project.namespace, project) visit namespace_project_pipelines_path(project.namespace, project)
...@@ -143,7 +184,14 @@ describe "Pipelines", feature: true, js: true do ...@@ -143,7 +184,14 @@ describe "Pipelines", feature: true, js: true do
end end
context 'when failed' do context 'when failed' do
let!(:status) { create(:generic_commit_status, :pending, pipeline: pipeline, stage: 'test') } let!(:status) do
create(
:generic_commit_status,
:pending,
pipeline: pipeline,
stage: 'test'
)
end
before do before do
status.drop status.drop
...@@ -162,9 +210,20 @@ describe "Pipelines", feature: true, js: true do ...@@ -162,9 +210,20 @@ describe "Pipelines", feature: true, js: true do
context 'downloadable pipelines' do context 'downloadable pipelines' do
context 'with artifacts' do context 'with artifacts' do
let!(:with_artifacts) { create(:ci_build, :artifacts, :success, pipeline: pipeline, name: 'rspec tests', stage: 'test') } let!(:with_artifacts) do
create(
:ci_build,
:artifacts,
:success,
pipeline: pipeline,
name: 'rspec tests',
stage: 'test'
)
end
before { visit namespace_project_pipelines_path(project.namespace, project) } before do
visit namespace_project_pipelines_path(project.namespace, project)
end
it do it do
wait_for_vue_resource wait_for_vue_resource
...@@ -178,17 +237,38 @@ describe "Pipelines", feature: true, js: true do ...@@ -178,17 +237,38 @@ describe "Pipelines", feature: true, js: true do
end end
context 'with artifacts expired' do context 'with artifacts expired' do
let!(:with_artifacts_expired) { create(:ci_build, :artifacts_expired, :success, pipeline: pipeline, name: 'rspec', stage: 'test') } let!(:with_artifacts_expired) do
create(
:ci_build,
:artifacts_expired,
:success,
pipeline: pipeline,
name: 'rspec',
stage: 'test'
)
end
before { visit namespace_project_pipelines_path(project.namespace, project) } before do
visit namespace_project_pipelines_path(project.namespace, project)
end
it { expect(page).not_to have_selector('.build-artifacts') } it { expect(page).not_to have_selector('.build-artifacts') }
end end
context 'without artifacts' do context 'without artifacts' do
let!(:without_artifacts) { create(:ci_build, :success, pipeline: pipeline, name: 'rspec', stage: 'test') } let!(:without_artifacts) do
create(
:ci_build,
:success,
pipeline: pipeline,
name: 'rspec',
stage: 'test'
)
end
before { visit namespace_project_pipelines_path(project.namespace, project) } before do
visit namespace_project_pipelines_path(project.namespace, project)
end
it { expect(page).not_to have_selector('.build-artifacts') } it { expect(page).not_to have_selector('.build-artifacts') }
end end
...@@ -199,14 +279,49 @@ describe "Pipelines", feature: true, js: true do ...@@ -199,14 +279,49 @@ describe "Pipelines", feature: true, js: true do
let(:pipeline) { create(:ci_pipeline, project: project, ref: 'master') } let(:pipeline) { create(:ci_pipeline, project: project, ref: 'master') }
before do before do
@success = create(:ci_build, :success, pipeline: pipeline, stage: 'build', name: 'build') @success = create(
@failed = create(:ci_build, :failed, pipeline: pipeline, stage: 'test', name: 'test', commands: 'test') :ci_build,
@running = create(:ci_build, :running, pipeline: pipeline, stage: 'deploy', name: 'deploy') :success,
@manual = create(:ci_build, :manual, pipeline: pipeline, stage: 'deploy', name: 'manual build') pipeline: pipeline,
@external = create(:generic_commit_status, status: 'success', pipeline: pipeline, name: 'jenkins', stage: 'external') stage: 'build',
name: 'build'
)
@failed = create(
:ci_build,
:failed,
pipeline: pipeline,
stage: 'test',
name: 'test',
commands: 'test'
)
@running = create(
:ci_build,
:running,
pipeline: pipeline,
stage: 'deploy',
name: 'deploy'
)
@manual = create(
:ci_build,
:manual,
pipeline: pipeline,
stage: 'deploy',
name: 'manual build'
)
@external = create(
:generic_commit_status,
status: 'success',
pipeline: pipeline,
name: 'jenkins',
stage: 'external'
)
end end
before { visit namespace_project_pipeline_path(project.namespace, project, pipeline) } before do
visit namespace_project_pipeline_path(
project.namespace, project, pipeline
)
end
it 'shows a list of builds' do it 'shows a list of builds' do
expect(page).to have_content('Test') expect(page).to have_content('Test')
...@@ -256,7 +371,9 @@ describe "Pipelines", feature: true, js: true do ...@@ -256,7 +371,9 @@ describe "Pipelines", feature: true, js: true do
describe 'POST /:project/pipelines', feature: true, js: true do describe 'POST /:project/pipelines', feature: true, js: true do
let(:project) { create(:project) } let(:project) { create(:project) }
before { visit new_namespace_project_pipeline_path(project.namespace, project) } before do
visit new_namespace_project_pipeline_path(project.namespace, project)
end
context 'for valid commit' do context 'for valid commit' do
before { fill_in('pipeline[ref]', with: 'master') } before { fill_in('pipeline[ref]', with: 'master') }
...@@ -264,7 +381,13 @@ describe "Pipelines", feature: true, js: true do ...@@ -264,7 +381,13 @@ describe "Pipelines", feature: true, js: true do
context 'with gitlab-ci.yml' do context 'with gitlab-ci.yml' do
before { stub_ci_pipeline_to_return_yaml_file } before { stub_ci_pipeline_to_return_yaml_file }
it { expect{ click_on 'Create pipeline' }.to change{ Ci::Pipeline.count }.by(1) } it do
expect{
click_on 'Create pipeline'
}.to change{
Ci::Pipeline.count
}.by(1)
end
end end
context 'without gitlab-ci.yml' do context 'without gitlab-ci.yml' do
......
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