summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorClement Ho <ClemMakesApps@gmail.com>2016-12-16 01:05:27 -0600
committerClement Ho <ClemMakesApps@gmail.com>2017-01-09 16:01:32 -0600
commit625ecdbcc848f05eafaf167255901efd2d32cb37 (patch)
treed87ca2b3827bc0128704d1338f0f3f51256b50be
parent61680a2d9833cc3ef63b9e76930f47e44258f30d (diff)
downloadgitlab-ce-625ecdbcc848f05eafaf167255901efd2d32cb37.tar.gz
Create dropdown hint spec
-rw-r--r--spec/features/issues/filtered_search/dropdown_hint_spec.rb113
-rw-r--r--spec/features/issues/filtered_search/filter_issues_spec.rb (renamed from spec/features/issues/filter_issues_spec.rb)12
-rw-r--r--spec/features/issues/filtered_search/search_bar_spec.rb (renamed from spec/features/issues/search_bar_spec.rb)33
3 files changed, 152 insertions, 6 deletions
diff --git a/spec/features/issues/filtered_search/dropdown_hint_spec.rb b/spec/features/issues/filtered_search/dropdown_hint_spec.rb
new file mode 100644
index 00000000000..364d4bf4db1
--- /dev/null
+++ b/spec/features/issues/filtered_search/dropdown_hint_spec.rb
@@ -0,0 +1,113 @@
+require 'rails_helper'
+
+describe 'Dropdown hint', js: true, feature: true do
+ include WaitForAjax
+
+ let!(:project) { create(:empty_project) }
+ let!(:user) { create(:user) }
+ let(:filtered_search) { find('.filtered-search') }
+ before do
+ project.team << [user, :master]
+ login_as(user)
+ create(:issue, project: project)
+
+ visit namespace_project_issues_path(project.namespace, project)
+ end
+
+ describe 'behavior' do
+ before do
+ expect(page).to have_css('#js-dropdown-hint', visible: false)
+ filtered_search.click();
+ end
+
+ it 'opens when the search bar is first focused' do
+ expect(page).to have_css('#js-dropdown-hint', visible: true)
+ end
+
+ it 'closes when the search bar is unfocused' do
+ find('body').click();
+ expect(page).to have_css('#js-dropdown-hint', visible: false)
+ end
+ end
+
+ describe 'filtering' do
+ it 'does not filter `Keep typing and press Enter`' do
+ filtered_search.set('randomtext')
+ expect(page).to have_css('#js-dropdown-hint', text: 'Keep typing and press Enter', visible: false)
+ expect(page.all('#js-dropdown-hint .filter-dropdown .filter-dropdown-item').size).to eq(0)
+ end
+
+ it 'filters with text' do
+ filtered_search.set('a')
+ expect(page.all('#js-dropdown-hint .filter-dropdown .filter-dropdown-item').size).to eq(3)
+ end
+ end
+
+ describe 'selecting from dropdown with no input' do
+ before do
+ filtered_search.click
+ end
+
+ it 'opens the author dropdown when you click on author' do
+ find('#js-dropdown-hint .filter-dropdown .filter-dropdown-item', text: 'author').click
+ expect(page).to have_css('#js-dropdown-hint', visible: false)
+ expect(page).to have_css('#js-dropdown-author', visible: true)
+ expect(filtered_search.value).to eq('author:')
+ end
+
+ it 'opens the assignee dropdown when you click on assignee' do
+ find('#js-dropdown-hint .filter-dropdown .filter-dropdown-item', text: 'assignee').click
+ expect(page).to have_css('#js-dropdown-hint', visible: false)
+ expect(page).to have_css('#js-dropdown-assignee', visible: true)
+ expect(filtered_search.value).to eq('assignee:')
+ end
+
+ it 'opens the milestone dropdown when you click on milestone' do
+ find('#js-dropdown-hint .filter-dropdown .filter-dropdown-item', text: 'milestone').click
+ expect(page).to have_css('#js-dropdown-hint', visible: false)
+ expect(page).to have_css('#js-dropdown-milestone', visible: true)
+ expect(filtered_search.value).to eq('milestone:')
+ end
+
+ it 'opens the label dropdown when you click on label' do
+ find('#js-dropdown-hint .filter-dropdown .filter-dropdown-item', text: 'label').click
+ expect(page).to have_css('#js-dropdown-hint', visible: false)
+ expect(page).to have_css('#js-dropdown-label', visible: true)
+ expect(filtered_search.value).to eq('label:')
+ end
+ end
+
+ describe 'selecting from dropdown with some input' do
+ it 'opens the author dropdown when you click on author' do
+ filtered_search.set('auth')
+ find('#js-dropdown-hint .filter-dropdown .filter-dropdown-item', text: 'author').click
+ expect(page).to have_css('#js-dropdown-hint', visible: false)
+ expect(page).to have_css('#js-dropdown-author', visible: true)
+ expect(filtered_search.value).to eq('author:')
+ end
+
+ it 'opens the assignee dropdown when you click on assignee' do
+ filtered_search.set('assign')
+ find('#js-dropdown-hint .filter-dropdown .filter-dropdown-item', text: 'assignee').click
+ expect(page).to have_css('#js-dropdown-hint', visible: false)
+ expect(page).to have_css('#js-dropdown-assignee', visible: true)
+ expect(filtered_search.value).to eq('assignee:')
+ end
+
+ it 'opens the milestone dropdown when you click on milestone' do
+ filtered_search.set('mile')
+ find('#js-dropdown-hint .filter-dropdown .filter-dropdown-item', text: 'milestone').click
+ expect(page).to have_css('#js-dropdown-hint', visible: false)
+ expect(page).to have_css('#js-dropdown-milestone', visible: true)
+ expect(filtered_search.value).to eq('milestone:')
+ end
+
+ it 'opens the label dropdown when you click on label' do
+ filtered_search.set('lab')
+ find('#js-dropdown-hint .filter-dropdown .filter-dropdown-item', text: 'label').click
+ expect(page).to have_css('#js-dropdown-hint', visible: false)
+ expect(page).to have_css('#js-dropdown-label', visible: true)
+ expect(filtered_search.value).to eq('label:')
+ end
+ end
+end
diff --git a/spec/features/issues/filter_issues_spec.rb b/spec/features/issues/filtered_search/filter_issues_spec.rb
index 0b94bcc4e3f..283814d2cbb 100644
--- a/spec/features/issues/filter_issues_spec.rb
+++ b/spec/features/issues/filtered_search/filter_issues_spec.rb
@@ -3,13 +3,13 @@ require 'rails_helper'
describe 'Filter issues', feature: true do
include WaitForAjax
- let!(:group) { create(:group) }
- let!(:project) { create(:project, group: group) }
- let!(:user) { create(:user) }
- let!(:user2) { create(:user) }
+ let!(:group) { create(:group) }
+ let!(:project) { create(:project, group: group) }
+ let!(:user) { create(:user) }
+ let!(:user2) { create(:user) }
let!(:milestone) { create(:milestone, project: project) }
- let!(:label) { create(:label, project: project) }
- let!(:wontfix) { create(:label, project: project, title: "Won't fix") }
+ let!(:label) { create(:label, project: project) }
+ let!(:wontfix) { create(:label, project: project, title: "Won't fix") }
let!(:bug_label) { create(:label, project: project, title: 'bug') }
let!(:caps_sensitive_label) { create(:label, project: project, title: 'CAPS_sensitive') }
diff --git a/spec/features/issues/search_bar_spec.rb b/spec/features/issues/filtered_search/search_bar_spec.rb
index d0abdc284ea..5862214cdc3 100644
--- a/spec/features/issues/search_bar_spec.rb
+++ b/spec/features/issues/filtered_search/search_bar_spec.rb
@@ -14,6 +14,11 @@ describe 'Search bar', js: true, feature: true do
visit namespace_project_issues_path(project.namespace, project)
end
+ def getLeftStyle(style)
+ leftStyle = /left:\s\d*[.]\d*px/.match(style)
+ leftStyle.to_s.gsub('left: ', '').to_f;
+ end
+
describe 'clear search button' do
it 'clears text' do
search_text = 'search_text'
@@ -49,5 +54,33 @@ describe 'Search bar', js: true, feature: true do
expect(page).to have_css('.clear-search', visible: true)
end
+
+ it 'resets the dropdown hint filter' do
+ filtered_search = find('.filtered-search')
+ filtered_search.click();
+ original_size = page.all('#js-dropdown-hint .filter-dropdown .filter-dropdown-item').size
+
+ filtered_search.set('author')
+ expect(page.all('#js-dropdown-hint .filter-dropdown .filter-dropdown-item').size).to eq(1)
+
+ find('.filtered-search-input-container .clear-search').click
+ filtered_search.click()
+ expect(page.all('#js-dropdown-hint .filter-dropdown .filter-dropdown-item').size).to eq(original_size)
+ end
+
+ it 'resets the dropdown filters' do
+ filtered_search = find('.filtered-search')
+ filtered_search.set('a')
+ hintStyle = page.find('#js-dropdown-hint')['style']
+ hintOffset = getLeftStyle(hintStyle)
+
+ filtered_search.set('author:')
+ expect(page.all('#js-dropdown-hint .filter-dropdown .filter-dropdown-item').size).to eq(0)
+
+ find('.filtered-search-input-container .clear-search').click
+ filtered_search.click()
+ expect(page.all('#js-dropdown-hint .filter-dropdown .filter-dropdown-item').size).to be > 0
+ expect(getLeftStyle(page.find('#js-dropdown-hint')['style'])).to eq (hintOffset)
+ end
end
end