Project

General

Profile

Actions

Defect #39760

closed

Some API tests fail with Ruby 2.7

Added by Go MAEDA 9 months ago. Updated 9 months ago.

Status:
Closed
Priority:
Normal
Category:
REST API
Target version:
-
Start date:
Due date:
% Done:

0%

Estimated time:
Resolution:
Fixed
Affected version:

Description

In the current trunk r22493, the following three API tests fail if you run tests with Ruby 2.7.

Failure:
Redmine::ApiTest::MyTest#test_GET_/my/account.json_should_return_user [/path/to/redmine/test/integration/api_test/my_test.rb:30]:
Expected: "application/json" 
  Actual: "text/html" 

bin/rails test test/integration/api_test/my_test.rb:25
Failure:
Redmine::ApiTest::NewsTest#test_GET_/news/:id.json [/path/to/redmine/test/integration/api_test/news_test.rb:84]:
Expected: "application/json" 
  Actual: "text/html" 

bin/rails test test/integration/api_test/news_test.rb:81
Failure:
Redmine::ApiTest::NewsTest#test_GET_/news/:id.xml [/path/to/redmine/test/integration/api_test/news_test.rb:69]:
Expected: "application/xml" 
  Actual: "text/html" 

bin/rails test test/integration/api_test/news_test.rb:66

Related issues

Related to Redmine - Feature #36320: Migrate to Rails 7.2ClosedMarius BĂLTEANU

Actions
Actions #1

Updated by Go MAEDA 9 months ago

I found the following change fixes the errors.

diff --git a/app/controllers/my_controller.rb b/app/controllers/my_controller.rb
index 860a91f06..7f1f2180f 100644
--- a/app/controllers/my_controller.rb
+++ b/app/controllers/my_controller.rb
@@ -69,6 +69,11 @@ class MyController < ApplicationController
           format.api  {render_validation_errors(@user)}
         end
       end
+    else
+      respond_to do |format|
+        format.html
+        format.api
+      end
     end
   end

diff --git a/app/controllers/news_controller.rb b/app/controllers/news_controller.rb
index a4c48614f..3f1a13ab1 100644
--- a/app/controllers/news_controller.rb
+++ b/app/controllers/news_controller.rb
@@ -69,6 +69,11 @@ class NewsController < ApplicationController
   def show
     @comments = @news.comments.to_a
     @comments.reverse! if User.current.wants_comments_in_reverse_order?
+
+    respond_to do |format|
+      format.html
+      format.api
+    end
   end

   def new
Actions #2

Updated by Minoru Maeda 9 months ago

Thank you for the insightful report. I appreciate the detailed information, which has helped me understand the main problem.

In Ruby 2.7, some API tests fail due to changes in how Module#include and Module#prepend work from Ruby 3.0 onwards. In Ruby 2.7, the order in which modules are included affects whether include/prepend functions properly in certain cases. This issue is related to https://bugs.ruby-lang.org/issues/9573 .

Since trunk revision r22488, ActionView::Rendering has been prepended with an anonymous module in config/initializers/10-patches.rb. However, ActionView::Rendering is already included in ActionController::Base. Thus, in Ruby 2.7, prepending ActionView::Rendering at the beginning with this anonymous module seems to be ineffective, and the API tests fail to produce the expected context-type.

Implementing the following changes will allow the API tests to pass in Ruby 2.7.

diff --git a/config/initializers/10-patches.rb b/config/initializers/10-patches.rb
index adac86583..7694fb60d 100644
--- a/config/initializers/10-patches.rb
+++ b/config/initializers/10-patches.rb
@@ -148,8 +148,9 @@ module ActionView
       super values
     end
   end)
-
-  Rendering.prepend(Module.new do
+end
+module ActionController
+  Base.prepend(Module.new do
     def rendered_format
       if lookup_context.formats.first == :api
         return request.format

I hope this proves helpful.

Actions #3

Updated by Marius BĂLTEANU 9 months ago

Actions #4

Updated by Marius BĂLTEANU 9 months ago

  • Status changed from New to Closed
  • Assignee set to Marius BĂLTEANU
  • Resolution set to Fixed

Committed, thanks!

Actions

Also available in: Atom PDF