diff options
author | Rémy Coutable <remy@rymai.me> | 2018-01-08 09:37:43 +0000 |
---|---|---|
committer | Rémy Coutable <remy@rymai.me> | 2018-01-08 09:37:43 +0000 |
commit | 4bf0e1eb329d4542b9a4c7bcd2d17cde162bf49b (patch) | |
tree | 069e88323a7d00a1d68b957f06fbc50af92bb8b5 /spec | |
parent | 55addea754aed23b34ef12086e163c53a9174307 (diff) | |
parent | 7a815d7585a8a433359297f37b349604bfbcf2c8 (diff) | |
download | gitlab-ce-4bf0e1eb329d4542b9a4c7bcd2d17cde162bf49b.tar.gz |
Merge branch 'mv-explore-groups-spinach-to-rspec' into 'master'
Move explore groups spinach test to RSpec
See merge request gitlab-org/gitlab-ce!16129
Diffstat (limited to 'spec')
-rw-r--r-- | spec/features/explore/groups_spec.rb | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/spec/features/explore/groups_spec.rb b/spec/features/explore/groups_spec.rb new file mode 100644 index 00000000000..e4ef47d88dd --- /dev/null +++ b/spec/features/explore/groups_spec.rb @@ -0,0 +1,87 @@ +require 'spec_helper' + +describe 'Explore Groups', :js do + let(:user) { create :user } + let(:group) { create :group } + let!(:private_project) do + create :project, :private, namespace: group do |project| + create(:issue, project: internal_project) + create(:merge_request, source_project: project, target_project: project) + end + end + + let!(:internal_project) do + create :project, :internal, namespace: group do |project| + create(:issue, project: project) + create(:merge_request, source_project: project, target_project: project) + end + end + + let!(:public_project) do + create(:project, :public, namespace: group) do |project| + create(:issue, project: project) + create(:merge_request, source_project: project, target_project: project) + end + end + + shared_examples 'renders public and internal projects' do + it do + visit_page + expect(page).to have_content(public_project.name) + expect(page).to have_content(internal_project.name) + expect(page).not_to have_content(private_project.name) + end + end + + shared_examples 'renders only public project' do + it do + visit_page + expect(page).to have_content(public_project.name) + expect(page).not_to have_content(internal_project.name) + expect(page).not_to have_content(private_project.name) + end + end + + shared_examples 'renders group in public groups area' do + it do + visit explore_groups_path + expect(page).to have_content(group.name) + end + end + + context 'when signed in' do + before do + sign_in(user) + end + + it_behaves_like 'renders public and internal projects' do + subject(:visit_page) { visit group_path(group) } + end + + it_behaves_like 'renders public and internal projects' do + subject(:visit_page) { visit issues_group_path(group) } + end + + it_behaves_like 'renders public and internal projects' do + subject(:visit_page) { visit merge_requests_group_path(group) } + end + + it_behaves_like 'renders group in public groups area' + end + + context 'when signed out' do + it_behaves_like 'renders only public project' do + subject(:visit_page) { visit group_path(group) } + end + + it_behaves_like 'renders only public project' do + subject(:visit_page) { visit issues_group_path(group) } + end + + it_behaves_like 'renders only public project' do + subject(:visit_page) { visit merge_requests_group_path(group) } + end + + it_behaves_like 'renders group in public groups area' + end +end |