aboutsummaryrefslogtreecommitdiffstats
path: root/railties/test/application/rake/initializers_test.rb
blob: 8de496702131908db8f80a1914a4be19781f06e4 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# frozen_string_literal: true

require "isolation/abstract_unit"

module ApplicationTests
  module RakeTests
    class RakeInitializersTest < ActiveSupport::TestCase
      setup :build_app
      teardown :teardown_app

      test "`rake initializers` prints out defined initializers invoked by Rails" do
        capture(:stderr) do
          initial_output = run_rake_initializers
          initial_output_length = initial_output.split("\n").length

          assert_operator initial_output_length, :>, 0
          assert_not initial_output.include?("set_added_test_module")

          add_to_config <<-RUBY
            initializer(:set_added_test_module) { }
          RUBY

          final_output = run_rake_initializers
          final_output_length = final_output.split("\n").length

          assert_equal 1, (final_output_length - initial_output_length)
          assert final_output.include?("set_added_test_module")
        end
      end

      test "`rake initializers` outputs a deprecation warning" do
        add_to_env_config("development", "config.active_support.deprecation = :stderr")

        stderr = capture(:stderr) { run_rake_initializers }
        assert_match(/DEPRECATION WARNING: Using `bin\/rake initializers` is deprecated and will be removed in Rails 6.1/, stderr)
      end

      private
        def run_rake_initializers
          Dir.chdir(app_path) { `bin/rake initializers` }
        end
    end
  end
end