Commit e7dd1958 authored by Tomislav Nikić's avatar Tomislav Nikić Committed by Sanad Liaquat

Create a basic test with commit reset

Reset all the commits into one collective commit that encompasses all
the work done.
parent 050a97e0
...@@ -155,7 +155,7 @@ export default { ...@@ -155,7 +155,7 @@ export default {
{{ cherryPickLabel }} {{ cherryPickLabel }}
</a> </a>
</div> </div>
<section class="mr-info-list"> <section class="mr-info-list" data-qa-selector="merged_status_content">
<p> <p>
{{ s__('mrWidget|The changes were merged into') }} {{ s__('mrWidget|The changes were merged into') }}
<span class="label-branch"> <span class="label-branch">
......
...@@ -249,9 +249,10 @@ export default { ...@@ -249,9 +249,10 @@ export default {
type="button" type="button"
class="btn btn-sm btn-info dropdown-toggle js-merge-moment" class="btn btn-sm btn-info dropdown-toggle js-merge-moment"
data-toggle="dropdown" data-toggle="dropdown"
data-qa-selector="merge_moment_dropdown"
:aria-label="__('Select merge moment')" :aria-label="__('Select merge moment')"
> >
<i class="fa fa-chevron-down qa-merge-moment-dropdown" aria-hidden="true"></i> <i class="fa fa-chevron-down" aria-hidden="true"></i>
</button> </button>
<ul <ul
v-if="shouldShowMergeImmediatelyDropdown" v-if="shouldShowMergeImmediatelyDropdown"
...@@ -272,7 +273,8 @@ export default { ...@@ -272,7 +273,8 @@ export default {
</li> </li>
<li> <li>
<a <a
class="accept-merge-request qa-merge-immediately-option" class="accept-merge-request"
data-qa-selector="merge_immediately_option"
href="#" href="#"
@click.prevent="handleMergeButtonClick(false, true)" @click.prevent="handleMergeButtonClick(false, true)"
> >
......
...@@ -44,7 +44,7 @@ ...@@ -44,7 +44,7 @@
- if group_sidebar_link?(:contribution_analytics) - if group_sidebar_link?(:contribution_analytics)
= nav_link(path: 'analytics#show') do = nav_link(path: 'analytics#show') do
= link_to group_analytics_path(@group), title: _('Contribution Analytics'), data: { placement: 'right' } do = link_to group_analytics_path(@group), title: _('Contribution Analytics'), data: { placement: 'right', qa_selector: 'contribution_analytics_link' } do
%span %span
= _('Contribution Analytics') = _('Contribution Analytics')
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
- if is_current_user - if is_current_user
- if can_update - if can_update
= link_to "Close #{display_issuable_type}", close_issuable_path(issuable), method: button_method, = link_to "Close #{display_issuable_type}", close_issuable_path(issuable), method: button_method,
class: "d-none d-sm-none d-md-block btn btn-grouped btn-close js-btn-issue-action #{issuable_button_visibility(issuable, true)}", title: "Close #{display_issuable_type}" class: "d-none d-sm-none d-md-block btn btn-grouped btn-close js-btn-issue-action #{issuable_button_visibility(issuable, true)}", title: "Close #{display_issuable_type}", data: { qa_selector: 'close_issue_button' }
- if can_reopen - if can_reopen
= link_to "Reopen #{display_issuable_type}", reopen_issuable_path(issuable), method: button_method, = link_to "Reopen #{display_issuable_type}", reopen_issuable_path(issuable), method: button_method,
class: "d-none d-sm-none d-md-block btn btn-grouped btn-reopen js-btn-issue-action #{issuable_button_visibility(issuable, false)}", title: "Reopen #{display_issuable_type}", data: { qa_selector: 'reopen_issue_button' } class: "d-none d-sm-none d-md-block btn btn-grouped btn-reopen js-btn-issue-action #{issuable_button_visibility(issuable, false)}", title: "Reopen #{display_issuable_type}", data: { qa_selector: 'reopen_issue_button' }
......
...@@ -20,40 +20,43 @@ ...@@ -20,40 +20,43 @@
.oneline .oneline
Contribution analytics for issues, merge requests and push events since #{@start_date} Contribution analytics for issues, merge requests and push events since #{@start_date}
%h3 Push %div{ data: { qa_selector: 'push_content' } }
- code_push_count = @data_collector.total_push_count %h3 Push
- commits_count = @data_collector.total_commit_count - code_push_count = @data_collector.total_push_count
- person_count = @data_collector.total_push_author_count - commits_count = @data_collector.total_commit_count
- person_count_string = pluralize person_count, 'person' - person_count = @data_collector.total_push_author_count
- pushes_string = _('<strong>%{pushes}</strong> pushes, more than <strong>%{commits}</strong> commits by <strong>%{people}</strong> contributors.').html_safe % { pushes: code_push_count, commits: commits_count , people: person_count_string } - person_count_string = pluralize person_count, 'person'
- if code_push_count > 0 || commits_count > 0 || person_count > 0 - pushes_string = _('<strong>%{pushes}</strong> pushes, more than <strong>%{commits}</strong> commits by <strong>%{people}</strong> contributors.').html_safe % { pushes: code_push_count, commits: commits_count , people: person_count_string }
= pushes_string - if code_push_count > 0 || commits_count > 0 || person_count > 0
- else = pushes_string
= _('No pushes for the selected time period.') - else
= _('No pushes for the selected time period.')
.row .row
.col-md-12 .col-md-12
#js_pushes_chart_vue #js_pushes_chart_vue
%h3 Merge Requests %div{ data: { qa_selector: 'merge_request_content' } }
- mr_created_count = @data_collector.total_merge_requests_created_count %h3 Merge Requests
- mr_merged_count = @data_collector.total_merge_requests_merged_count - mr_created_count = @data_collector.total_merge_requests_created_count
- if mr_created_count > 0 || mr_merged_count > 0 - mr_merged_count = @data_collector.total_merge_requests_merged_count
= _('<strong>%{created_count}</strong> created, <strong>%{accepted_count}</strong> accepted.').html_safe % { created_count: mr_created_count, accepted_count: mr_merged_count } - if mr_created_count > 0 || mr_merged_count > 0
- else = _('<strong>%{created_count}</strong> created, <strong>%{accepted_count}</strong> accepted.').html_safe % { created_count: mr_created_count, accepted_count: mr_merged_count }
= _('No merge requests for the selected time period.') - else
= _('No merge requests for the selected time period.')
.row .row
.col-md-12 .col-md-12
#js_merge_requests_chart_vue #js_merge_requests_chart_vue
%h3 Issues %div{ data: { qa_selector: 'issue_content' } }
- issues_created_count = @data_collector.total_issues_created_count %h3 Issues
- issues_closed_count = @data_collector.total_issues_closed_count - issues_created_count = @data_collector.total_issues_created_count
- if issues_created_count > 0 && issues_closed_count > 0 - issues_closed_count = @data_collector.total_issues_closed_count
= _('<strong>%{created_count}</strong> created, <strong>%{closed_count}</strong> closed.').html_safe % { created_count: issues_created_count, closed_count: issues_closed_count } - if issues_created_count > 0 && issues_closed_count > 0
- else = _('<strong>%{created_count}</strong> created, <strong>%{closed_count}</strong> closed.').html_safe % { created_count: issues_created_count, closed_count: issues_closed_count }
= _('No issues for the selected time period.') - else
= _('No issues for the selected time period.')
.row .row
.col-md-12 .col-md-12
......
...@@ -34,6 +34,7 @@ module QA ...@@ -34,6 +34,7 @@ module QA
autoload :SamlSSOSignIn, 'qa/ee/page/group/saml_sso_sign_in' autoload :SamlSSOSignIn, 'qa/ee/page/group/saml_sso_sign_in'
autoload :SamlSSOSignUp, 'qa/ee/page/group/saml_sso_sign_up' autoload :SamlSSOSignUp, 'qa/ee/page/group/saml_sso_sign_up'
autoload :Members, 'qa/ee/page/group/members' autoload :Members, 'qa/ee/page/group/members'
autoload :ContributionAnalytics, 'qa/ee/page/group/contribution_analytics'
module Settings module Settings
autoload :SamlSSO, 'qa/ee/page/group/settings/saml_sso' autoload :SamlSSO, 'qa/ee/page/group/settings/saml_sso'
......
# frozen_string_literal: true
module QA
module EE
module Page
module Group
class ContributionAnalytics < QA::Page::Base
view 'ee/app/views/groups/analytics/show.html.haml' do
element :push_content
element :merge_request_content
element :issue_content
end
def has_push_element?(text)
has_element? :push_content, text: text
end
def has_mr_element?(text)
has_element? :merge_request_content, text: text
end
def has_issue_element?(text)
has_element? :issue_content, text: text
end
end
end
end
end
end
...@@ -10,6 +10,7 @@ module QA ...@@ -10,6 +10,7 @@ module QA
element :group_settings_item element :group_settings_item
element :group_members_item element :group_members_item
element :general_settings_link element :general_settings_link
element :contribution_analytics_link
end end
def click_group_members_item def click_group_members_item
...@@ -18,6 +19,12 @@ module QA ...@@ -18,6 +19,12 @@ module QA
end end
end end
def click_group_analytics_item
within_sidebar do
click_element(:contribution_analytics_link)
end
end
def click_group_general_settings_item def click_group_general_settings_item
hover_element(:group_settings_item) do hover_element(:group_settings_item) do
within_submenu(:group_sidebar_submenu) do within_submenu(:group_sidebar_submenu) do
......
...@@ -26,7 +26,7 @@ module QA ...@@ -26,7 +26,7 @@ module QA
end end
view 'app/assets/javascripts/vue_merge_request_widget/components/states/mr_widget_merged.vue' do view 'app/assets/javascripts/vue_merge_request_widget/components/states/mr_widget_merged.vue' do
element :merged_status, 'The changes were merged into' # rubocop:disable QA/ElementWithPattern element :merged_status_content
end end
view 'app/assets/javascripts/vue_merge_request_widget/components/states/mr_widget_rebase.vue' do view 'app/assets/javascripts/vue_merge_request_widget/components/states/mr_widget_rebase.vue' do
...@@ -86,13 +86,31 @@ module QA ...@@ -86,13 +86,31 @@ module QA
has_element?(:merge_moment_dropdown) has_element?(:merge_moment_dropdown)
end end
def merged?
has_element? :merged_status_content, text: 'The changes were merged into'
end
def merge_immediately def merge_immediately
wait(reload: false, max: 60) do
has_merge_options?
end
if has_merge_options? if has_merge_options?
click_element :merge_moment_dropdown if has_no_element? :merge_immediately_option
retry_until do
click_element :merge_moment_dropdown
has_element? :merge_immediately_option
end
end
click_element :merge_immediately_option click_element :merge_immediately_option
else else
click_element :merge_button click_element :merge_button
end end
wait(reload: false, max: 60) do
merged?
end
end end
def rebase! def rebase!
......
...@@ -44,6 +44,7 @@ module QA ...@@ -44,6 +44,7 @@ module QA
end end
view 'app/views/shared/issuable/_close_reopen_button.html.haml' do view 'app/views/shared/issuable/_close_reopen_button.html.haml' do
element :close_issue_button
element :reopen_issue_button element :reopen_issue_button
end end
...@@ -84,6 +85,10 @@ module QA ...@@ -84,6 +85,10 @@ module QA
click_element(:remove_related_issue_button) click_element(:remove_related_issue_button)
end end
def click_close_issue_button
click_element :close_issue_button
end
# Adds a comment to an issue # Adds a comment to an issue
# attachment option should be an absolute path # attachment option should be an absolute path
def comment(text, attachment: nil, filter: :all_activities) def comment(text, attachment: nil, filter: :all_activities)
......
# frozen_string_literal: true
module QA
context 'Create' do
describe 'Contribution Analytics' do
let(:group) do
Resource::Group.fabricate_via_api! do |group|
group.path = "contribution_analytics-#{SecureRandom.hex(8)}"
end
end
let(:project) do
Resource::Project.fabricate_via_api! do |project|
project.name = 'contribution_analytics'
project.group = group
end
end
let(:issue) do
Resource::Issue.fabricate_via_api! do |issue|
issue.project = project
end
end
let(:mr) do
Resource::MergeRequest.fabricate_via_api! do |mr|
mr.project = project
end
end
before do
Flow::Login.sign_in
issue.visit!
Page::Project::Issue::Show.perform(&:click_close_issue_button)
mr.visit!
Page::MergeRequest::Show.perform(&:merge_immediately)
group.visit!
Page::Group::Menu.perform(&:click_group_analytics_item)
end
it 'tests contributions' do
EE::Page::Group::ContributionAnalytics.perform do |contribution_analytics|
expect(contribution_analytics).to have_push_element('3 pushes, more than 4.0 commits by 1 person contributors.')
expect(contribution_analytics).to have_mr_element('1 created, 1 accepted.')
expect(contribution_analytics).to have_issue_element('1 created, 1 closed.')
end
end
end
end
end
...@@ -75,9 +75,7 @@ module QA ...@@ -75,9 +75,7 @@ module QA
show.merge_immediately show.merge_immediately
end end
merged = Support::Retrier.retry_until(reload_page: page) do merged = Page::MergeRequest::Show.perform(&:merged?)
page.has_content?('The changes were merged')
end
expect(merged).to be_truthy, "Expected content 'The changes were merged' but it did not appear." expect(merged).to be_truthy, "Expected content 'The changes were merged' but it did not appear."
end end
...@@ -116,7 +114,7 @@ module QA ...@@ -116,7 +114,7 @@ module QA
# automatically refresh, so we reload if the merge status # automatically refresh, so we reload if the merge status
# doesn't update quickly. # doesn't update quickly.
merged = Support::Retrier.retry_until(reload_page: page) do merged = Support::Retrier.retry_until(reload_page: page) do
page.has_content?('The changes were merged') Page::MergeRequest::Show.perform(&:merged?)
end end
expect(merged).to be_truthy, "Expected content 'The changes were merged' but it did not appear." expect(merged).to be_truthy, "Expected content 'The changes were merged' but it did not appear."
......
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