memhealth 0.1.2 → 0.1.4

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 5fda50a609f167feffba18ed772f70c528fe8ae883605520a8b51283ea9e45af
4
- data.tar.gz: 30bb76d54747594b6fe1b2b9432759a53f201b2ed8b6e5852a78fe7775f654a1
3
+ metadata.gz: 6937ace9f7a2407974057577e378f9433bb891c4d848779f80da32e4eb32703d
4
+ data.tar.gz: 70534a9390c32d9e0cdc1e318caee705ca82a3a93042625876978b72ed8c3079
5
5
  SHA512:
6
- metadata.gz: 2d69b6f4a6f3341f1eb02f64301d690479788fbd6de6e8ef65e9da88ce40c709af7743c685d290d42e020003d67bd093318ed6189ebe722fa1a37eb25017a800
7
- data.tar.gz: 9160e5176c77f8d06e3f6ade37ecc39b0ba171829370eb93f33b332b51c775096c403aba3cd52e977b17912fc33123d8f9ba2b9d47da73aaf47138bab8c98072
6
+ metadata.gz: 2d10a9cee1ea390ee7b55a121fdc94f4f38086eb5ab1cdbad53e1cbf71d2e1b7355d8689d30f7774ce494df25c261e5f27cfce357d594255d279e5d9149307c9
7
+ data.tar.gz: 6aea016d4c158e2554317c531a44314bf650b87623bea24b604e252cf74b3bc3cb10339b5a6209c7d952e2c494270159c6d120f4b9f7a1f74c853e9429dae86a
@@ -30,8 +30,14 @@ module MemHealth
30
30
  private
31
31
 
32
32
  def extract_job_class(worker, job)
33
- # For ActiveJob jobs, extract the actual job class from the wrapper
34
- if worker.class.name == 'ActiveJob::QueueAdapters::SidekiqAdapter::JobWrapper'
33
+ # For ActiveJob jobs, extract the actual job class from the wrapper.
34
+ # Detect via the payload's "wrapped" key rather than the wrapper's class
35
+ # name: on Sidekiq 7+/Rails 7.1+ the old
36
+ # ActiveJob::QueueAdapters::SidekiqAdapter::JobWrapper constant is just an
37
+ # alias whose #name resolves to "Sidekiq::ActiveJob::Wrapper", so the old
38
+ # string comparison never matched and every job was mislabeled as the
39
+ # wrapper. The "wrapped" key is what the sibling extractors key off too.
40
+ if job['wrapped'] # ActiveJob
35
41
  job['wrapped'] || job['args']&.first&.dig('job_class') || worker.class.name
36
42
  else
37
43
  worker.class.name
@@ -4,6 +4,7 @@ module MemHealth
4
4
 
5
5
  @@request_count = 0
6
6
  @@skipped_requests_count = 0
7
+ @@counter_mutex = Mutex.new
7
8
 
8
9
  def self.redis_tracked_requests_key
9
10
  "#{MemHealth.configuration.redis_key_prefix}:tracked_requests"
@@ -14,12 +15,13 @@ module MemHealth
14
15
  end
15
16
 
16
17
  def call(env)
17
- @@request_count += 1
18
+ @@counter_mutex.synchronize { @@request_count += 1 }
18
19
 
19
20
  request = Rack::Request.new(env)
20
21
 
22
+ status = headers = response = nil
21
23
  metrics = measure_memory do
22
- @status, @headers, @response = @app.call(env)
24
+ status, headers, response = @app.call(env)
23
25
  end
24
26
 
25
27
  # Skip the first few requests as they have large memory jumps due to class loading
@@ -40,15 +42,17 @@ module MemHealth
40
42
  metadata.merge(execution_time: metrics[:execution_time]), type: :web)
41
43
  end
42
44
  else
43
- @@skipped_requests_count += 1
45
+ @@counter_mutex.synchronize { @@skipped_requests_count += 1 }
44
46
  end
45
47
 
46
- [@status, @headers, @response]
48
+ [status, headers, response]
47
49
  end
48
50
 
49
51
  def self.reset_data
50
- @@request_count = 0
51
- @@skipped_requests_count = 0
52
+ @@counter_mutex.synchronize do
53
+ @@request_count = 0
54
+ @@skipped_requests_count = 0
55
+ end
52
56
  MemHealth.configuration.redis.del(redis_tracked_requests_key)
53
57
  end
54
58
 
@@ -1,3 +1,3 @@
1
1
  module MemHealth
2
- VERSION = '0.1.2'
2
+ VERSION = '0.1.4'
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: memhealth
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.2
4
+ version: 0.1.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Klemen Nagode
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-10-01 00:00:00.000000000 Z
11
+ date: 2026-06-04 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails