eager_eye 1.1.11 → 1.1.13

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: 200f52cfc9b2d47ee338155372eded81c115c5c05578e6ff89e689f148fabac5
4
- data.tar.gz: 3b236fff4d78662c30140b3e429d222defed03100b2c8d6928711886bd7c525a
3
+ metadata.gz: 2016440524db060dc267545c436a7f3ed33958efc344bba2a6c14b94a69dd0a3
4
+ data.tar.gz: 61961e507f36c1929f0d1d68a8b05ec8169667aac2e8f941e155d94af01d011f
5
5
  SHA512:
6
- metadata.gz: 8a09fbc10c6f944c9c42f31723dc0bf248eff29691a35fbc31f6a4e21836224225863eb625ac33e818a30b2e12b119831e02ec2f0d0689476e014a9ab0d5331e
7
- data.tar.gz: 36dff575a0277abc141848a1866a057f31fcefe6fdecd861a32fcad7120167a56120f0ed8a507c9ff9fdcb4ac54be72be64a475ca0b5105574ace91e26618f8b
6
+ metadata.gz: 9ff57ccdd2efe4fa5cf526a6833caa534e429cf45b84ac5e8e578b1bc280d088ec0aa65553879da5d654561a963b80d7381928fcb8e2275060d78271600b8468
7
+ data.tar.gz: ccc2892f3bfb35d89fd2a2b2b7976e80ecae008d9341f93231a1e23fc4d444a614402253e28d1c2f6b3e8a4bab8c5c5d42ae8e6c4ad22d888f9aef0315f1f895
data/CHANGELOG.md CHANGED
@@ -7,6 +7,22 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [1.1.13] - 2026-01-16
11
+
12
+ ### Fixed
13
+
14
+ - **CustomMethodQuery False Positive** - Skip `.ids` on SQL alias attributes
15
+ - `s_eod.ids` no longer flagged when `ids` is a SQL alias (e.g., `select('array_agg(...) AS ids')`)
16
+ - Deep chains like `item.comments.ids` still correctly detected
17
+
18
+ ## [1.1.12] - 2026-01-15
19
+
20
+ ### Fixed
21
+
22
+ - **CustomMethodQuery Stack Overflow** - Fix infinite recursion in `collection_is_array?`
23
+ - Added `visited` Set to track already-visited nodes and prevent cyclic traversal
24
+ - Fixes `stack level too deep` error on complex method chains
25
+
10
26
  ## [1.1.11] - 2026-01-13
11
27
 
12
28
  ### Fixed
data/README.md CHANGED
@@ -10,7 +10,7 @@
10
10
 
11
11
  <p align="center">
12
12
  <a href="https://github.com/hamzagedikkaya/eager_eye/actions/workflows/main.yml"><img src="https://github.com/hamzagedikkaya/eager_eye/actions/workflows/main.yml/badge.svg" alt="CI"></a>
13
- <a href="https://rubygems.org/gems/eager_eye"><img src="https://img.shields.io/badge/gem-v1.1.11-red.svg" alt="Gem Version"></a>
13
+ <a href="https://rubygems.org/gems/eager_eye"><img src="https://img.shields.io/badge/gem-v1.1.13-red.svg" alt="Gem Version"></a>
14
14
  <a href="https://github.com/hamzagedikkaya/eager_eye"><img src="https://img.shields.io/badge/coverage-95%25-brightgreen.svg" alt="Coverage"></a>
15
15
  <a href="https://www.ruby-lang.org/"><img src="https://img.shields.io/badge/ruby-%3E%3D%203.1-ruby.svg" alt="Ruby"></a>
16
16
  <a href="https://opensource.org/licenses/MIT"><img src="https://img.shields.io/badge/License-MIT-yellow.svg" alt="License: MIT"></a>
@@ -5,7 +5,7 @@ module EagerEye
5
5
  class CustomMethodQuery < Base
6
6
  QUERY_METHODS = %i[where find_by find_by! exists? find first last take pluck ids count sum average minimum
7
7
  maximum].freeze
8
- SAFE_QUERY_METHODS = %i[first last take count sum find size length].freeze
8
+ SAFE_QUERY_METHODS = %i[first last take count sum find size length ids].freeze
9
9
  SAFE_TRANSFORM_METHODS = %i[keys values split [] params sort pluck ids to_s to_a to_i chars bytes].freeze
10
10
  ITERATION_METHODS = %i[each map select find_all reject collect detect find_index flat_map].freeze
11
11
 
@@ -93,28 +93,32 @@ module EagerEye
93
93
  first_arg&.type == :arg ? first_arg.children[0] : nil
94
94
  end
95
95
 
96
- def collection_is_array?(node, definitions = {})
96
+ def collection_is_array?(node, definitions = {}, visited = Set.new)
97
97
  return false unless node.is_a?(Parser::AST::Node)
98
+ return false if visited.include?(node.object_id)
99
+
100
+ visited.add(node.object_id)
101
+
98
102
  return true if %i[array hash].include?(node.type)
99
- return check_lvar_collection?(node, definitions) if node.type == :lvar
100
- return check_send_collection?(node, definitions) if node.type == :send
103
+ return check_lvar_collection?(node, definitions, visited) if node.type == :lvar
104
+ return check_send_collection?(node, definitions, visited) if node.type == :send
101
105
 
102
106
  false
103
107
  end
104
108
 
105
- def check_lvar_collection?(node, definitions)
109
+ def check_lvar_collection?(node, definitions, visited)
106
110
  return false unless definitions
107
111
 
108
112
  definition = definitions[node.children[0]]
109
- definition ? collection_is_array?(definition, definitions) : false
113
+ definition ? collection_is_array?(definition, definitions, visited) : false
110
114
  end
111
115
 
112
- def check_send_collection?(node, definitions)
116
+ def check_send_collection?(node, definitions, visited)
113
117
  method_name = node.children[1]
114
118
  return true if %i[map select collect flat_map uniq compact].include?(method_name)
115
119
  return true if SAFE_TRANSFORM_METHODS.include?(method_name)
116
120
 
117
- collection_is_array?(node.children[0], definitions)
121
+ collection_is_array?(node.children[0], definitions, visited)
118
122
  end
119
123
 
120
124
  def receiver_ends_with_safe_transform_method?(node)
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module EagerEye
4
- VERSION = "1.1.11"
4
+ VERSION = "1.1.13"
5
5
  end
data/lib/eager_eye.rb CHANGED
@@ -1,5 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require "set"
3
4
  require_relative "eager_eye/version"
4
5
  require_relative "eager_eye/configuration"
5
6
  require_relative "eager_eye/issue"
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: eager_eye
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.1.11
4
+ version: 1.1.13
5
5
  platform: ruby
6
6
  authors:
7
7
  - hamzagedikkaya
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2026-01-13 00:00:00.000000000 Z
11
+ date: 2026-01-16 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: ast