diff options
| author | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2015-10-06 17:31:54 +0000 | 
|---|---|---|
| committer | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2015-10-06 17:31:54 +0000 | 
| commit | ad627e40dcb00b54761a60078448286667a179fd (patch) | |
| tree | 7d20d0af596b89a6e9ba02272b0532fff426357b | |
| parent | fcc39d551977888fef161492cd47b502ed4c325b (diff) | |
| parent | f509e3afeb47158558e417d700bfc42db5ddd3f5 (diff) | |
| download | gitlab-ce-ad627e40dcb00b54761a60078448286667a179fd.tar.gz | |
Merge branch 'ci-commit-page' into 'master'
Render CI statuses on commit page
This MR merges CI commit page into CE commit page.
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
See merge request !1519
| -rw-r--r-- | app/assets/stylesheets/pages/commit.scss | 13 | ||||
| -rw-r--r-- | app/controllers/projects/commit_controller.rb | 7 | ||||
| -rw-r--r-- | app/helpers/ci_status_helper.rb | 3 | ||||
| -rw-r--r-- | app/views/projects/commit/_ci_menu.html.haml | 7 | ||||
| -rw-r--r-- | app/views/projects/commit/ci.html.haml | 62 | ||||
| -rw-r--r-- | app/views/projects/commit/show.html.haml | 1 | ||||
| -rw-r--r-- | config/routes.rb | 5 | ||||
| -rw-r--r-- | features/project/commits/commits.feature | 2 | ||||
| -rw-r--r-- | features/steps/project/commits/commits.rb | 14 | 
9 files changed, 110 insertions, 4 deletions
| diff --git a/app/assets/stylesheets/pages/commit.scss b/app/assets/stylesheets/pages/commit.scss index 741ff9051a2..fbd7c363de1 100644 --- a/app/assets/stylesheets/pages/commit.scss +++ b/app/assets/stylesheets/pages/commit.scss @@ -107,3 +107,16 @@      z-index: 2;    }  } + +.commit-ci-menu { +  padding: 0; +  margin: 0; +  list-style: none; +  margin-top: 5px; +  height: 56px; +  margin: -16px; +  padding: 16px; +  text-align: center; +  margin-top: 0px; +  margin-bottom: 2px; +} diff --git a/app/controllers/projects/commit_controller.rb b/app/controllers/projects/commit_controller.rb index 2fae5057138..1938c63c10c 100644 --- a/app/controllers/projects/commit_controller.rb +++ b/app/controllers/projects/commit_controller.rb @@ -31,6 +31,13 @@ class Projects::CommitController < Projects::ApplicationController      end    end +  def ci +    @ci_commit = @project.ci_commit(@commit.sha) +    @builds = @ci_commit.builds if @ci_commit +    @notes_count = @commit.notes.count +    @ci_project = @project.gitlab_ci_project +  end +    def branches      @branches = @project.repository.branch_names_contains(commit.id)      @tags = @project.repository.tag_names_contains(commit.id) diff --git a/app/helpers/ci_status_helper.rb b/app/helpers/ci_status_helper.rb index 794bdc2530e..dbd1e26fa79 100644 --- a/app/helpers/ci_status_helper.rb +++ b/app/helpers/ci_status_helper.rb @@ -1,6 +1,7 @@  module CiStatusHelper    def ci_status_path(ci_commit) -    ci_project_commits_path(ci_commit.project, ci_commit) +    project = ci_commit.gl_project +    ci_namespace_project_commit_path(project.namespace, project, ci_commit.sha)    end    def ci_status_icon(ci_commit) diff --git a/app/views/projects/commit/_ci_menu.html.haml b/app/views/projects/commit/_ci_menu.html.haml new file mode 100644 index 00000000000..a634ae5dfda --- /dev/null +++ b/app/views/projects/commit/_ci_menu.html.haml @@ -0,0 +1,7 @@ +%ul.center-top-menu.commit-ci-menu +  = nav_link(path: 'commit#show') do +    = link_to namespace_project_commit_path(@project.namespace, @project, @commit.id) do +      Changes +  = nav_link(path: 'commit#ci') do +    = link_to ci_namespace_project_commit_path(@project.namespace, @project, @commit.id) do +      Builds diff --git a/app/views/projects/commit/ci.html.haml b/app/views/projects/commit/ci.html.haml new file mode 100644 index 00000000000..bbb41a80268 --- /dev/null +++ b/app/views/projects/commit/ci.html.haml @@ -0,0 +1,62 @@ +- page_title "#{@commit.title} (#{@commit.short_id})", "Commits" += render "projects/commits/header_title" += render "commit_box" += render "ci_menu" + +- if @ci_project && current_user && can?(current_user, :manage_builds, @project) +  .pull-right +    - if @ci_commit.builds.running_or_pending.any? +      = link_to "Cancel", cancel_ci_project_commits_path(@ci_project, @ci_commit), class: 'btn btn-sm btn-danger' + + +- if @ci_commit.yaml_errors.present? +  .bs-callout.bs-callout-danger +    %h4 Found errors in your .gitlab-ci.yml: +    %ul +      - @ci_commit.yaml_errors.split(",").each do |error| +        %li= error + +- unless @ci_commit.ci_yaml_file +  .bs-callout.bs-callout-warning +    \.gitlab-ci.yml not found in this commit + +- @ci_commit.refs.each do |ref| +  .gray-content-block.second-block +    Builds for #{ref} +    - if @ci_commit.duration_for_ref(ref) > 0 +      %small.pull-right +        %i.fa.fa-time +        #{time_interval_in_words @ci_commit.duration_for_ref(ref)} + +  %table.table.builds +    %thead +      %tr +        %th Status +        %th Build ID +        %th Stage +        %th Name +        %th Duration +        %th Finished at +        - if @ci_project && @ci_project.coverage_enabled? +          %th Coverage +        %th +    = render partial: "ci/builds/build", collection: @ci_commit.builds_without_retry.for_ref(ref), controls: true + +- if @ci_commit.retried_builds.any? +  %h3 +    Retried builds + +  %table.table.builds +    %thead +      %tr +        %th Status +        %th Build ID +        %th Ref +        %th Stage +        %th Name +        %th Duration +        %th Finished at +        - if @ci_project && @ci_project.coverage_enabled? +          %th Coverage +        %th +    = render partial: "ci/builds/build", collection: @ci_commit.retried_builds, ref: true diff --git a/app/views/projects/commit/show.html.haml b/app/views/projects/commit/show.html.haml index f8681024d1b..30a3973828f 100644 --- a/app/views/projects/commit/show.html.haml +++ b/app/views/projects/commit/show.html.haml @@ -1,5 +1,6 @@  - page_title "#{@commit.title} (#{@commit.short_id})", "Commits"  = render "projects/commits/header_title"  = render "commit_box" += render "ci_menu" if @ci_commit  = render "projects/diffs/diffs", diffs: @diffs, project: @project  = render "projects/notes/notes_with_form", view: params[:view] diff --git a/config/routes.rb b/config/routes.rb index a21889631ed..beebb3258d1 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -485,7 +485,10 @@ Gitlab::Application.routes.draw do          resource  :avatar, only: [:show, :destroy]          resources :commit, only: [:show], constraints: { id: /[[:alnum:]]{6,40}/ } do -          get :branches, on: :member +          member do +            get :branches +            get :ci +          end          end          resources :compare, only: [:index, :create] diff --git a/features/project/commits/commits.feature b/features/project/commits/commits.feature index 34161b81d44..e4beeb59adc 100644 --- a/features/project/commits/commits.feature +++ b/features/project/commits/commits.feature @@ -20,6 +20,8 @@ Feature: Project Commits      Given commit has ci status      And I click on commit link      Then I see commit ci info +    And I click status link +    Then I see builds list    Scenario: I browse commit with side-by-side diff view      Given I click on commit link diff --git a/features/steps/project/commits/commits.rb b/features/steps/project/commits/commits.rb index 5ebc3a49760..ae5f90004e6 100644 --- a/features/steps/project/commits/commits.rb +++ b/features/steps/project/commits/commits.rb @@ -104,10 +104,20 @@ class Spinach::Features::ProjectCommits < Spinach::FeatureSteps    step 'commit has ci status' do      @project.enable_ci -    create :ci_commit, gl_project: @project, sha: sample_commit.id +    ci_commit = create :ci_commit, gl_project: @project, sha: sample_commit.id +    create :ci_build, commit: ci_commit    end    step 'I see commit ci info' do -    expect(page).to have_content "build: skipped" +    expect(page).to have_content "build: pending" +  end + +  step 'I click status link' do +    click_link "Builds" +  end + +  step 'I see builds list' do +    expect(page).to have_content "build: pending" +    expect(page).to have_content "Builds for master"    end  end | 
