diff options
Diffstat (limited to 'spec/views/projects')
-rw-r--r-- | spec/views/projects/_home_panel.html.haml_spec.rb | 1 | ||||
-rw-r--r-- | spec/views/projects/empty.html.haml_spec.rb | 37 | ||||
-rw-r--r-- | spec/views/projects/show.html.haml_spec.rb | 51 | ||||
-rw-r--r-- | spec/views/projects/tree/_tree_row.html.haml_spec.rb | 43 |
4 files changed, 89 insertions, 43 deletions
diff --git a/spec/views/projects/_home_panel.html.haml_spec.rb b/spec/views/projects/_home_panel.html.haml_spec.rb index 548dba7874a..cc0eb9919da 100644 --- a/spec/views/projects/_home_panel.html.haml_spec.rb +++ b/spec/views/projects/_home_panel.html.haml_spec.rb @@ -9,6 +9,7 @@ RSpec.describe 'projects/_home_panel' do let(:project) { create(:project) } before do + stub_feature_flags(vue_notification_dropdown: false) assign(:project, project) allow(view).to receive(:current_user).and_return(user) diff --git a/spec/views/projects/empty.html.haml_spec.rb b/spec/views/projects/empty.html.haml_spec.rb index de83722160e..6762dcd22d5 100644 --- a/spec/views/projects/empty.html.haml_spec.rb +++ b/spec/views/projects/empty.html.haml_spec.rb @@ -79,4 +79,41 @@ RSpec.describe 'projects/empty' do it_behaves_like 'no invite member info' end end + + context 'when rendering with the layout' do + subject(:render_page) { render template: 'projects/empty.html.haml', layout: 'layouts/project' } + + describe 'invite team members' do + before do + allow(view).to receive(:session).and_return({}) + allow(view).to receive(:current_user_mode).and_return(Gitlab::Auth::CurrentUserMode.new(user)) + allow(view).to receive(:current_user).and_return(user) + allow(view).to receive(:experiment_enabled?).and_return(false) + end + + context 'when invite team members is not available in sidebar' do + before do + allow(view).to receive(:can_invite_members_for_project?).and_return(false) + end + + it 'does not display the js-invite-members-trigger' do + render_page + + expect(rendered).not_to have_selector('.js-invite-members-trigger') + end + end + + context 'when invite team members is available' do + before do + allow(view).to receive(:can_invite_members_for_project?).and_return(true) + end + + it 'includes the div for js-invite-members-trigger' do + render_page + + expect(rendered).to have_selector('.js-invite-members-trigger') + end + end + end + end end diff --git a/spec/views/projects/show.html.haml_spec.rb b/spec/views/projects/show.html.haml_spec.rb new file mode 100644 index 00000000000..995e31e83af --- /dev/null +++ b/spec/views/projects/show.html.haml_spec.rb @@ -0,0 +1,51 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe 'projects/show.html.haml' do + let_it_be(:user) { build(:user) } + let_it_be(:project) { ProjectPresenter.new(create(:project, :repository), current_user: user) } + + before do + assign(:project, project) + end + + context 'when rendering with the layout' do + subject(:render_page) { render template: 'projects/show.html.haml', layout: 'layouts/project' } + + describe 'invite team members' do + before do + allow(view).to receive(:event_filter_link) + allow(view).to receive(:session).and_return({}) + allow(view).to receive(:current_user_mode).and_return(Gitlab::Auth::CurrentUserMode.new(user)) + allow(view).to receive(:current_user).and_return(user) + allow(view).to receive(:experiment_enabled?).and_return(false) + allow(view).to receive(:add_page_startup_graphql_call) + end + + context 'when invite team members is not available in sidebar' do + before do + allow(view).to receive(:can_invite_members_for_project?).and_return(false) + end + + it 'does not display the js-invite-members-trigger' do + render_page + + expect(rendered).not_to have_selector('.js-invite-members-trigger') + end + end + + context 'when invite team members is available' do + before do + allow(view).to receive(:can_invite_members_for_project?).and_return(true) + end + + it 'includes the div for js-invite-members-trigger' do + render_page + + expect(rendered).to have_selector('.js-invite-members-trigger') + end + end + end + end +end diff --git a/spec/views/projects/tree/_tree_row.html.haml_spec.rb b/spec/views/projects/tree/_tree_row.html.haml_spec.rb deleted file mode 100644 index 43a37934afd..00000000000 --- a/spec/views/projects/tree/_tree_row.html.haml_spec.rb +++ /dev/null @@ -1,43 +0,0 @@ -# frozen_string_literal: true - -require 'spec_helper' - -RSpec.describe 'projects/tree/_tree_row' do - let(:project) { create(:project, :repository) } - let(:repository) { project.repository } - - # rubocop: disable Rails/FindBy - # This is not ActiveRecord where..first - let(:blob_item) { Gitlab::Git::Tree.where(repository, SeedRepo::Commit::ID, 'files/ruby').first } - # rubocop: enable Rails/FindBy - - before do - assign(:project, project) - assign(:repository, repository) - assign(:id, File.join('master', '')) - assign(:lfs_blob_ids, []) - end - - it 'renders blob item' do - render_partial(blob_item) - - expect(rendered).to have_content(blob_item.name) - expect(rendered).not_to have_selector('.label-lfs', text: 'LFS') - end - - describe 'LFS blob' do - before do - assign(:lfs_blob_ids, [blob_item].map(&:id)) - - render_partial(blob_item) - end - - it 'renders LFS badge' do - expect(rendered).to have_selector('.label-lfs', text: 'LFS') - end - end - - def render_partial(items) - render partial: 'projects/tree/tree_row', collection: [items].flatten - end -end |