From 36f38473011748c26baaf6d2a564b361517c5299 Mon Sep 17 00:00:00 2001 From: "jorg.vr" Date: Wed, 8 Jan 2025 13:50:39 +0100 Subject: [PATCH 1/4] Correctly copy all series info when copying courses --- app/controllers/courses_controller.rb | 6 ++- test/controllers/courses_controller_test.rb | 57 +++++++++++++++++++-- 2 files changed, 57 insertions(+), 6 deletions(-) diff --git a/app/controllers/courses_controller.rb b/app/controllers/courses_controller.rb index a923fa92d8..3b43f68652 100644 --- a/app/controllers/courses_controller.rb +++ b/app/controllers/courses_controller.rb @@ -155,7 +155,7 @@ def create deadlines: false }.merge(@copy_options).symbolize_keys - @course.series = policy_scope(@copy_options[:base].series).map do |s| + @course.series = policy_scope(@copy_options[:base].series.reorder(id: :asc)).map do |s| # rubocop:disable Style/MultilineTernaryOperator Series.new( series_memberships: @copy_options[:exercises] ? @@ -169,7 +169,9 @@ def create visibility_start: @copy_options[:hide_series] ? nil : s.visibility_start, deadline: @copy_options[:deadlines] ? s.deadline : nil, order: s.order, - progress_enabled: s.progress_enabled + progress_enabled: s.progress_enabled, + activities_visible: s.activities_visible, + activity_numbers_enabled: s.activity_numbers_enabled ) # rubocop:enable Style/MultilineTernaryOperator end diff --git a/test/controllers/courses_controller_test.rb b/test/controllers/courses_controller_test.rb index 54f2427b9f..c9c9aed488 100644 --- a/test/controllers/courses_controller_test.rb +++ b/test/controllers/courses_controller_test.rb @@ -748,11 +748,16 @@ def with_users_signed_in(users) end test 'a course copied by a regular student should not include hidden/closed series' do - add_students - user = @students.first - user.update(permission: :staff) + user = create :user, permission: :staff course = create :course - _series = create :series, course: course, visibility: :hidden + course.enrolled_members << user + create :series, course: course, visibility: :hidden + create :series, course: course, visibility: :closed + create :series, course: course, visibility: :timed, visibility_start: 1.day.from_now + create :series, course: course, visibility: :timed, visibility_start: 1.day.ago + create :series, course: course, visibility: :open + + assert_equal 5, course.reload.series.count sign_in user new_course = build :course @@ -761,6 +766,50 @@ def with_users_signed_in(users) assert_equal 0, Course.find(response.parsed_body['id']).series.count end + test 'a copied course should contain all series with the same advanced settings' do + user = create :user, permission: :staff + course = create :course + course.administrating_members << user + create :series, course: course, progress_enabled: false, activities_visible: false, activity_numbers_enabled: true, name: 'foo' + create :series, course: course, progress_enabled: true, activities_visible: true, activity_numbers_enabled: false, name: 'bar' + + sign_in user + new_course = build :course + post courses_url, params: { course: { name: new_course.name, description: new_course.description, visibility: new_course.visibility, registration: new_course.registration, teacher: new_course.teacher }, copy_options: { base_id: course.id }, format: :json } + new_course = Course.find(response.parsed_body['id']) + + assert_equal 2, new_course.series.count + + new_course.series.zip(course.series).each do |series, original_series| + assert_equal original_series.name, series.name + assert_equal original_series.progress_enabled, series.progress_enabled + assert_equal original_series.activities_visible, series.activities_visible + assert_equal original_series.activity_numbers_enabled, series.activity_numbers_enabled + end + end + + test 'a copied course should maintain the same series order' do + user = create :user, permission: :staff + course = create :course + course.administrating_members << user + create :series, course: course, name: 'second' + create :series, course: course, name: 'first' + create :series, course: course, name: 'third', order: 1 + create :series, course: course, name: 'fifth', order: 3 + create :series, course: course, name: 'fourth', order: 2 + + sign_in user + new_course = build :course + post courses_url, params: { course: { name: new_course.name, description: new_course.description, visibility: new_course.visibility, registration: new_course.registration, teacher: new_course.teacher }, copy_options: { base_id: course.id }, format: :json } + new_course = Course.find(response.parsed_body['id']) + + assert_equal course.series.pluck(:name), new_course.series.pluck(:name) + new_course.series.zip(course.series).each do |series, original_series| + assert_equal original_series.name, series.name + assert_equal original_series.order, series.order + end + end + test 'hidden course page shown to unsubscribed student should include registration url with secret' do add_externals @course.update(visibility: :hidden) From 81b2a0bcff27399551cbedb92ac2ad72d46bd549 Mon Sep 17 00:00:00 2001 From: jorg-vr Date: Wed, 8 Jan 2025 15:48:41 +0100 Subject: [PATCH 2/4] Update test/controllers/courses_controller_test.rb Co-authored-by: Bart Mesuere --- test/controllers/courses_controller_test.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/controllers/courses_controller_test.rb b/test/controllers/courses_controller_test.rb index c9c9aed488..4ec71d0ccc 100644 --- a/test/controllers/courses_controller_test.rb +++ b/test/controllers/courses_controller_test.rb @@ -747,7 +747,7 @@ def with_users_signed_in(users) assert_includes course.subscribed_members, user end - test 'a course copied by a regular student should not include hidden/closed series' do + test 'a course copied by staff who isn't course admin should not include hidden/closed series' do user = create :user, permission: :staff course = create :course course.enrolled_members << user From 71f001708c80027a32d7d24100ebeb407dc86216 Mon Sep 17 00:00:00 2001 From: "jorg.vr" Date: Wed, 8 Jan 2025 15:51:08 +0100 Subject: [PATCH 3/4] Fix unfinished string --- test/controllers/courses_controller_test.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/controllers/courses_controller_test.rb b/test/controllers/courses_controller_test.rb index 4ec71d0ccc..e59facfcc2 100644 --- a/test/controllers/courses_controller_test.rb +++ b/test/controllers/courses_controller_test.rb @@ -747,7 +747,7 @@ def with_users_signed_in(users) assert_includes course.subscribed_members, user end - test 'a course copied by staff who isn't course admin should not include hidden/closed series' do + test "a course copied by staff who isn't course admin should not include hidden/closed series" do user = create :user, permission: :staff course = create :course course.enrolled_members << user From 0758cef600329d361eb1dd8582de276c89f05b07 Mon Sep 17 00:00:00 2001 From: "jorg.vr" Date: Wed, 8 Jan 2025 15:52:43 +0100 Subject: [PATCH 4/4] Fully fix test --- test/controllers/courses_controller_test.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/controllers/courses_controller_test.rb b/test/controllers/courses_controller_test.rb index e59facfcc2..f62669b2ec 100644 --- a/test/controllers/courses_controller_test.rb +++ b/test/controllers/courses_controller_test.rb @@ -763,7 +763,7 @@ def with_users_signed_in(users) new_course = build :course post courses_url, params: { course: { name: new_course.name, description: new_course.description, visibility: new_course.visibility, registration: new_course.registration, teacher: new_course.teacher }, copy_options: { base_id: course.id }, format: :json } - assert_equal 0, Course.find(response.parsed_body['id']).series.count + assert_equal 2, Course.find(response.parsed_body['id']).series.count end test 'a copied course should contain all series with the same advanced settings' do