Sha256: fd20a971283968ad2839f536ec3ae58d1bf3993f7ac0e3f30d4b1d5db4438129

Contents?: true

Size: 1.99 KB

Versions: 11

Compression:

Stored size: 1.99 KB

Contents

# frozen_string_literal: true

require "rack/test"

RSpec.describe "Logging / Notifications", :app_integration do
  include Rack::Test::Methods

  let(:app) { Hanami.app }

  specify "Request logging continues even when notifications bus has already been used" do
    dir = Dir.mktmpdir

    with_tmp_directory(dir) do
      write "config/app.rb", <<~RUBY
        require "hanami"

        module TestApp
          class App < Hanami::App
            config.actions.format :json
            config.logger.options = {colorize: true}
            config.logger.stream = config.root.join("test.log")
          end
        end
      RUBY

      write "config/routes.rb", <<~RUBY
        module TestApp
          class Routes < Hanami::Routes
            post "/users", to: "users.create"
          end
        end
      RUBY

      write "app/actions/users/create.rb", <<~RUBY
        module TestApp
          module Actions
            module Users
              class Create < Hanami::Action
                def handle(req, resp)
                  resp.body = req.params.to_h.keys
                end
              end
            end
          end
        end
      RUBY

      require "hanami/prepare"

      # Simulate any component interacting with the notifications bus such that it creates its
      # internal bus with a duplicate copy of all currently registered events. This means that the
      # class-level Dry::Monitor::Notification events implicitly registered by the
      # Dry::Monitor::Rack::Middleware activated via the rack provider are ignored, unless our
      # provider explicitly re-registers them on _instance_ of the notifications bus.
      #
      # See Hanami::Providers::Rack for more detail.
      Hanami.app["notifications"].instrument(:sql)

      logs = -> { Pathname(dir).join("test.log").realpath.read }

      post "/users", JSON.generate(name: "jane", password: "secret"), {"CONTENT_TYPE" => "application/json"}
      expect(logs.()).to match %r{POST 200 \d+(µs|ms) 127.0.0.1 /}
    end
  end
end



Version data entries

11 entries across 11 versions & 1 rubygems

Version Path
hanami-2.2.1 spec/integration/logging/notifications_spec.rb
hanami-2.2.0 spec/integration/logging/notifications_spec.rb
hanami-2.2.0.rc1 spec/integration/logging/notifications_spec.rb
hanami-2.2.0.beta2 spec/integration/logging/notifications_spec.rb
hanami-2.2.0.beta1 spec/integration/logging/notifications_spec.rb
hanami-2.1.0 spec/integration/logging/notifications_spec.rb
hanami-2.1.0.rc3 spec/integration/logging/notifications_spec.rb
hanami-2.1.0.rc2 spec/integration/logging/notifications_spec.rb
hanami-2.1.0.rc1 spec/integration/logging/notifications_spec.rb
hanami-2.1.0.beta2.1 spec/integration/logging/notifications_spec.rb
hanami-2.1.0.beta2 spec/integration/logging/notifications_spec.rb