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
1
Merge Requests
1
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
nexedi
gitlab-ce
Commits
5e79276b
Commit
5e79276b
authored
May 23, 2018
by
Phil Hughes
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
improve API calls by calling internal API to get data
render job items (needs improvements to components)
parent
cfe4d2f2
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
137 additions
and
56 deletions
+137
-56
app/assets/javascripts/api.js
app/assets/javascripts/api.js
+3
-3
app/assets/javascripts/ide/components/pipelines/jobs.vue
app/assets/javascripts/ide/components/pipelines/jobs.vue
+44
-6
app/assets/javascripts/ide/stores/modules/pipelines/actions.js
...ssets/javascripts/ide/stores/modules/pipelines/actions.js
+29
-17
app/assets/javascripts/ide/stores/modules/pipelines/getters.js
...ssets/javascripts/ide/stores/modules/pipelines/getters.js
+3
-3
app/assets/javascripts/ide/stores/modules/pipelines/mutation_types.js
...avascripts/ide/stores/modules/pipelines/mutation_types.js
+4
-0
app/assets/javascripts/ide/stores/modules/pipelines/mutations.js
...ets/javascripts/ide/stores/modules/pipelines/mutations.js
+41
-26
app/assets/javascripts/vue_shared/components/tabs/tab.vue
app/assets/javascripts/vue_shared/components/tabs/tab.vue
+3
-0
app/controllers/projects/pipelines_controller.rb
app/controllers/projects/pipelines_controller.rb
+10
-1
No files found.
app/assets/javascripts/api.js
View file @
5e79276b
...
@@ -24,7 +24,7 @@ const Api = {
...
@@ -24,7 +24,7 @@ const Api = {
branchSinglePath
:
'
/api/:version/projects/:id/repository/branches/:branch
'
,
branchSinglePath
:
'
/api/:version/projects/:id/repository/branches/:branch
'
,
createBranchPath
:
'
/api/:version/projects/:id/repository/branches
'
,
createBranchPath
:
'
/api/:version/projects/:id/repository/branches
'
,
pipelinesPath
:
'
/api/:version/projects/:id/pipelines
'
,
pipelinesPath
:
'
/api/:version/projects/:id/pipelines
'
,
pipelineJobsPath
:
'
/
api/:version/projects/:id/pipelines/:pipeline_id/jobs
'
,
pipelineJobsPath
:
'
/
:project_path/pipelines/:id/builds.json
'
,
group
(
groupId
,
callback
)
{
group
(
groupId
,
callback
)
{
const
url
=
Api
.
buildUrl
(
Api
.
groupPath
).
replace
(
'
:id
'
,
groupId
);
const
url
=
Api
.
buildUrl
(
Api
.
groupPath
).
replace
(
'
:id
'
,
groupId
);
...
@@ -232,8 +232,8 @@ const Api = {
...
@@ -232,8 +232,8 @@ const Api = {
pipelineJobs
(
projectPath
,
pipelineId
,
params
=
{})
{
pipelineJobs
(
projectPath
,
pipelineId
,
params
=
{})
{
const
url
=
Api
.
buildUrl
(
this
.
pipelineJobsPath
)
const
url
=
Api
.
buildUrl
(
this
.
pipelineJobsPath
)
.
replace
(
'
:
id
'
,
encodeURIComponent
(
projectPath
)
)
.
replace
(
'
:
project_path
'
,
projectPath
)
.
replace
(
'
:
pipeline_
id
'
,
pipelineId
);
.
replace
(
'
:id
'
,
pipelineId
);
return
axios
.
get
(
url
,
{
params
});
return
axios
.
get
(
url
,
{
params
});
},
},
...
...
app/assets/javascripts/ide/components/pipelines/jobs.vue
View file @
5e79276b
<
script
>
<
script
>
import
{
mapActions
,
mapGetters
}
from
'
vuex
'
;
import
{
mapActions
,
mapGetters
,
mapState
}
from
'
vuex
'
;
import
Icon
from
'
../../../vue_shared/components/icon.vue
'
;
import
CiIcon
from
'
../../../vue_shared/components/ci_icon.vue
'
;
import
Tabs
from
'
../../../vue_shared/components/tabs/tabs
'
;
import
Tabs
from
'
../../../vue_shared/components/tabs/tabs
'
;
import
Tab
from
'
../../../vue_shared/components/tabs/tab.vue
'
;
import
Tab
from
'
../../../vue_shared/components/tabs/tab.vue
'
;
...
@@ -7,15 +9,18 @@ export default {
...
@@ -7,15 +9,18 @@ export default {
components
:
{
components
:
{
Tabs
,
Tabs
,
Tab
,
Tab
,
Icon
,
CiIcon
,
},
},
computed
:
{
computed
:
{
...
mapGetters
(
'
pipelines
'
,
[
'
jobsCount
'
,
'
failedJobs
'
]),
...
mapGetters
(
'
pipelines
'
,
[
'
jobsCount
'
,
'
failedJobsCount
'
]),
...
mapState
(
'
pipelines
'
,
[
'
stages
'
]),
},
},
mounted
()
{
mounted
()
{
this
.
fetch
Job
s
();
this
.
fetch
Stage
s
();
},
},
methods
:
{
methods
:
{
...
mapActions
(
'
pipelines
'
,
[
'
fetch
Job
s
'
]),
...
mapActions
(
'
pipelines
'
,
[
'
fetch
Stage
s
'
]),
},
},
};
};
</
script
>
</
script
>
...
@@ -27,11 +32,44 @@ export default {
...
@@ -27,11 +32,44 @@ export default {
<template
slot=
"title"
>
<template
slot=
"title"
>
Jobs
<span
class=
"badge"
>
{{
jobsCount
}}
</span>
Jobs
<span
class=
"badge"
>
{{
jobsCount
}}
</span>
</
template
>
</
template
>
List all jobs here
<div
style=
"overflow: auto;"
>
<div
v-for=
"stage in stages"
:key=
"stage.id"
class=
"panel panel-default"
>
<div
class=
"panel-heading"
@
click=
"() => stage.isCollapsed = !stage.isCollapsed"
>
<ci-icon
:status=
"stage.status"
/>
{{ stage.title }}
<span
class=
"badge"
>
{{ stage.jobs.length }}
</span>
<icon
:name=
"stage.isCollapsed ? 'angle-left' : 'angle-down'"
css-classes=
"pull-right"
/>
</div>
<div
class=
"panel-body"
v-show=
"!stage.isCollapsed"
>
<div
v-for=
"job in stage.jobs"
:key=
"job.id"
>
<ci-icon
:status=
"job.status"
/>
{{ job.name }} #{{ job.id }}
</div>
</div>
</div>
</div>
</tab>
</tab>
<tab>
<tab>
<
template
slot=
"title"
>
<
template
slot=
"title"
>
Failed Jobs
<span
class=
"badge"
>
{{
failedJobs
.
length
}}
</span>
Failed Jobs
<span
class=
"badge"
>
{{
failedJobs
Count
}}
</span>
</
template
>
</
template
>
List all failed jobs here
List all failed jobs here
</tab>
</tab>
...
...
app/assets/javascripts/ide/stores/modules/pipelines/actions.js
View file @
5e79276b
import
axios
from
'
axios
'
;
import
{
__
}
from
'
../../../../locale
'
;
import
{
__
}
from
'
../../../../locale
'
;
import
Api
from
'
../../../../api
'
;
import
Api
from
'
../../../../api
'
;
import
flash
from
'
../../../../flash
'
;
import
flash
from
'
../../../../flash
'
;
...
@@ -21,29 +22,40 @@ export const fetchLatestPipeline = ({ dispatch, rootState }, sha) => {
...
@@ -21,29 +22,40 @@ export const fetchLatestPipeline = ({ dispatch, rootState }, sha) => {
.
catch
(()
=>
dispatch
(
'
receiveLatestPipelineError
'
));
.
catch
(()
=>
dispatch
(
'
receiveLatestPipelineError
'
));
};
};
export
const
request
Jobs
=
({
commit
})
=>
commit
(
types
.
REQUEST_JOB
S
);
export
const
request
Stages
=
({
commit
})
=>
commit
(
types
.
REQUEST_STAGE
S
);
export
const
receive
Job
sError
=
({
commit
})
=>
{
export
const
receive
Stage
sError
=
({
commit
})
=>
{
flash
(
__
(
'
There was an error loading jobs
'
));
flash
(
__
(
'
There was an error loading job
stage
s
'
));
commit
(
types
.
RECEIVE_
JOB
S_ERROR
);
commit
(
types
.
RECEIVE_
STAGE
S_ERROR
);
};
};
export
const
receiveJobsSuccess
=
({
commit
},
data
)
=>
commit
(
types
.
RECEIVE_JOBS_SUCCESS
,
data
);
export
const
receiveStagesSuccess
=
({
commit
},
data
)
=>
commit
(
types
.
RECEIVE_STAGES_SUCCESS
,
data
);
export
const
fetch
Jobs
=
({
dispatch
,
state
,
rootState
},
page
=
'
1
'
)
=>
{
export
const
fetch
Stages
=
({
dispatch
,
state
,
rootState
}
)
=>
{
dispatch
(
'
request
Job
s
'
);
dispatch
(
'
request
Stage
s
'
);
Api
.
pipelineJobs
(
rootState
.
currentProjectId
,
state
.
latestPipeline
.
id
,
{
Api
.
pipelineJobs
(
rootState
.
currentProjectId
,
state
.
latestPipeline
.
id
)
page
,
.
then
(({
data
})
=>
dispatch
(
'
receiveStagesSuccess
'
,
data
))
}
)
.
then
(()
=>
state
.
stages
.
forEach
(
stage
=>
dispatch
(
'
fetchJobs
'
,
stage
))
)
.
then
(({
data
,
headers
})
=>
{
.
catch
(()
=>
dispatch
(
'
receiveStagesError
'
));
const
nextPage
=
headers
&&
headers
[
'
x-next-page
'
]
;
}
;
dispatch
(
'
receiveJobsSuccess
'
,
data
);
export
const
requestJobs
=
({
commit
},
id
)
=>
commit
(
types
.
REQUEST_JOBS
,
id
);
export
const
receiveJobsError
=
({
commit
},
id
)
=>
{
flash
(
__
(
'
There was an error loading jobs
'
));
commit
(
types
.
RECEIVE_JOBS_ERROR
,
id
);
};
export
const
receiveJobsSuccess
=
({
commit
},
{
id
,
data
})
=>
commit
(
types
.
RECEIVE_JOBS_SUCCESS
,
{
id
,
data
});
export
const
fetchJobs
=
({
dispatch
},
stage
)
=>
{
dispatch
(
'
requestJobs
'
,
stage
.
id
);
if
(
nextPage
)
{
axios
dispatch
(
'
fetchJobs
'
,
nextPage
);
.
get
(
stage
.
dropdown_path
)
}
.
then
(({
data
})
=>
{
dispatch
(
'
receiveJobsSuccess
'
,
{
id
:
stage
.
id
,
data
});
})
})
.
catch
(()
=>
dispatch
(
'
receiveJobsError
'
));
.
catch
(()
=>
dispatch
(
'
receiveJobsError
'
,
stage
.
id
));
};
};
export
default
()
=>
{};
export
default
()
=>
{};
app/assets/javascripts/ide/stores/modules/pipelines/getters.js
View file @
5e79276b
export
const
hasLatestPipeline
=
state
=>
!
state
.
isLoadingPipeline
&&
!!
state
.
latestPipeline
;
export
const
hasLatestPipeline
=
state
=>
!
state
.
isLoadingPipeline
&&
!!
state
.
latestPipeline
;
export
const
failedJobs
=
state
=>
export
const
failedJobs
Count
=
state
=>
state
.
stages
.
reduce
(
state
.
stages
.
reduce
(
(
acc
,
stage
)
=>
acc
.
concat
(
stage
.
jobs
.
filter
(
job
=>
job
.
status
===
'
failed
'
))
,
(
acc
,
stage
)
=>
acc
+
stage
.
jobs
.
filter
(
j
=>
j
.
status
.
label
===
'
failed
'
).
length
,
[]
,
0
,
);
);
export
const
jobsCount
=
state
=>
state
.
stages
.
reduce
((
acc
,
stage
)
=>
acc
+
stage
.
jobs
.
length
,
0
);
export
const
jobsCount
=
state
=>
state
.
stages
.
reduce
((
acc
,
stage
)
=>
acc
+
stage
.
jobs
.
length
,
0
);
app/assets/javascripts/ide/stores/modules/pipelines/mutation_types.js
View file @
5e79276b
...
@@ -2,6 +2,10 @@ export const REQUEST_LATEST_PIPELINE = 'REQUEST_LATEST_PIPELINE';
...
@@ -2,6 +2,10 @@ export const REQUEST_LATEST_PIPELINE = 'REQUEST_LATEST_PIPELINE';
export
const
RECEIVE_LASTEST_PIPELINE_ERROR
=
'
RECEIVE_LASTEST_PIPELINE_ERROR
'
;
export
const
RECEIVE_LASTEST_PIPELINE_ERROR
=
'
RECEIVE_LASTEST_PIPELINE_ERROR
'
;
export
const
RECEIVE_LASTEST_PIPELINE_SUCCESS
=
'
RECEIVE_LASTEST_PIPELINE_SUCCESS
'
;
export
const
RECEIVE_LASTEST_PIPELINE_SUCCESS
=
'
RECEIVE_LASTEST_PIPELINE_SUCCESS
'
;
export
const
REQUEST_STAGES
=
'
REQUEST_STAGES
'
;
export
const
RECEIVE_STAGES_ERROR
=
'
RECEIVE_STAGES_ERROR
'
;
export
const
RECEIVE_STAGES_SUCCESS
=
'
RECEIVE_STAGES_SUCCESS
'
;
export
const
REQUEST_JOBS
=
'
REQUEST_JOBS
'
;
export
const
REQUEST_JOBS
=
'
REQUEST_JOBS
'
;
export
const
RECEIVE_JOBS_ERROR
=
'
RECEIVE_JOBS_ERROR
'
;
export
const
RECEIVE_JOBS_ERROR
=
'
RECEIVE_JOBS_ERROR
'
;
export
const
RECEIVE_JOBS_SUCCESS
=
'
RECEIVE_JOBS_SUCCESS
'
;
export
const
RECEIVE_JOBS_SUCCESS
=
'
RECEIVE_JOBS_SUCCESS
'
;
app/assets/javascripts/ide/stores/modules/pipelines/mutations.js
View file @
5e79276b
...
@@ -18,37 +18,52 @@ export default {
...
@@ -18,37 +18,52 @@ export default {
};
};
}
}
},
},
[
types
.
REQUEST_
JOB
S
](
state
)
{
[
types
.
REQUEST_
STAGE
S
](
state
)
{
state
.
isLoadingJobs
=
true
;
state
.
isLoadingJobs
=
true
;
},
},
[
types
.
RECEIVE_
JOB
S_ERROR
](
state
)
{
[
types
.
RECEIVE_
STAGE
S_ERROR
](
state
)
{
state
.
isLoadingJobs
=
false
;
state
.
isLoadingJobs
=
false
;
},
},
[
types
.
RECEIVE_
JOBS_SUCCESS
](
state
,
job
s
)
{
[
types
.
RECEIVE_
STAGES_SUCCESS
](
state
,
stage
s
)
{
state
.
isLoadingJobs
=
false
;
state
.
isLoadingJobs
=
false
;
state
.
stages
=
jobs
.
reduce
((
acc
,
job
)
=>
{
state
.
stages
=
stages
.
map
((
stage
,
i
)
=>
({
let
stage
=
acc
.
find
(
s
=>
s
.
title
===
job
.
stage
);
...
stage
,
id
:
i
,
if
(
!
stage
)
{
stage
=
{
title
:
job
.
stage
,
isCollapsed
:
false
,
isCollapsed
:
false
,
isLoading
:
false
,
jobs
:
[],
jobs
:
[],
};
}));
},
acc
.
push
(
stage
);
[
types
.
REQUEST_JOBS
](
state
,
id
)
{
}
state
.
stages
=
state
.
stages
.
reduce
(
(
acc
,
stage
)
=>
stage
.
jobs
=
stage
.
jobs
.
concat
({
acc
.
concat
({
id
:
job
.
id
,
...
stage
,
name
:
job
.
name
,
isLoading
:
id
===
stage
.
id
?
true
:
stage
.
isLoading
,
status
:
job
.
status
,
}),
stage
:
job
.
stage
,
[],
duration
:
job
.
duration
,
);
});
},
[
types
.
RECEIVE_JOBS_ERROR
](
state
,
id
)
{
return
acc
;
state
.
stages
=
state
.
stages
.
reduce
(
},
state
.
stages
);
(
acc
,
stage
)
=>
acc
.
concat
({
...
stage
,
isLoading
:
id
===
stage
.
id
?
false
:
stage
.
isLoading
,
}),
[],
);
},
[
types
.
RECEIVE_JOBS_SUCCESS
](
state
,
{
id
,
data
})
{
state
.
stages
=
state
.
stages
.
reduce
(
(
acc
,
stage
)
=>
acc
.
concat
({
...
stage
,
isLoading
:
id
===
stage
.
id
?
false
:
stage
.
isLoading
,
jobs
:
id
===
stage
.
id
?
data
.
latest_statuses
:
stage
.
jobs
,
}),
[],
);
},
},
};
};
app/assets/javascripts/vue_shared/components/tabs/tab.vue
View file @
5e79276b
...
@@ -26,6 +26,9 @@ export default {
...
@@ -26,6 +26,9 @@ export default {
created
()
{
created
()
{
this
.
isTab
=
true
;
this
.
isTab
=
true
;
},
},
updated
()
{
this
.
$parent
.
$forceUpdate
();
},
};
};
</
script
>
</
script
>
...
...
app/controllers/projects/pipelines_controller.rb
View file @
5e79276b
...
@@ -76,8 +76,17 @@ class Projects::PipelinesController < Projects::ApplicationController
...
@@ -76,8 +76,17 @@ class Projects::PipelinesController < Projects::ApplicationController
end
end
def
builds
def
builds
respond_to
do
|
format
|
format
.
html
do
render_show
render_show
end
end
format
.
json
do
render
json:
PipelineSerializer
.
new
(
project:
@project
,
current_user:
@current_user
)
.
represent_stages
(
@pipeline
)
end
end
end
def
failures
def
failures
if
@pipeline
.
failed_builds
.
present?
if
@pipeline
.
failed_builds
.
present?
...
...
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