77d384d
From df0de681dc1873534ecd2fc8371e1f2562984b68 Mon Sep 17 00:00:00 2001
77d384d
From: John Crepezzi <john.crepezzi@gmail.com>
77d384d
Date: Thu, 16 Jun 2022 08:34:05 -0400
77d384d
Subject: [PATCH] Remove the multi-call form of assert_called_with
77d384d
77d384d
The `assert_called_with` helper allows passing a multi-dimensional array to
77d384d
mock multiple calls to the same method for a given block. This works
77d384d
fine now, but when adding support for real kwargs arguments to line up with
77d384d
recent upgrades in Minitest, this approach is no longer workable because
77d384d
we can't pass multiple sets of differing kwargs.
77d384d
77d384d
Rather than complicated this method further, this commit removes the
77d384d
multi-call form of `assert_called_with` and modifies the tests that
77d384d
currently make use of that functionality to just use the underlying
77d384d
`Minitest::Mock` calls.
77d384d
77d384d
Co-authored-by: Eileen M. Uchitelle <eileencodes@gmail.com>
77d384d
---
77d384d
 .../test/cases/tasks/database_tasks_test.rb   | 71 ++++++++---------
77d384d
 .../test/cases/tasks/mysql_rake_test.rb       | 15 ++--
77d384d
 .../test/cases/tasks/postgresql_rake_test.rb  | 76 +++++++------------
77d384d
 3 files changed, 72 insertions(+), 90 deletions(-)
77d384d
77d384d
diff --git a/activerecord/test/cases/tasks/database_tasks_test.rb b/activerecord/test/cases/tasks/database_tasks_test.rb
77d384d
index 70c378c6680a9..9aa4da54d889a 100644
77d384d
--- a/activerecord/test/cases/tasks/database_tasks_test.rb
77d384d
+++ b/activerecord/test/cases/tasks/database_tasks_test.rb
77d384d
@@ -39,6 +39,16 @@ def with_stubbed_new(&block)
77d384d
     end
77d384d
   end
77d384d
 
77d384d
+  module DatabaseTasksHelper
77d384d
+    def assert_called_for_configs(method_name, configs, &block)
77d384d
+      mock = Minitest::Mock.new
77d384d
+      configs.each { |config| mock.expect(:call, nil, config) }
77d384d
+
77d384d
+      ActiveRecord::Tasks::DatabaseTasks.stub(method_name, mock, &block)
77d384d
+      assert_mock(mock)
77d384d
+    end
77d384d
+  end
77d384d
+
77d384d
   ADAPTERS_TASKS = {
77d384d
     mysql2:     :mysql_tasks,
77d384d
     postgresql: :postgresql_tasks,
77d384d
@@ -368,6 +378,8 @@ def with_stubbed_configurations_establish_connection(&block)
77d384d
   end
77d384d
 
77d384d
   class DatabaseTasksCreateCurrentTest < ActiveRecord::TestCase
77d384d
+    include DatabaseTasksHelper
77d384d
+
77d384d
     def setup
77d384d
       @configurations = {
77d384d
         "development" => { "database" => "dev-db" },
77d384d
@@ -406,8 +418,7 @@ def test_creates_current_environment_database_with_url
77d384d
 
77d384d
     def test_creates_test_and_development_databases_when_env_was_not_specified
77d384d
       with_stubbed_configurations_establish_connection do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :create,
77d384d
           [
77d384d
             [config_for("development", "primary")],
77d384d
@@ -426,8 +437,7 @@ def test_creates_test_and_development_databases_when_rails_env_is_development
77d384d
       ENV["RAILS_ENV"] = "development"
77d384d
 
77d384d
       with_stubbed_configurations_establish_connection do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :create,
77d384d
           [
77d384d
             [config_for("development", "primary")],
77d384d
@@ -449,8 +459,7 @@ def test_creates_development_database_without_test_database_when_skip_test_datab
77d384d
       ENV["SKIP_TEST_DATABASE"] = "true"
77d384d
 
77d384d
       with_stubbed_configurations_establish_connection do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :create,
77d384d
           [
77d384d
             [config_for("development", "primary")]
77d384d
@@ -492,6 +501,8 @@ def with_stubbed_configurations_establish_connection(&block)
77d384d
   end
77d384d
 
77d384d
   class DatabaseTasksCreateCurrentThreeTierTest < ActiveRecord::TestCase
77d384d
+    include DatabaseTasksHelper
77d384d
+
77d384d
     def setup
77d384d
       @configurations = {
77d384d
         "development" => { "primary" => { "database" => "dev-db" }, "secondary" => { "database" => "secondary-dev-db" } },
77d384d
@@ -502,8 +513,7 @@ def setup
77d384d
 
77d384d
     def test_creates_current_environment_database
77d384d
       with_stubbed_configurations_establish_connection do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :create,
77d384d
           [
77d384d
             [config_for("test", "primary")],
77d384d
@@ -519,8 +529,7 @@ def test_creates_current_environment_database
77d384d
 
77d384d
     def test_creates_current_environment_database_with_url
77d384d
       with_stubbed_configurations_establish_connection do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :create,
77d384d
           [
77d384d
             [config_for("production", "primary")],
77d384d
@@ -536,8 +545,7 @@ def test_creates_current_environment_database_with_url
77d384d
 
77d384d
     def test_creates_test_and_development_databases_when_env_was_not_specified
77d384d
       with_stubbed_configurations_establish_connection do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :create,
77d384d
           [
77d384d
             [config_for("development", "primary")],
77d384d
@@ -558,8 +566,7 @@ def test_creates_test_and_development_databases_when_rails_env_is_development
77d384d
       ENV["RAILS_ENV"] = "development"
77d384d
 
77d384d
       with_stubbed_configurations_establish_connection do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :create,
77d384d
           [
77d384d
             [config_for("development", "primary")],
77d384d
@@ -705,6 +712,8 @@ def with_stubbed_configurations
77d384d
   end
77d384d
 
77d384d
   class DatabaseTasksDropCurrentTest < ActiveRecord::TestCase
77d384d
+    include DatabaseTasksHelper
77d384d
+
77d384d
     def setup
77d384d
       @configurations = {
77d384d
         "development" => { "database" => "dev-db" },
77d384d
@@ -743,8 +752,7 @@ def test_drops_current_environment_database_with_url
77d384d
 
77d384d
     def test_drops_test_and_development_databases_when_env_was_not_specified
77d384d
       with_stubbed_configurations do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :drop,
77d384d
           [
77d384d
             [config_for("development", "primary")],
77d384d
@@ -763,8 +771,7 @@ def test_drops_testand_development_databases_when_rails_env_is_development
77d384d
       ENV["RAILS_ENV"] = "development"
77d384d
 
77d384d
       with_stubbed_configurations do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :drop,
77d384d
           [
77d384d
             [config_for("development", "primary")],
77d384d
@@ -796,6 +803,8 @@ def with_stubbed_configurations
77d384d
   end
77d384d
 
77d384d
   class DatabaseTasksDropCurrentThreeTierTest < ActiveRecord::TestCase
77d384d
+    include DatabaseTasksHelper
77d384d
+
77d384d
     def setup
77d384d
       @configurations = {
77d384d
         "development" => { "primary" => { "database" => "dev-db" }, "secondary" => { "database" => "secondary-dev-db" } },
77d384d
@@ -806,8 +815,7 @@ def setup
77d384d
 
77d384d
     def test_drops_current_environment_database
77d384d
       with_stubbed_configurations do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :drop,
77d384d
           [
77d384d
             [config_for("test", "primary")],
77d384d
@@ -823,8 +831,7 @@ def test_drops_current_environment_database
77d384d
 
77d384d
     def test_drops_current_environment_database_with_url
77d384d
       with_stubbed_configurations do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :drop,
77d384d
           [
77d384d
             [config_for("production", "primary")],
77d384d
@@ -840,8 +847,7 @@ def test_drops_current_environment_database_with_url
77d384d
 
77d384d
     def test_drops_test_and_development_databases_when_env_was_not_specified
77d384d
       with_stubbed_configurations do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :drop,
77d384d
           [
77d384d
             [config_for("development", "primary")],
77d384d
@@ -862,8 +868,7 @@ def test_drops_testand_development_databases_when_rails_env_is_development
77d384d
       ENV["RAILS_ENV"] = "development"
77d384d
 
77d384d
       with_stubbed_configurations do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :drop,
77d384d
           [
77d384d
             [config_for("development", "primary")],
77d384d
@@ -1232,6 +1237,8 @@ class DatabaseTasksTruncateAllWithSuffixTest < DatabaseTasksTruncateAllTest
77d384d
   end
77d384d
 
77d384d
   class DatabaseTasksTruncateAllWithMultipleDatabasesTest < ActiveRecord::TestCase
77d384d
+    include DatabaseTasksHelper
77d384d
+
77d384d
     def setup
77d384d
       @configurations = {
77d384d
         "development" => { "primary" => { "database" => "dev-db" }, "secondary" => { "database" => "secondary-dev-db" } },
77d384d
@@ -1242,8 +1249,7 @@ def setup
77d384d
 
77d384d
     def test_truncate_all_databases_for_environment
77d384d
       with_stubbed_configurations do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :truncate_tables,
77d384d
           [
77d384d
             [config_for("test", "primary")],
77d384d
@@ -1259,8 +1265,7 @@ def test_truncate_all_databases_for_environment
77d384d
 
77d384d
     def test_truncate_all_databases_with_url_for_environment
77d384d
       with_stubbed_configurations do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :truncate_tables,
77d384d
           [
77d384d
             [config_for("production", "primary")],
77d384d
@@ -1276,8 +1281,7 @@ def test_truncate_all_databases_with_url_for_environment
77d384d
 
77d384d
     def test_truncate_all_development_databases_when_env_is_not_specified
77d384d
       with_stubbed_configurations do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :truncate_tables,
77d384d
           [
77d384d
             [config_for("development", "primary")],
77d384d
@@ -1296,8 +1300,7 @@ def test_truncate_all_development_databases_when_env_is_development
77d384d
       ENV["RAILS_ENV"] = "development"
77d384d
 
77d384d
       with_stubbed_configurations do
77d384d
-        assert_called_with(
77d384d
-          ActiveRecord::Tasks::DatabaseTasks,
77d384d
+        assert_called_for_configs(
77d384d
           :truncate_tables,
77d384d
           [
77d384d
             [config_for("development", "primary")],
77d384d
diff --git a/activerecord/test/cases/tasks/mysql_rake_test.rb b/activerecord/test/cases/tasks/mysql_rake_test.rb
77d384d
index 75f557444c535..5fa3c500cfc36 100644
77d384d
--- a/activerecord/test/cases/tasks/mysql_rake_test.rb
77d384d
+++ b/activerecord/test/cases/tasks/mysql_rake_test.rb
77d384d
@@ -26,18 +26,17 @@ def teardown
77d384d
       def test_establishes_connection_without_database
77d384d
         db_config = ActiveRecord::DatabaseConfigurations::HashConfig.new("default_env", "primary", @configuration)
77d384d
 
77d384d
+        mock = Minitest::Mock.new
77d384d
+        mock.expect(:call, nil, [adapter: "mysql2", database: nil])
77d384d
+        mock.expect(:call, nil, [db_config])
77d384d
+
77d384d
         ActiveRecord::Base.stub(:connection, @connection) do
77d384d
-          assert_called_with(
77d384d
-            ActiveRecord::Base,
77d384d
-            :establish_connection,
77d384d
-            [
77d384d
-              [adapter: "mysql2", database: nil],
77d384d
-              [db_config]
77d384d
-            ]
77d384d
-          ) do
77d384d
+          ActiveRecord::Base.stub(:establish_connection, mock) do
77d384d
             ActiveRecord::Tasks::DatabaseTasks.create(db_config)
77d384d
           end
77d384d
         end
77d384d
+
77d384d
+        assert_mock(mock)
77d384d
       end
77d384d
 
77d384d
       def test_creates_database_with_no_default_options
77d384d
diff --git a/activerecord/test/cases/tasks/postgresql_rake_test.rb b/activerecord/test/cases/tasks/postgresql_rake_test.rb
77d384d
index 5c5df88e96afb..3b328cb5d5603 100644
77d384d
--- a/activerecord/test/cases/tasks/postgresql_rake_test.rb
77d384d
+++ b/activerecord/test/cases/tasks/postgresql_rake_test.rb
77d384d
@@ -23,22 +23,17 @@ def teardown
77d384d
       def test_establishes_connection_to_postgresql_database
77d384d
         db_config = ActiveRecord::DatabaseConfigurations::HashConfig.new("default_env", "primary", @configuration)
77d384d
 
77d384d
+        mock = Minitest::Mock.new
77d384d
+        mock.expect(:call, nil, [{ adapter: "postgresql", database: "postgres", schema_search_path: "public" }])
77d384d
+        mock.expect(:call, nil, [db_config])
77d384d
+
77d384d
         ActiveRecord::Base.stub(:connection, @connection) do
77d384d
-          assert_called_with(
77d384d
-            ActiveRecord::Base,
77d384d
-            :establish_connection,
77d384d
-            [
77d384d
-              [
77d384d
-                adapter: "postgresql",
77d384d
-                database: "postgres",
77d384d
-                schema_search_path: "public"
77d384d
-              ],
77d384d
-              [db_config]
77d384d
-            ]
77d384d
-          ) do
77d384d
+          ActiveRecord::Base.stub(:establish_connection, mock) do
77d384d
             ActiveRecord::Tasks::DatabaseTasks.create(db_config)
77d384d
           end
77d384d
         end
77d384d
+
77d384d
+        assert_mock(mock)
77d384d
       end
77d384d
 
77d384d
       def test_creates_database_with_default_encoding
77d384d
@@ -89,22 +84,17 @@ def test_creates_database_with_given_collation_and_ctype
77d384d
       def test_establishes_connection_to_new_database
77d384d
         db_config = ActiveRecord::DatabaseConfigurations::HashConfig.new("default_env", "primary", @configuration)
77d384d
 
77d384d
+        mock = Minitest::Mock.new
77d384d
+        mock.expect(:call, nil, [{ adapter: "postgresql", database: "postgres", schema_search_path: "public" }])
77d384d
+        mock.expect(:call, nil, [db_config])
77d384d
+
77d384d
         ActiveRecord::Base.stub(:connection, @connection) do
77d384d
-          assert_called_with(
77d384d
-            ActiveRecord::Base,
77d384d
-            :establish_connection,
77d384d
-            [
77d384d
-              [
77d384d
-                adapter: "postgresql",
77d384d
-                database: "postgres",
77d384d
-                schema_search_path: "public"
77d384d
-              ],
77d384d
-              [db_config]
77d384d
-            ]
77d384d
-          ) do
77d384d
+          ActiveRecord::Base.stub(:establish_connection, mock) do
77d384d
             ActiveRecord::Tasks::DatabaseTasks.create(db_config)
77d384d
           end
77d384d
         end
77d384d
+
77d384d
+        assert_mock(mock)
77d384d
       end
77d384d
 
77d384d
       def test_db_create_with_error_prints_message
77d384d
@@ -229,22 +219,17 @@ def test_clears_active_connections
77d384d
       def test_establishes_connection_to_postgresql_database
77d384d
         db_config = ActiveRecord::DatabaseConfigurations::HashConfig.new("default_env", "primary", @configuration)
77d384d
 
77d384d
+        mock = Minitest::Mock.new
77d384d
+        mock.expect(:call, nil, [{ adapter: "postgresql", database: "postgres", schema_search_path: "public" }])
77d384d
+        mock.expect(:call, nil, [db_config])
77d384d
+
77d384d
         with_stubbed_connection do
77d384d
-          assert_called_with(
77d384d
-            ActiveRecord::Base,
77d384d
-            :establish_connection,
77d384d
-            [
77d384d
-              [
77d384d
-                adapter: "postgresql",
77d384d
-                database: "postgres",
77d384d
-                schema_search_path: "public"
77d384d
-              ],
77d384d
-              [db_config]
77d384d
-            ]
77d384d
-          ) do
77d384d
+          ActiveRecord::Base.stub(:establish_connection, mock) do
77d384d
             ActiveRecord::Tasks::DatabaseTasks.purge(db_config)
77d384d
           end
77d384d
         end
77d384d
+
77d384d
+        assert_mock(mock)
77d384d
       end
77d384d
 
77d384d
       def test_drops_database
77d384d
@@ -274,22 +259,17 @@ def test_creates_database
77d384d
       def test_establishes_connection
77d384d
         db_config = ActiveRecord::DatabaseConfigurations::HashConfig.new("default_env", "primary", @configuration)
77d384d
 
77d384d
+        mock = Minitest::Mock.new
77d384d
+        mock.expect(:call, nil, [{ adapter: "postgresql", database: "postgres", schema_search_path: "public" }])
77d384d
+        mock.expect(:call, nil, [db_config])
77d384d
+
77d384d
         with_stubbed_connection do
77d384d
-          assert_called_with(
77d384d
-            ActiveRecord::Base,
77d384d
-            :establish_connection,
77d384d
-            [
77d384d
-              [
77d384d
-                adapter: "postgresql",
77d384d
-                database: "postgres",
77d384d
-                schema_search_path: "public"
77d384d
-              ],
77d384d
-              [db_config]
77d384d
-            ]
77d384d
-          ) do
77d384d
+          ActiveRecord::Base.stub(:establish_connection, mock) do
77d384d
             ActiveRecord::Tasks::DatabaseTasks.purge(db_config)
77d384d
           end
77d384d
         end
77d384d
+
77d384d
+        assert_mock(mock)
77d384d
       end
77d384d
 
77d384d
       private