From d0eb2eed881338a83a68a792a68c6c22106eea7c Mon Sep 17 00:00:00 2001 From: Juan Vasquez Date: Mon, 22 Jan 2024 16:01:54 -0600 Subject: [PATCH] Action Plan should only include approved stories Closes #321 --- app/controllers/action_plans_controller.rb | 2 +- app/models/project.rb | 1 + spec/features/action_plan_generate_spec.rb | 10 ++++++---- spec/models/project_spec.rb | 15 ++++++++------- spec/models/story_spec.rb | 9 +++++++++ 5 files changed, 25 insertions(+), 12 deletions(-) diff --git a/app/controllers/action_plans_controller.rb b/app/controllers/action_plans_controller.rb index 9d742f94..590d3ca1 100644 --- a/app/controllers/action_plans_controller.rb +++ b/app/controllers/action_plans_controller.rb @@ -3,7 +3,7 @@ class ActionPlansController < ApplicationController def show @project = Project.find(params[:project_id]) - @project_stories = @project.stories.by_position + @project_stories = @project.stories.approved.by_position @children = Project.sub_projects_with_ordered_stories(@project.id) end end diff --git a/app/models/project.rb b/app/models/project.rb index f2f2293e..5842593c 100644 --- a/app/models/project.rb +++ b/app/models/project.rb @@ -16,6 +16,7 @@ class Project < ApplicationRecord scope :sub_projects_with_ordered_stories, ->(project_id) { where(parent_id: project_id) .includes(:stories).references(:stories) + .where(stories: {status: :approved}) .order("projects.position ASC, stories.position ASC NULLS FIRST") } diff --git a/spec/features/action_plan_generate_spec.rb b/spec/features/action_plan_generate_spec.rb index bea80175..62f93c0f 100644 --- a/spec/features/action_plan_generate_spec.rb +++ b/spec/features/action_plan_generate_spec.rb @@ -8,15 +8,17 @@ let!(:project) do FactoryBot.create(:project, parent: parent).tap do |project| - FactoryBot.create(:story, title: "Second Story", description: "Second", position: 2, project: project, extra_info: "Extra Information") - FactoryBot.create(:story, title: "First Story", description: "First", position: 1, project: project) + FactoryBot.create(:story, :approved, title: "Second Story", description: "Second", position: 2, project: project, extra_info: "Extra Information") + FactoryBot.create(:story, :approved, title: "First Story", description: "First", position: 1, project: project) + FactoryBot.create(:story, :pending, title: "Pending task", description: "Pending description", position: 3, project: project) end end let!(:project2) do FactoryBot.create(:project, parent: parent).tap do |project| - FactoryBot.create(:story, title: "Third Story", description: "Third", position: 2, project: project) - FactoryBot.create(:story, title: "Forth Story", description: "Forth", position: 1, project: project) + FactoryBot.create(:story, :approved, title: "Third Story", description: "Third", position: 2, project: project) + FactoryBot.create(:story, :approved, title: "Forth Story", description: "Forth", position: 1, project: project) + FactoryBot.create(:story, :rejected, title: "Rejected task", description: "Rejected description", position: 3, project: project) end end diff --git a/spec/models/project_spec.rb b/spec/models/project_spec.rb index 31749db3..b93f7d61 100644 --- a/spec/models/project_spec.rb +++ b/spec/models/project_spec.rb @@ -21,17 +21,18 @@ expect(sub_project2.position).to eq 2 end - describe ".with_ordered_descendents" do + describe ".sub_projects_with_ordered_stories" do it "orders sub projects properly" do parent = FactoryBot.create(:project) sub_project1 = FactoryBot.create(:project, parent: parent, position: 2) - story_5 = FactoryBot.create(:story, project: sub_project1, position: 2) - story_4 = FactoryBot.create(:story, project: sub_project1, position: 1) - story_6 = FactoryBot.create(:story, project: sub_project1, position: 3) + story_5 = FactoryBot.create(:story, :approved, project: sub_project1, position: 2) + story_4 = FactoryBot.create(:story, :approved, project: sub_project1, position: 1) + story_6 = FactoryBot.create(:story, :approved, project: sub_project1, position: 3) + sub_project2 = FactoryBot.create(:project, parent: parent, position: 1) - story_3 = FactoryBot.create(:story, project: sub_project2, position: 3) - story_1 = FactoryBot.create(:story, project: sub_project2, position: 1) - story_2 = FactoryBot.create(:story, project: sub_project2, position: 2) + story_3 = FactoryBot.create(:story, :approved, project: sub_project2, position: 3) + story_1 = FactoryBot.create(:story, :approved, project: sub_project2, position: 1) + story_2 = FactoryBot.create(:story, :approved, project: sub_project2, position: 2) sub_projects = Project.sub_projects_with_ordered_stories(parent.id) expect(sub_projects.count).to eq 2 diff --git a/spec/models/story_spec.rb b/spec/models/story_spec.rb index 60c549c5..b9b69db6 100644 --- a/spec/models/story_spec.rb +++ b/spec/models/story_spec.rb @@ -115,4 +115,13 @@ end end end + + describe ".approved" do + it "returns only approved stories" do + approved_stories = FactoryBot.create_list(:story, 2, :approved) + FactoryBot.create_list(:story, 2, :rejected) + + expect(Story.approved).to eq(approved_stories) + end + end end