Commit 0b68db84 authored by Grzegorz Bizon's avatar Grzegorz Bizon

Merge branch 'epics-e2e-tests' into 'master'

Epics e2e tests Automation

Closes #7486 and #7470

See merge request gitlab-org/gitlab-ee!7381
parents c2584ae4 d4c04d8e
...@@ -380,7 +380,7 @@ js-gfm-input js-autosize markdown-area js-vue-textarea qa-comment-input" ...@@ -380,7 +380,7 @@ js-gfm-input js-autosize markdown-area js-vue-textarea qa-comment-input"
append-right-10 comment-type-dropdown js-comment-type-dropdown droplab-dropdown"> append-right-10 comment-type-dropdown js-comment-type-dropdown droplab-dropdown">
<button <button
:disabled="isSubmitButtonDisabled" :disabled="isSubmitButtonDisabled"
class="btn btn-create comment-btn js-comment-button js-comment-submit-button class="btn btn-success comment-btn js-comment-button js-comment-submit-button
qa-comment-button" qa-comment-button"
type="submit" type="submit"
@click.prevent="handleSave()"> @click.prevent="handleSave()">
......
...@@ -54,7 +54,7 @@ ...@@ -54,7 +54,7 @@
return this.isEpicOpen ? __('Open') : __('Closed'); return this.isEpicOpen ? __('Open') : __('Closed');
}, },
actionButtonClass() { actionButtonClass() {
return `btn btn-grouped js-btn-epic-action ${this.isEpicOpen ? 'btn-close' : 'btn-open'}`; return `btn btn-grouped js-btn-epic-action qa-close-reopen-epic-button ${this.isEpicOpen ? 'btn-close' : 'btn-open'}`;
}, },
actionButtonText() { actionButtonText() {
return this.isEpicOpen ? __('Close epic') : __('Reopen epic'); return this.isEpicOpen ? __('Close epic') : __('Reopen epic');
......
...@@ -61,7 +61,7 @@ ...@@ -61,7 +61,7 @@
<template> <template>
<div class="dropdown new-epic-dropdown"> <div class="dropdown new-epic-dropdown">
<button <button
class="btn btn-success" class="btn btn-success qa-new-epic-button"
type="button" type="button"
data-toggle="dropdown" data-toggle="dropdown"
@click="focusInput" @click="focusInput"
...@@ -77,13 +77,13 @@ ...@@ -77,13 +77,13 @@
v-model="title" v-model="title"
:placeholder="s__('Title')" :placeholder="s__('Title')"
type="text" type="text"
class="form-control" class="form-control qa-epic-title"
/> />
<loading-button <loading-button
:disabled="isCreatingDisabled" :disabled="isCreatingDisabled"
:loading="creating" :loading="creating"
:label="buttonLabel" :label="buttonLabel"
container-class="btn btn-success btn-inverted prepend-top-10" container-class="btn btn-success btn-inverted prepend-top-10 qa-create-epic-button"
@click.stop="createEpic" @click.stop="createEpic"
/> />
</div> </div>
......
...@@ -140,7 +140,7 @@ export default { ...@@ -140,7 +140,7 @@ export default {
:value="inputValue" :value="inputValue"
:placeholder="inputPlaceholder" :placeholder="inputPlaceholder"
type="text" type="text"
class="js-add-issuable-form-input add-issuable-form-input" class="js-add-issuable-form-input add-issuable-form-input qa-add-issue-input"
@input="onInput" @input="onInput"
@focus="onFocus" @focus="onFocus"
@blur="onBlur" /> @blur="onBlur" />
...@@ -152,7 +152,7 @@ export default { ...@@ -152,7 +152,7 @@ export default {
ref="addButton" ref="addButton"
:disabled="isSubmitButtonDisabled" :disabled="isSubmitButtonDisabled"
type="submit" type="submit"
class="js-add-issuable-form-add-button btn btn-success float-left"> class="js-add-issuable-form-add-button btn btn-success float-left qa-add-issue-button">
Add Add
<gl-loading-icon <gl-loading-icon
v-if="isSubmitting" v-if="isSubmitting"
......
...@@ -54,7 +54,8 @@ export default { ...@@ -54,7 +54,8 @@ export default {
v-tooltip v-tooltip
:disabled="removeDisabled" :disabled="removeDisabled"
type="button" type="button"
class="btn btn-default js-issue-item-remove-button flex-align-self-center flex-right" class="btn btn-default js-issue-item-remove-button flex-align-self-center flex-right
qa-remove-issue-button"
title="Remove" title="Remove"
aria-label="Remove" aria-label="Remove"
@click="onRemoveRequest" @click="onRemoveRequest"
......
...@@ -179,7 +179,7 @@ fa fa-question-circle" ...@@ -179,7 +179,7 @@ fa fa-question-circle"
ref="issueCountBadgeAddButton" ref="issueCountBadgeAddButton"
type="button" type="button"
class="js-issue-count-badge-add-button class="js-issue-count-badge-add-button
issue-count-badge-add-button btn btn-sm btn-default" issue-count-badge-add-button btn btn-sm btn-default qa-add-issues-button"
aria-label="Add an issue" aria-label="Add an issue"
data-placement="top" data-placement="top"
@click="toggleAddRelatedIssuesForm" @click="toggleAddRelatedIssuesForm"
......
...@@ -80,14 +80,14 @@ describe('epicHeader', () => { ...@@ -80,14 +80,14 @@ describe('epicHeader', () => {
}); });
describe('actionButtonClass', () => { describe('actionButtonClass', () => {
it('returns classes `btn btn-grouped js-btn-epic-action` & `btn-close` when `isEpicOpen` prop is true', () => { it('returns classes `btn btn-grouped js-btn-epic-action qa-close-reopen-epic-button` & `btn-close` when `isEpicOpen` prop is true', () => {
vm.isEpicOpen = true; vm.isEpicOpen = true;
expect(vm.actionButtonClass).toContain('btn btn-grouped js-btn-epic-action btn-close'); expect(vm.actionButtonClass).toContain('btn btn-grouped js-btn-epic-action qa-close-reopen-epic-button btn-close');
}); });
it('returns classes `btn btn-grouped js-btn-epic-action` & `btn-open` when `isEpicOpen` prop is false', () => { it('returns classes `btn btn-grouped js-btn-epic-action qa-close-reopen-epic-button` & `btn-open` when `isEpicOpen` prop is false', () => {
vm.isEpicOpen = false; vm.isEpicOpen = false;
expect(vm.actionButtonClass).toContain('btn btn-grouped js-btn-epic-action btn-open'); expect(vm.actionButtonClass).toContain('btn btn-grouped js-btn-epic-action qa-close-reopen-epic-button btn-open');
}); });
}); });
......
...@@ -56,6 +56,14 @@ module QA ...@@ -56,6 +56,14 @@ module QA
module MergeRequest module MergeRequest
autoload :Show, 'qa/ee/page/merge_request/show' autoload :Show, 'qa/ee/page/merge_request/show'
end end
module Group
module Epic
autoload :Index, 'qa/ee/page/group/epic/index'
autoload :Show, 'qa/ee/page/group/epic/show'
autoload :Edit, 'qa/ee/page/group/epic/edit'
end
end
end end
module Factory module Factory
...@@ -64,6 +72,10 @@ module QA ...@@ -64,6 +72,10 @@ module QA
module Geo module Geo
autoload :Node, 'qa/ee/factory/geo/node' autoload :Node, 'qa/ee/factory/geo/node'
end end
module Resource
autoload :Epic, 'qa/ee/factory/resource/epic'
end
end end
module Scenario module Scenario
......
# frozen_string_literal: true
module QA
module EE
module Factory
module Resource
class Epic < QA::Factory::Base
attr_accessor :title
dependency QA::Factory::Resource::Group, as: :group
def fabricate!
group.visit!
QA::Page::Menu::Side.act { click_epics }
Page::Group::Epic::Index.perform do |page|
page.click_new_epic
page.set_title(@title)
page.create_new_epic
page.wait(time: 1) do
page.has_text?(@title)
end
end
end
end
end
end
end
end
# frozen_string_literal: true
module QA
module EE
module Page
module Group
module Epic
class Edit < QA::Page::Base
include QA::Page::Component::Issuable::Common
def set_title(title)
fill_element :title_input, title
end
def set_description(description)
fill_element :description_textarea, description
end
def save_changes
click_element :save_button
end
def delete_epic
page.accept_alert("Epic will be removed! Are you sure?") do
click_element :delete_button
end
end
end
end
end
end
end
end
# frozen_string_literal: true
module QA
module EE
module Page
module Group
module Epic
class Index < QA::Page::Base
view 'ee/app/assets/javascripts/epics/new_epic/components/new_epic.vue' do
element :new_epic_button
element :epic_title
element :create_epic_button
end
def click_new_epic
click_element :new_epic_button
end
def set_title(title)
fill_element :epic_title, title
end
def create_new_epic
click_element :create_epic_button
end
end
end
end
end
end
end
# frozen_string_literal: true
module QA
module EE
module Page
module Group
module Epic
class Show < QA::Page::Base
include QA::Page::Component::Issuable::Common
view 'ee/app/assets/javascripts/related_issues/components/related_issues_block.vue' do
element :add_issues_button
end
view 'ee/app/assets/javascripts/related_issues/components/add_issuable_form.vue' do
element :add_issue_input
element :add_issue_button
end
view 'ee/app/assets/javascripts/related_issues/components/issue_item.vue' do
element :remove_issue_button
end
view 'ee/app/assets/javascripts/epics/epic_show/components/epic_header.vue' do
element :close_reopen_epic_button
end
def add_issue_to_epic(issue_url)
click_element :add_issues_button
fill_element :add_issue_input, issue_url
click_element :add_issue_button
click_element :add_issue_button
end
def add_comment_to_epic(comment)
fill_element :comment_input, comment
click_element :comment_button
end
def remove_issue_from_epic
click_element :remove_issue_button
end
def go_to_edit_page
click_element :edit_button
end
def delete_epic
page.accept_alert("Epic will be removed! Are you sure?") do
click_element :delete_epic_button
end
end
def close_reopen_epic
click_element :close_reopen_epic_button
end
end
end
end
end
end
end
...@@ -3,6 +3,8 @@ require 'capybara/dsl' ...@@ -3,6 +3,8 @@ require 'capybara/dsl'
module QA module QA
module Factory module Factory
class Product class Product
attr_reader :location
include Capybara::DSL include Capybara::DSL
Attribute = Struct.new(:name, :block) Attribute = Struct.new(:name, :block)
......
...@@ -90,6 +90,12 @@ module QA ...@@ -90,6 +90,12 @@ module QA
end end
end end
def click_epics
within_sidebar do
click_link('Epics')
end
end
private private
def hover_settings def hover_settings
......
# frozen_string_literal: true
module QA
context :plan do
describe 'Epics Creation' do
let!(:issue) do
Factory::Resource::Issue.fabricate! do |issue|
issue.title = 'Issue for epics tests'
end
end
before(:all) do
Runtime::Browser.visit(:gitlab, Page::Main::Login)
Page::Main::Login.act { sign_in_using_credentials }
end
it 'user creates, edits, deletes epic' do
epic = EE::Factory::Resource::Epic.fabricate! do |epic|
epic.title = "My First Epic"
end
expect(page).to have_content(/My First Epic/)
# Edit Epics
EE::Page::Group::Epic::Show.act { go_to_edit_page }
EE::Page::Group::Epic::Edit.perform do |edit_page|
edit_page.set_description("My Edited Epic Description")
edit_page.set_title("My Edited Epic")
edit_page.save_changes
expect(edit_page).to have_content(/My Edited Epic/)
end
# Add/Remove Issues to/from Epics
EE::Page::Group::Epic::Show.perform do |show_page|
show_page.add_issue_to_epic(issue.location)
show_page.remove_issue_from_epic
expect(show_page).to have_content(/removed issue/)
end
# Comment on Epics
EE::Page::Group::Epic::Show.act { add_comment_to_epic("My Epic Comments") }
expect(page).to have_content(/My Epic Comments/)
# Add Issue to Epic using quick actions
issue.visit!
Page::Project::Issue::Show.perform do |show_page|
show_page.comment("/epic #{epic.location}")
show_page.comment("/remove_epic")
expect(show_page).to have_content(/removed from epic/)
end
epic.visit!
expect(page).to have_content("added issue", count: 2)
expect(page).to have_content("removed issue", count: 2)
# Close Epic
EE::Page::Group::Epic::Show.act { close_reopen_epic }
expect(page).to have_content(/Closed/)
# Reopen Epic
EE::Page::Group::Epic::Show.act { close_reopen_epic }
expect(page).to have_content(/Open/)
# Delete Epics
EE::Page::Group::Epic::Show.act { go_to_edit_page }
EE::Page::Group::Epic::Edit.perform do |edit_page|
edit_page.delete_epic
expect(edit_page).to have_content(/The epic was successfully deleted/)
end
end
end
end
end
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