arlequin 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 64dab272387e862b66546a8de88779cc36ffbdfaa0a6082125b8404509fec181
4
+ data.tar.gz: 0c1d6fe9c4af985484476e81645ce54a1a1391ed19765276dd9d1915bc12b514
5
+ SHA512:
6
+ metadata.gz: 6dab0e3d89077eccf1a50591045e75720bade0b638ff4ab5c2e892c7297b6b12c314cdb25047094b50ac4a45895e18ebb6e2a742409dc290cb7d8620fa911995
7
+ data.tar.gz: 194ba82a1169e3abec5d4114bd1fae8e3c51b169103f8ae3c2ae8fea8cb4bedc596e0681fbb75840fa6b94f0ea34e1e8acf431eb71e6ddf5efb9097fca91f503
@@ -0,0 +1,40 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Arlequin
4
+ class Middleware
5
+ def initialize(app)
6
+ @app = app
7
+ end
8
+
9
+ def call(env)
10
+ # Set up a query counter
11
+ @queries = Hash.new { |hash, key| hash[key] = 0 }
12
+
13
+ ActiveSupport::Notifications.subscribe("sql.active_record", &method(:on_sql))
14
+
15
+ status, headers, response = @app.call(env)
16
+
17
+ # Detect and log N+1 queries
18
+ log_n_plus_one_warnings
19
+
20
+ [ status, headers, response ]
21
+ end
22
+
23
+ private
24
+
25
+ def on_sql(_name, _start, _finish, _id, payload)
26
+ return if payload[:name] == "SCHEMA" # Skip schema queries
27
+
28
+ query = payload[:sql]
29
+ @queries[query] += 1
30
+ end
31
+
32
+ def log_n_plus_one_warnings
33
+ @queries.each do |query, count|
34
+ if count > 1
35
+ Rails.logger.warn("N+1 query detected: #{query}, executed #{count} times")
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
data/lib/arlequin.rb ADDED
@@ -0,0 +1,9 @@
1
+ # frozen_string_literal: true
2
+
3
+ class Arlequin
4
+ class Railtie < Rails::Railtie
5
+ initializer "arlequin.configure_rails_initialization" do |app|
6
+ app.middleware.use Arlequin::Middleware
7
+ end
8
+ end
9
+ end
metadata ADDED
@@ -0,0 +1,58 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: arlequin
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Dominic Goulet
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2024-07-10 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rails
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '5.0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '5.0'
27
+ description: Performance Logger Gem
28
+ email: dominic.goulet@gmail.com
29
+ executables: []
30
+ extensions: []
31
+ extra_rdoc_files: []
32
+ files:
33
+ - lib/arlequin.rb
34
+ - lib/arlequin/middleware.rb
35
+ homepage: https://rubygems.org/gems/arlequin
36
+ licenses:
37
+ - MIT
38
+ metadata: {}
39
+ post_install_message:
40
+ rdoc_options: []
41
+ require_paths:
42
+ - lib
43
+ required_ruby_version: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ required_rubygems_version: !ruby/object:Gem::Requirement
49
+ requirements:
50
+ - - ">="
51
+ - !ruby/object:Gem::Version
52
+ version: '0'
53
+ requirements: []
54
+ rubygems_version: 3.4.19
55
+ signing_key:
56
+ specification_version: 4
57
+ summary: Arlequin performance logger gem
58
+ test_files: []