Files
openproject/modules/backlogs/spec/controllers/rb_taskboards_controller_spec.rb
T
Alexander Brandon Coles 44b434e328 [#73798] Remove scrum_projects feature flag
Make Backlogs use the sprint-based behavior unconditionally and
remove the old feature-flagged branches from controllers, routes,
representers, and supporting helpers.

Update the affected Backlogs specs and PDF export expectations to
match the permanent sprint model and keep list reordering stable when
moving work packages between backlog and sprint scopes.

https://community.openproject.org/wp/73798
2026-04-17 09:47:10 +01:00

138 lines
4.6 KiB
Ruby

# frozen_string_literal: true
#-- copyright
# OpenProject is an open source project management software.
# Copyright (C) the OpenProject GmbH
#
# 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-2013 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 COPYRIGHT and LICENSE files for more details.
#++
require "spec_helper"
RSpec.describe RbTaskboardsController do
shared_let(:type_feature) { create(:type_feature) }
shared_let(:type_task) { create(:type_task) }
let(:user) { create(:user) }
let(:permissions) { [] }
let(:project) { create(:project, member_with_permissions: { user => permissions }) }
let(:status) { create(:status, name: "status 1", is_default: true) }
let(:board) { create(:board_grid_with_query, project:) }
current_user { user }
before do
allow(Setting)
.to receive(:plugin_openproject_backlogs)
.and_return({ "story_types" => [type_feature.id], "task_type" => type_task.id })
end
describe "GET show" do
let(:sprint) { create(:agile_sprint, project:) }
context "when the board exists" do
let!(:other_project) { create(:project) }
let!(:other_board) { create(:board_grid_with_query, project: other_project, linked: sprint) }
before do
board.update!(linked: sprint)
end
context "as a member with view_sprints permission" do
let(:permissions) { %i[view_sprints view_work_packages] }
before do
get :show, params: { project_id: project.identifier, sprint_id: sprint.id }
end
it "redirects to the board" do
expect(response).to redirect_to(project_work_package_board_path(project, board))
end
it "uses the board for the current project" do
expect(response).to redirect_to(project_work_package_board_path(project, board))
expect(response).not_to redirect_to(project_work_package_board_path(other_project, other_board))
end
end
end
context "when the board does not exist" do
let(:permissions) { %i[view_sprints view_work_packages] }
before do
get :show, params: { project_id: project.identifier, sprint_id: sprint.id }
end
it "returns not found" do
expect(response).to have_http_status(:not_found)
end
end
context "when the sprint is rendered in a receiving project" do
let(:source_project) { create(:project, sprint_sharing: "share_all_projects") }
let(:project) do
create(:project,
sprint_sharing: "receive_shared",
member_with_permissions: { user => permissions })
end
let(:permissions) { %i[view_sprints view_work_packages] }
let(:sprint) { create(:agile_sprint, project: source_project) }
before do
create(:board_grid_with_query, project: source_project, linked: sprint)
get :show, params: { project_id: project.identifier, sprint_id: sprint.id }
end
it "returns not found when the receiving project has no task board" do
expect(response).to have_http_status(:not_found)
end
end
context "as a member without view_sprints permission" do
let(:permissions) { [:view_project] }
before do
board.update!(linked: sprint)
get :show, params: { project_id: project.identifier, sprint_id: sprint.id }
end
it "denies access" do
expect(response).to have_http_status(:not_found)
end
end
context "as a non-member" do
current_user { create(:user) }
before do
board.update!(linked: sprint)
get :show, params: { project_id: project.identifier, sprint_id: sprint.id }
end
it "denies access" do
expect(response).to have_http_status(:not_found)
end
end
end
end