From 005f71e2c2e79ba346c60a9958b0da1c8322bfb9 Mon Sep 17 00:00:00 2001 From: Benjamin Fleischer Date: Fri, 28 Aug 2015 00:00:07 -0500 Subject: [PATCH] Add ActiveModelSerializers.logger with default null device --- lib/active_model/serializer/railtie.rb | 6 ++++++ lib/active_model_serializers.rb | 11 ++++++++--- test/logger_test.rb | 19 +++++++++++++++++++ 3 files changed, 33 insertions(+), 3 deletions(-) create mode 100644 test/logger_test.rb diff --git a/lib/active_model/serializer/railtie.rb b/lib/active_model/serializer/railtie.rb index 88878a28a..cade0354e 100644 --- a/lib/active_model/serializer/railtie.rb +++ b/lib/active_model/serializer/railtie.rb @@ -1,6 +1,12 @@ require 'rails/railtie' module ActiveModel class Railtie < Rails::Railtie + initializer 'active_model_serializers.logger' do + ActiveSupport.on_load(:action_controller) do + ActiveModelSerializers.logger = ActionController::Base.logger + end + end + initializer 'generators' do |app| app.load_generators require 'generators/serializer/resource_override' diff --git a/lib/active_model_serializers.rb b/lib/active_model_serializers.rb index 8b90ba7a9..02b9c592d 100644 --- a/lib/active_model_serializers.rb +++ b/lib/active_model_serializers.rb @@ -1,4 +1,12 @@ +require 'logger' +require 'active_model' +require "active_support/railtie" +require 'action_controller' +require "action_controller/railtie" module ActiveModelSerializers + mattr_accessor :logger + self.logger = Rails.logger || Logger.new(IO::NULL) + module_function def silence_warnings @@ -11,9 +19,6 @@ def silence_warnings end -require 'active_model' -require 'action_controller' - require 'active_model/serializer' require 'active_model/serializable_resource' require 'active_model/serializer/version' diff --git a/test/logger_test.rb b/test/logger_test.rb new file mode 100644 index 000000000..c92614353 --- /dev/null +++ b/test/logger_test.rb @@ -0,0 +1,19 @@ +require 'test_helper' + +class ActiveModelSerializers::LoggerTest < Minitest::Test + + def test_logger_is_set_to_action_controller_logger_when_initializer_runs + assert_equal ActiveModelSerializers.logger, ActionController::Base.logger + end + + def test_logger_can_be_set + original_logger = ActiveModelSerializers.logger + logger = Logger.new(STDOUT) + + ActiveModelSerializers.logger = logger + + assert_equal ActiveModelSerializers.logger, logger + ensure + ActiveModelSerializers.logger = original_logger + end +end