Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
gitlab-ce
Commits
46898c40
Commit
46898c40
authored
Nov 17, 2016
by
Regis
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
working on tests
parent
bd0e6936
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
151 additions
and
28 deletions
+151
-28
app/assets/javascripts/vue_pipelines_index/pipeline_actions.js.es6
...s/javascripts/vue_pipelines_index/pipeline_actions.js.es6
+1
-1
app/assets/javascripts/vue_pipelines_index/store.js.es6
app/assets/javascripts/vue_pipelines_index/store.js.es6
+3
-3
spec/features/projects/pipelines_spec.rb
spec/features/projects/pipelines_spec.rb
+147
-24
No files found.
app/assets/javascripts/vue_pipelines_index/pipeline_actions.js.es6
View file @
46898c40
...
@@ -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>
...
...
app/assets/javascripts/vue_pipelines_index/store.js.es6
View file @
46898c40
...
@@ -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 update
NumberOfPipeline
s = (total, running) => {
const update
PipelineNum
s = (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);
update
NumberOfPipeline
s(this.count.all, this.count.running_or_pending);
update
PipelineNum
s(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);
update
NumberOfPipeline
s(this.count.all, this.count.running_or_pending);
update
PipelineNum
s(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.'
...
...
spec/features/projects/pipelines_spec.rb
View file @
46898c40
...
@@ -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
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment