#-- copyright # OpenProject is a project management system. # Copyright (C) 2012-2018 the OpenProject Foundation (OPF) # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License version 3. # # OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows: # Copyright (C) 2006-2017 Jean-Philippe Lang # Copyright (C) 2010-2013 the ChiliProject Team # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. # # See docs/COPYRIGHT.rdoc for more details. #++ require 'spec_helper' # FIXME: deprecate this example and replace by 'has an untitled action link' # it does not work as intended (setting user has no effect, but by chance :role overrides base spec) # it does not check the actual href/method shared_examples_for 'action link' do let(:permissions) { %i(view_work_packages edit_work_packages) } let(:user) do FactoryBot.build_stubbed(:user) end let(:href) { nil } before do login_as(user) allow(user) .to receive(:allowed_to?) do |permission, project| permissions.include?(permission) end end it { expect(subject).not_to have_json_path("_links/#{action}/href") } describe 'with permission' do before do permissions << permission end it { expect(subject).to have_json_path("_links/#{action}/href") } it do if href expect(subject).to be_json_eql(href.to_json).at_path("_links/#{action}/href") end end end end shared_examples_for 'has an untitled action link' do it_behaves_like 'has an untitled link' it 'indicates the desired method' do is_expected.to be_json_eql(method.to_json).at_path("_links/#{link}/method") end describe 'without permission' do let(:permissions) { all_permissions - [permission] } it_behaves_like 'has no link' end end shared_examples_for 'has a titled link' do it { is_expected.to be_json_eql(href.to_json).at_path("_links/#{link}/href") } it { is_expected.to be_json_eql(title.to_json).at_path("_links/#{link}/title") } end shared_examples_for 'has an untitled link' do it { is_expected.to be_json_eql(href.to_json).at_path("_links/#{link}/href") } it { is_expected.not_to have_json_path("_links/#{link}/title") } end shared_examples_for 'has a templated link' do it { is_expected.to be_json_eql(href.to_json).at_path("_links/#{link}/href") } it { is_expected.to be_json_eql(true.to_json).at_path("_links/#{link}/templated") } end shared_examples_for 'has an empty link' do it { is_expected.to be_json_eql(nil.to_json).at_path("_links/#{link}/href") } it 'has no embedded resource' do is_expected.not_to have_json_path("_embedded/#{link}") end end shared_examples_for 'has an empty link collection' do it { is_expected.to be_json_eql([].to_json).at_path("_links/#{link}") } end shared_examples_for 'has a link collection' do it { is_expected.to be_json_eql(hrefs.to_json).at_path("_links/#{link}") } end shared_examples_for 'has no link' do it { is_expected.not_to have_json_path("_links/#{link}") } it 'has no embedded resource' do is_expected.not_to have_json_path("_embedded/#{link}") end end