19217: Silence SQL logs during database reset.
authorTom Clegg <tom@curii.com>
Mon, 27 Jun 2022 13:38:19 +0000 (09:38 -0400)
committerTom Clegg <tom@curii.com>
Mon, 27 Jun 2022 13:38:19 +0000 (09:38 -0400)
Arvados-DCO-1.1-Signed-off-by: Tom Clegg <tom@curii.com>

services/api/app/controllers/database_controller.rb

index 5c4cf7bc16c22ad8d8780714d9b0165cf2c4043b..fa1e1ca43c64dc0b98a0587e703f0a075e890dae 100644 (file)
@@ -6,6 +6,8 @@ class DatabaseController < ApplicationController
   skip_before_action :find_object_by_uuid
   skip_before_action :render_404_if_no_object
   before_action :admin_required
+  around_action :silence_logs, only: [:reset]
+
   def reset
     raise ArvadosModel::PermissionDeniedError unless Rails.env == 'test'
 
@@ -83,4 +85,17 @@ class DatabaseController < ApplicationController
     # Done.
     send_json success: true
   end
+
+  protected
+
+  def silence_logs
+    Rails.logger.info("(logging level temporarily raised to :error, see #{__FILE__})")
+    orig = ActiveRecord::Base.logger.level
+    ActiveRecord::Base.logger.level = :error
+    begin
+      yield
+    ensure
+      ActiveRecord::Base.logger.level = orig
+    end
+  end
 end