Commit f2711628 authored by Ezekiel Kigbo's avatar Ezekiel Kigbo

Minor review cleanup

Minor refactor specs
parent b054a961
...@@ -31,7 +31,7 @@ module SortingHelper ...@@ -31,7 +31,7 @@ module SortingHelper
end end
def projects_sort_options_hash def projects_sort_options_hash
use_old_sorting = !Feature.enabled?(:project_list_filter_bar) || current_controller?('admin/projects') use_old_sorting = Feature.disabled?(:project_list_filter_bar) || current_controller?('admin/projects')
options = { options = {
sort_value_latest_activity => sort_title_latest_activity, sort_value_latest_activity => sort_title_latest_activity,
......
...@@ -70,8 +70,6 @@ describe SortingHelper do ...@@ -70,8 +70,6 @@ describe SortingHelper do
describe '#projects_sort_options_hash' do describe '#projects_sort_options_hash' do
it 'returns a hash of available sorting options' do it 'returns a hash of available sorting options' do
hash = projects_sort_options_hash
admin_options = project_common_options.merge({ admin_options = project_common_options.merge({
sort_value_oldest_activity => sort_title_oldest_activity, sort_value_oldest_activity => sort_title_oldest_activity,
sort_value_oldest_created => sort_title_oldest_created, sort_value_oldest_created => sort_title_oldest_created,
...@@ -79,7 +77,8 @@ describe SortingHelper do ...@@ -79,7 +77,8 @@ describe SortingHelper do
sort_value_stars_desc => sort_title_most_stars, sort_value_stars_desc => sort_title_most_stars,
sort_value_largest_repo => sort_title_largest_repo sort_value_largest_repo => sort_title_largest_repo
}) })
expect(hash).to eq(admin_options)
expect(projects_sort_options_hash).to eq(admin_options)
end end
end end
end end
...@@ -91,60 +90,62 @@ describe SortingHelper do ...@@ -91,60 +90,62 @@ describe SortingHelper do
describe '#projects_sort_options_hash' do describe '#projects_sort_options_hash' do
it 'returns a hash of available sorting options' do it 'returns a hash of available sorting options' do
hash = projects_sort_options_hash expect(projects_sort_options_hash).to include(project_common_options)
common_options = project_common_options
common_options.each do |key, opt|
expect(hash).to include(key)
expect(hash[key]).to eq(opt)
end
end end
end end
describe '#projects_reverse_sort_options_hash' do describe '#projects_reverse_sort_options_hash' do
it 'returns a reversed hash of available sorting options' do context 'returns a reversed hash of available sorting options' do
using RSpec::Parameterized::TableSyntax
where(:sort_key, :reverse_sort_title) do
sort_value_latest_activity | sort_value_oldest_activity
sort_value_recently_created | sort_value_oldest_created
sort_value_name | sort_value_name_desc
sort_value_stars_desc | sort_value_stars_asc
sort_value_oldest_activity | sort_value_latest_activity
sort_value_oldest_created | sort_value_recently_created
sort_value_name_desc | sort_value_name
sort_value_stars_asc | sort_value_stars_desc
end
with_them do
it do
reverse_hash = projects_reverse_sort_options_hash reverse_hash = projects_reverse_sort_options_hash
options = { expect(reverse_hash).to include(sort_key)
sort_value_latest_activity => sort_value_oldest_activity, expect(reverse_hash[sort_key]).to eq(reverse_sort_title)
sort_value_recently_created => sort_value_oldest_created, end
sort_value_name => sort_value_name_desc,
sort_value_stars_desc => sort_value_stars_asc,
sort_value_oldest_activity => sort_value_latest_activity,
sort_value_oldest_created => sort_value_recently_created,
sort_value_name_desc => sort_value_name,
sort_value_stars_asc => sort_value_stars_desc
}
options.each do |key, opt|
expect(reverse_hash).to include(key)
expect(reverse_hash[key]).to eq(opt)
end end
end end
end end
describe '#project_sort_direction_button' do describe '#project_sort_direction_button' do
it 'returns the correct icon for each sort option' do context 'returns the correct icon for each sort option' do
using RSpec::Parameterized::TableSyntax
sort_lowest_icon = 'sort-lowest' sort_lowest_icon = 'sort-lowest'
sort_highest_icon = 'sort-highest' sort_highest_icon = 'sort-highest'
sort_options_icons = { where(:selected_sort, :icon) do
sort_value_latest_activity => sort_highest_icon, sort_value_latest_activity | sort_highest_icon
sort_value_recently_created => sort_highest_icon, sort_value_recently_created | sort_highest_icon
sort_value_name_desc => sort_highest_icon, sort_value_name_desc | sort_highest_icon
sort_value_stars_desc => sort_highest_icon, sort_value_stars_desc | sort_highest_icon
sort_value_oldest_activity => sort_lowest_icon, sort_value_oldest_activity | sort_lowest_icon
sort_value_oldest_created => sort_lowest_icon, sort_value_oldest_created | sort_lowest_icon
sort_value_name => sort_lowest_icon, sort_value_name | sort_lowest_icon
sort_value_stars_asc => sort_lowest_icon sort_value_stars_asc | sort_lowest_icon
} end
sort_options_icons.each do |selected_sort, icon| with_them do
it do
set_sorting_url selected_sort set_sorting_url selected_sort
expect(project_sort_direction_button(selected_sort)).to include(icon) expect(project_sort_direction_button(selected_sort)).to include(icon)
end end
end end
end
it 'returns the correct link to reverse the current sort option' do it 'returns the correct link to reverse the current sort option' do
sort_options_links = projects_reverse_sort_options_hash sort_options_links = projects_reverse_sort_options_hash
...@@ -159,25 +160,14 @@ describe SortingHelper do ...@@ -159,25 +160,14 @@ describe SortingHelper do
describe '#projects_sort_option_titles' do describe '#projects_sort_option_titles' do
it 'returns a hash of titles for the sorting options' do it 'returns a hash of titles for the sorting options' do
titles = projects_sort_option_titles options = project_common_options.merge({
options = {
sort_value_latest_activity => sort_title_latest_activity,
sort_value_recently_created => sort_title_created_date,
sort_value_name => sort_title_name,
sort_value_stars_desc => sort_title_stars,
sort_value_oldest_activity => sort_title_latest_activity, sort_value_oldest_activity => sort_title_latest_activity,
sort_value_oldest_created => sort_title_created_date, sort_value_oldest_created => sort_title_created_date,
sort_value_name_desc => sort_title_name, sort_value_name_desc => sort_title_name,
sort_value_stars_asc => sort_title_stars sort_value_stars_asc => sort_title_stars
} })
expect(titles.length).to eq(options.length)
titles.each do |key, opt| expect(projects_sort_option_titles).to eq(options)
expect(options).to include(key)
expect(options[key]).to eq(opt)
end
end end
end end
...@@ -188,7 +178,6 @@ describe SortingHelper do ...@@ -188,7 +178,6 @@ describe SortingHelper do
describe '#projects_sort_options_hash' do describe '#projects_sort_options_hash' do
it 'returns a hash of available sorting options' do it 'returns a hash of available sorting options' do
hash = projects_sort_options_hash
options = project_common_options.merge({ options = project_common_options.merge({
sort_value_oldest_activity => sort_title_oldest_activity, sort_value_oldest_activity => sort_title_oldest_activity,
sort_value_oldest_created => sort_title_oldest_created, sort_value_oldest_created => sort_title_oldest_created,
...@@ -196,10 +185,7 @@ describe SortingHelper do ...@@ -196,10 +185,7 @@ describe SortingHelper do
sort_value_stars_desc => sort_title_most_stars sort_value_stars_desc => sort_title_most_stars
}) })
options.each do |key, opt| expect(projects_sort_options_hash).to eq(options)
expect(hash).to include(key)
expect(hash[key]).to eq(opt)
end
end 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