did_you_mean 0.5.0 → 0.9.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +12 -4
- data/Appraisals +6 -0
- data/Gemfile +14 -0
- data/README.md +69 -13
- data/Rakefile +47 -22
- data/did_you_mean.gemspec +3 -5
- data/docs/did_you_mean_example.png +0 -0
- data/ext/did_you_mean/extconf.rb +16 -11
- data/ext/did_you_mean/org/yukinishijima/ReceiverCapturer.java +58 -0
- data/ext/did_you_mean/ruby_headers/210/id.h +11 -9
- data/ext/did_you_mean/ruby_headers/210/version.h +6 -6
- data/ext/did_you_mean/ruby_headers/211/addr2line.h +21 -0
- data/ext/did_you_mean/ruby_headers/211/constant.h +36 -0
- data/ext/did_you_mean/ruby_headers/211/dln.h +51 -0
- data/ext/did_you_mean/ruby_headers/211/encdb.h +170 -0
- data/ext/did_you_mean/ruby_headers/211/eval_intern.h +260 -0
- data/ext/did_you_mean/ruby_headers/211/gc.h +101 -0
- data/ext/did_you_mean/ruby_headers/211/id.h +173 -0
- data/ext/did_you_mean/ruby_headers/211/internal.h +889 -0
- data/ext/did_you_mean/ruby_headers/211/iseq.h +136 -0
- data/ext/did_you_mean/ruby_headers/211/method.h +142 -0
- data/ext/did_you_mean/ruby_headers/211/node.h +543 -0
- data/ext/did_you_mean/ruby_headers/211/parse.h +183 -0
- data/ext/did_you_mean/ruby_headers/211/probes.h +83 -0
- data/ext/did_you_mean/ruby_headers/211/probes_helper.h +67 -0
- data/ext/did_you_mean/ruby_headers/211/regenc.h +223 -0
- data/ext/did_you_mean/ruby_headers/211/regint.h +911 -0
- data/ext/did_you_mean/ruby_headers/211/regparse.h +363 -0
- data/ext/did_you_mean/ruby_headers/211/revision.h +1 -0
- data/ext/did_you_mean/ruby_headers/211/ruby_atomic.h +170 -0
- data/ext/did_you_mean/ruby_headers/211/siphash.h +48 -0
- data/ext/did_you_mean/ruby_headers/211/thread_native.h +23 -0
- data/ext/did_you_mean/ruby_headers/211/thread_pthread.h +56 -0
- data/ext/did_you_mean/ruby_headers/211/thread_win32.h +45 -0
- data/ext/did_you_mean/ruby_headers/211/timev.h +42 -0
- data/ext/did_you_mean/ruby_headers/211/transcode_data.h +123 -0
- data/ext/did_you_mean/ruby_headers/211/transdb.h +190 -0
- data/ext/did_you_mean/ruby_headers/211/verconf.h +13 -0
- data/ext/did_you_mean/ruby_headers/211/version.h +52 -0
- data/ext/did_you_mean/ruby_headers/211/vm_core.h +1043 -0
- data/ext/did_you_mean/ruby_headers/211/vm_debug.h +37 -0
- data/ext/did_you_mean/ruby_headers/211/vm_exec.h +182 -0
- data/ext/did_you_mean/ruby_headers/211/vm_insnhelper.h +273 -0
- data/ext/did_you_mean/ruby_headers/211/vm_opts.h +56 -0
- data/ext/did_you_mean/ruby_headers/212/addr2line.h +21 -0
- data/ext/did_you_mean/ruby_headers/212/constant.h +36 -0
- data/ext/did_you_mean/ruby_headers/212/dln.h +51 -0
- data/ext/did_you_mean/ruby_headers/212/encdb.h +170 -0
- data/ext/did_you_mean/ruby_headers/212/eval_intern.h +260 -0
- data/ext/did_you_mean/ruby_headers/212/gc.h +101 -0
- data/ext/did_you_mean/ruby_headers/212/id.h +173 -0
- data/ext/did_you_mean/ruby_headers/212/internal.h +889 -0
- data/ext/did_you_mean/ruby_headers/212/iseq.h +136 -0
- data/ext/did_you_mean/ruby_headers/212/method.h +142 -0
- data/ext/did_you_mean/ruby_headers/212/node.h +543 -0
- data/ext/did_you_mean/ruby_headers/212/parse.h +183 -0
- data/ext/did_you_mean/ruby_headers/212/probes.h +83 -0
- data/ext/did_you_mean/ruby_headers/212/probes_helper.h +67 -0
- data/ext/did_you_mean/ruby_headers/212/regenc.h +223 -0
- data/ext/did_you_mean/ruby_headers/212/regint.h +911 -0
- data/ext/did_you_mean/ruby_headers/212/regparse.h +363 -0
- data/ext/did_you_mean/ruby_headers/212/revision.h +1 -0
- data/ext/did_you_mean/ruby_headers/212/ruby_atomic.h +170 -0
- data/ext/did_you_mean/ruby_headers/212/siphash.h +48 -0
- data/ext/did_you_mean/ruby_headers/212/thread_native.h +23 -0
- data/ext/did_you_mean/ruby_headers/212/thread_pthread.h +56 -0
- data/ext/did_you_mean/ruby_headers/212/thread_win32.h +45 -0
- data/ext/did_you_mean/ruby_headers/212/timev.h +42 -0
- data/ext/did_you_mean/ruby_headers/212/transcode_data.h +123 -0
- data/ext/did_you_mean/ruby_headers/212/transdb.h +190 -0
- data/ext/did_you_mean/ruby_headers/212/verconf.h +13 -0
- data/ext/did_you_mean/ruby_headers/212/version.h +52 -0
- data/ext/did_you_mean/ruby_headers/212/vm_core.h +1043 -0
- data/ext/did_you_mean/ruby_headers/212/vm_debug.h +37 -0
- data/ext/did_you_mean/ruby_headers/212/vm_exec.h +182 -0
- data/ext/did_you_mean/ruby_headers/212/vm_insnhelper.h +273 -0
- data/ext/did_you_mean/ruby_headers/212/vm_opts.h +56 -0
- data/ext/did_you_mean/ruby_headers/213/addr2line.h +21 -0
- data/ext/did_you_mean/ruby_headers/213/constant.h +36 -0
- data/ext/did_you_mean/ruby_headers/213/dln.h +51 -0
- data/ext/did_you_mean/ruby_headers/213/encdb.h +170 -0
- data/ext/did_you_mean/ruby_headers/213/eval_intern.h +270 -0
- data/ext/did_you_mean/ruby_headers/213/gc.h +101 -0
- data/ext/did_you_mean/ruby_headers/213/id.h +173 -0
- data/ext/did_you_mean/ruby_headers/213/internal.h +892 -0
- data/ext/did_you_mean/ruby_headers/213/iseq.h +136 -0
- data/ext/did_you_mean/ruby_headers/213/method.h +142 -0
- data/ext/did_you_mean/ruby_headers/213/node.h +543 -0
- data/ext/did_you_mean/ruby_headers/213/parse.h +183 -0
- data/ext/did_you_mean/ruby_headers/213/probes.h +83 -0
- data/ext/did_you_mean/ruby_headers/213/probes_helper.h +67 -0
- data/ext/did_you_mean/ruby_headers/213/regenc.h +223 -0
- data/ext/did_you_mean/ruby_headers/213/regint.h +911 -0
- data/ext/did_you_mean/ruby_headers/213/regparse.h +363 -0
- data/ext/did_you_mean/ruby_headers/213/revision.h +1 -0
- data/ext/did_you_mean/ruby_headers/213/ruby_atomic.h +170 -0
- data/ext/did_you_mean/ruby_headers/213/siphash.h +48 -0
- data/ext/did_you_mean/ruby_headers/213/thread_native.h +23 -0
- data/ext/did_you_mean/ruby_headers/213/thread_pthread.h +56 -0
- data/ext/did_you_mean/ruby_headers/213/thread_win32.h +45 -0
- data/ext/did_you_mean/ruby_headers/213/timev.h +42 -0
- data/ext/did_you_mean/ruby_headers/213/transcode_data.h +123 -0
- data/ext/did_you_mean/ruby_headers/213/transdb.h +190 -0
- data/ext/did_you_mean/ruby_headers/213/verconf.h +13 -0
- data/ext/did_you_mean/ruby_headers/213/version.h +52 -0
- data/ext/did_you_mean/ruby_headers/213/vm_core.h +1052 -0
- data/ext/did_you_mean/ruby_headers/213/vm_debug.h +37 -0
- data/ext/did_you_mean/ruby_headers/213/vm_exec.h +182 -0
- data/ext/did_you_mean/ruby_headers/213/vm_insnhelper.h +273 -0
- data/ext/did_you_mean/ruby_headers/213/vm_opts.h +56 -0
- data/ext/did_you_mean/ruby_headers/214/addr2line.h +21 -0
- data/ext/did_you_mean/ruby_headers/214/constant.h +36 -0
- data/ext/did_you_mean/ruby_headers/214/dln.h +51 -0
- data/ext/did_you_mean/ruby_headers/214/encdb.h +170 -0
- data/ext/did_you_mean/ruby_headers/214/eval_intern.h +270 -0
- data/ext/did_you_mean/ruby_headers/214/gc.h +101 -0
- data/ext/did_you_mean/ruby_headers/214/id.h +173 -0
- data/ext/did_you_mean/ruby_headers/214/internal.h +892 -0
- data/ext/did_you_mean/ruby_headers/214/iseq.h +136 -0
- data/ext/did_you_mean/ruby_headers/214/method.h +142 -0
- data/ext/did_you_mean/ruby_headers/214/node.h +543 -0
- data/ext/did_you_mean/ruby_headers/214/parse.h +183 -0
- data/ext/did_you_mean/ruby_headers/214/probes.h +83 -0
- data/ext/did_you_mean/ruby_headers/214/probes_helper.h +67 -0
- data/ext/did_you_mean/ruby_headers/214/regenc.h +223 -0
- data/ext/did_you_mean/ruby_headers/214/regint.h +911 -0
- data/ext/did_you_mean/ruby_headers/214/regparse.h +363 -0
- data/ext/did_you_mean/ruby_headers/214/revision.h +1 -0
- data/ext/did_you_mean/ruby_headers/214/ruby_atomic.h +170 -0
- data/ext/did_you_mean/ruby_headers/214/siphash.h +48 -0
- data/ext/did_you_mean/ruby_headers/214/thread_native.h +23 -0
- data/ext/did_you_mean/ruby_headers/214/thread_pthread.h +56 -0
- data/ext/did_you_mean/ruby_headers/214/thread_win32.h +45 -0
- data/ext/did_you_mean/ruby_headers/214/timev.h +42 -0
- data/ext/did_you_mean/ruby_headers/214/transcode_data.h +123 -0
- data/ext/did_you_mean/ruby_headers/214/transdb.h +190 -0
- data/ext/did_you_mean/ruby_headers/214/verconf.h +13 -0
- data/ext/did_you_mean/ruby_headers/214/version.h +52 -0
- data/ext/did_you_mean/ruby_headers/214/vm_core.h +1055 -0
- data/ext/did_you_mean/ruby_headers/214/vm_debug.h +37 -0
- data/ext/did_you_mean/ruby_headers/214/vm_exec.h +182 -0
- data/ext/did_you_mean/ruby_headers/214/vm_insnhelper.h +273 -0
- data/ext/did_you_mean/ruby_headers/214/vm_opts.h +56 -0
- data/ext/did_you_mean/ruby_headers/220/addr2line.h +1 -1
- data/ext/did_you_mean/ruby_headers/220/ccan/build_assert/build_assert.h +40 -0
- data/ext/did_you_mean/ruby_headers/220/ccan/check_type/check_type.h +63 -0
- data/ext/did_you_mean/ruby_headers/220/ccan/container_of/container_of.h +106 -0
- data/ext/did_you_mean/ruby_headers/220/ccan/licenses/BSD-MIT +17 -0
- data/ext/did_you_mean/ruby_headers/220/ccan/licenses/CC0 +28 -0
- data/ext/did_you_mean/ruby_headers/220/ccan/list/list.h +602 -0
- data/ext/did_you_mean/ruby_headers/220/ccan/str/str.h +16 -0
- data/ext/did_you_mean/ruby_headers/220/constant.h +10 -3
- data/ext/did_you_mean/ruby_headers/220/eval_intern.h +24 -5
- data/ext/did_you_mean/ruby_headers/220/gc.h +5 -0
- data/ext/did_you_mean/ruby_headers/220/id.h +11 -9
- data/ext/did_you_mean/ruby_headers/220/internal.h +116 -21
- data/ext/did_you_mean/ruby_headers/220/iseq.h +28 -7
- data/ext/did_you_mean/ruby_headers/220/method.h +0 -1
- data/ext/did_you_mean/ruby_headers/220/node.h +5 -4
- data/ext/did_you_mean/ruby_headers/220/regenc.h +18 -7
- data/ext/did_you_mean/ruby_headers/220/regint.h +72 -11
- data/ext/did_you_mean/ruby_headers/220/regparse.h +2 -2
- data/ext/did_you_mean/ruby_headers/220/ruby_atomic.h +2 -2
- data/ext/did_you_mean/ruby_headers/220/symbol.h +87 -0
- data/ext/did_you_mean/ruby_headers/220/thread_pthread.h +4 -6
- data/ext/did_you_mean/ruby_headers/220/thread_win32.h +0 -9
- data/ext/did_you_mean/ruby_headers/220/timev.h +2 -2
- data/ext/did_you_mean/ruby_headers/220/version.h +3 -3
- data/ext/did_you_mean/ruby_headers/220/vm_core.h +200 -65
- data/ext/did_you_mean/ruby_headers/220/vm_insnhelper.h +0 -40
- data/gemfiles/activerecord_30.gemfile +14 -0
- data/gemfiles/activerecord_31.gemfile +14 -0
- data/gemfiles/activerecord_32.gemfile +14 -0
- data/gemfiles/activerecord_40.gemfile +14 -0
- data/gemfiles/activerecord_41.gemfile +14 -0
- data/gemfiles/activerecord_42.gemfile +21 -0
- data/gemfiles/activerecord_edge.gemfile +16 -0
- data/lib/did_you_mean.rb +14 -4
- data/lib/did_you_mean/core_ext/name_error.rb +11 -44
- data/lib/did_you_mean/finders.rb +31 -0
- data/lib/did_you_mean/finders/name_error_finders.rb +24 -0
- data/lib/did_you_mean/finders/name_error_finders/similar_class_finder.rb +50 -0
- data/lib/did_you_mean/finders/name_error_finders/similar_name_finder.rb +61 -0
- data/lib/did_you_mean/finders/similar_attribute_finder.rb +26 -0
- data/lib/did_you_mean/finders/similar_method_finder.rb +42 -0
- data/lib/did_you_mean/levenshtein.rb +49 -0
- data/lib/did_you_mean/test_helper.rb +11 -0
- data/lib/did_you_mean/version.rb +1 -1
- data/lib/did_you_mean/word_collection.rb +27 -0
- data/test/all_test.rb +16 -2
- data/test/name_error_extension_test.rb +24 -0
- data/test/no_method_error_extension_test.rb +20 -0
- data/test/null_finder_test.rb +19 -0
- data/test/similar_attribute_finder_test.rb +2 -6
- data/test/similar_class_finder_test.rb +85 -0
- data/test/similar_method_finder_test.rb +16 -35
- data/test/similar_name_finder_test.rb +31 -23
- data/test/test_helper.rb +19 -11
- metadata +168 -45
- data/docs/better_errors_example.png +0 -0
- data/docs/irb_example.png +0 -0
- data/docs/rspec_example.png +0 -0
- data/lib/did_you_mean/method_finder.rb +0 -24
- data/lib/did_you_mean/strategies.rb +0 -23
- data/lib/did_you_mean/strategies/similar_attribute_finder.rb +0 -41
- data/lib/did_you_mean/strategies/similar_method_finder.rb +0 -46
- data/lib/did_you_mean/strategies/similar_name_finder.rb +0 -57
- data/test.sh +0 -18
@@ -0,0 +1,26 @@
|
|
1
|
+
module DidYouMean
|
2
|
+
class SimilarAttributeFinder
|
3
|
+
include BaseFinder
|
4
|
+
attr_reader :columns, :attribute_name
|
5
|
+
|
6
|
+
def initialize(exception)
|
7
|
+
@columns = exception.frame_binding.eval("self.class").columns
|
8
|
+
@attribute_name = (/unknown attribute(: | ')(\w+)/ =~ exception.original_message) && $2
|
9
|
+
end
|
10
|
+
|
11
|
+
def words
|
12
|
+
columns.map(&:name)
|
13
|
+
end
|
14
|
+
|
15
|
+
alias target_word attribute_name
|
16
|
+
|
17
|
+
def format(column_name)
|
18
|
+
"%{column}: %{type}" % {
|
19
|
+
column: column_name,
|
20
|
+
type: columns.detect{|c| c.name == column_name }.type
|
21
|
+
}
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
finders["ActiveRecord::UnknownAttributeError"] = SimilarAttributeFinder
|
26
|
+
end
|
@@ -0,0 +1,42 @@
|
|
1
|
+
module DidYouMean
|
2
|
+
class SimilarMethodFinder
|
3
|
+
include BaseFinder
|
4
|
+
attr_reader :method_name, :receiver
|
5
|
+
|
6
|
+
def initialize(exception)
|
7
|
+
@method_name, @receiver = exception.name, exception.args.first
|
8
|
+
end
|
9
|
+
|
10
|
+
def words
|
11
|
+
(receiver.methods + receiver.singleton_methods).uniq
|
12
|
+
end
|
13
|
+
|
14
|
+
alias target_word method_name
|
15
|
+
|
16
|
+
def format(word)
|
17
|
+
"#{separator}#{word}"
|
18
|
+
end
|
19
|
+
|
20
|
+
def class_method?
|
21
|
+
receiver.is_a? Class
|
22
|
+
end
|
23
|
+
|
24
|
+
def separator
|
25
|
+
class_method? ? "." : "#"
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
if defined?(RUBY_ENGINE)
|
30
|
+
finders["NoMethodError"] = SimilarMethodFinder
|
31
|
+
|
32
|
+
case RUBY_ENGINE
|
33
|
+
when 'ruby'
|
34
|
+
require 'did_you_mean/method_missing'
|
35
|
+
when 'jruby'
|
36
|
+
require 'did_you_mean/receiver_capturer'
|
37
|
+
org.yukinishijima.ReceiverCapturer.setup(JRuby.runtime)
|
38
|
+
else
|
39
|
+
finders.delete("NoMethodError")
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
@@ -0,0 +1,49 @@
|
|
1
|
+
module DidYouMean
|
2
|
+
module Levenshtein # :nodoc:
|
3
|
+
# This code is based directly on the Text gem implementation
|
4
|
+
# Returns a value representing the "cost" of transforming str1 into str2
|
5
|
+
def distance(str1, str2)
|
6
|
+
n = str1.length
|
7
|
+
m = str2.length
|
8
|
+
return m if n.zero?
|
9
|
+
return n if m.zero?
|
10
|
+
|
11
|
+
d = (0..m).to_a
|
12
|
+
x = nil
|
13
|
+
|
14
|
+
str1.each_char.with_index(1) do |char1, i|
|
15
|
+
str2.each_char.with_index do |char2, j|
|
16
|
+
cost = (char1 == char2) ? 0 : 1
|
17
|
+
x = min3(
|
18
|
+
d[j+1] + 1, # insertion
|
19
|
+
i + 1, # deletion
|
20
|
+
d[j] + cost # substitution
|
21
|
+
)
|
22
|
+
d[j] = i
|
23
|
+
i = x
|
24
|
+
end
|
25
|
+
d[m] = x
|
26
|
+
end
|
27
|
+
|
28
|
+
x
|
29
|
+
end
|
30
|
+
module_function :distance
|
31
|
+
|
32
|
+
private
|
33
|
+
|
34
|
+
# detects the minimum value out of three arguments. This method is
|
35
|
+
# faster than `[a, b, c].min` and puts less GC pressure.
|
36
|
+
# See https://github.com/yuki24/did_you_mean/pull/1 for a performance
|
37
|
+
# benchmark.
|
38
|
+
def min3(a, b, c)
|
39
|
+
if a < b && a < c
|
40
|
+
a
|
41
|
+
elsif b < c
|
42
|
+
b
|
43
|
+
else
|
44
|
+
c
|
45
|
+
end
|
46
|
+
end
|
47
|
+
module_function :min3
|
48
|
+
end
|
49
|
+
end
|
data/lib/did_you_mean/version.rb
CHANGED
@@ -0,0 +1,27 @@
|
|
1
|
+
require 'did_you_mean/levenshtein'
|
2
|
+
|
3
|
+
module DidYouMean
|
4
|
+
class WordCollection
|
5
|
+
include Enumerable
|
6
|
+
attr_reader :words
|
7
|
+
|
8
|
+
def initialize(words)
|
9
|
+
@words = words
|
10
|
+
end
|
11
|
+
|
12
|
+
def each(&block) words.each(&block); end
|
13
|
+
|
14
|
+
def similar_to(target_word)
|
15
|
+
target_word = target_word.to_s
|
16
|
+
threshold = threshold(target_word)
|
17
|
+
|
18
|
+
select {|word| Levenshtein.distance(word.to_s, target_word) <= threshold }
|
19
|
+
end
|
20
|
+
|
21
|
+
private
|
22
|
+
|
23
|
+
def threshold(word)
|
24
|
+
(word.size * 0.3).ceil
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
data/test/all_test.rb
CHANGED
@@ -1,3 +1,17 @@
|
|
1
|
+
require_relative 'null_finder_test'
|
2
|
+
require_relative 'name_error_extension_test'
|
1
3
|
require_relative 'similar_name_finder_test'
|
2
|
-
|
3
|
-
|
4
|
+
|
5
|
+
if defined?(RUBY_ENGINE) && %w(ruby jruby).include?(RUBY_ENGINE)
|
6
|
+
require_relative 'similar_method_finder_test'
|
7
|
+
require_relative 'no_method_error_extension_test'
|
8
|
+
else
|
9
|
+
puts "didn't run the tests for NoMethodError extension."
|
10
|
+
puts "running tests for #{RUBY_ENGINE}." if defined?(RUBY_ENGINE)
|
11
|
+
end
|
12
|
+
|
13
|
+
if defined?(ActiveRecord)
|
14
|
+
require_relative 'similar_attribute_finder_test'
|
15
|
+
end
|
16
|
+
|
17
|
+
require_relative 'similar_class_finder_test'
|
@@ -0,0 +1,24 @@
|
|
1
|
+
require_relative 'test_helper'
|
2
|
+
|
3
|
+
class NameErrorExtensionTest < Minitest::Test
|
4
|
+
class TestFinder
|
5
|
+
def initialize(*); end
|
6
|
+
def did_you_mean?; "Y U SO SLOW?"; end
|
7
|
+
end
|
8
|
+
|
9
|
+
def setup
|
10
|
+
@old_finder = DidYouMean.finders["NameError"]
|
11
|
+
DidYouMean.finders["NameError"] = TestFinder
|
12
|
+
|
13
|
+
@error = assert_raises(NameError){ doesnt_exist }
|
14
|
+
end
|
15
|
+
|
16
|
+
def teardown
|
17
|
+
DidYouMean.finders["NameError"] = @old_finder
|
18
|
+
end
|
19
|
+
|
20
|
+
def test_message?
|
21
|
+
assert_match "Y U SO SLOW?", @error.to_s
|
22
|
+
assert_match "Y U SO SLOW?", @error.message
|
23
|
+
end
|
24
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
require_relative 'test_helper'
|
2
|
+
|
3
|
+
class NoMethodErrorExtensionTest < Minitest::Test
|
4
|
+
def setup
|
5
|
+
@receiver = "receiver"
|
6
|
+
@error = assert_raises(NoMethodError) do
|
7
|
+
@receiver.doesnt_exist
|
8
|
+
end
|
9
|
+
end
|
10
|
+
|
11
|
+
def test_receiver
|
12
|
+
assert_same @receiver, @error.args.first
|
13
|
+
end
|
14
|
+
|
15
|
+
def test_extension_doesnt_break_ruby
|
16
|
+
assert_nothing_raised do
|
17
|
+
File.open('tmp/foo.txt', 'w'){|f| Array(Mail.new) }
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
require_relative 'test_helper'
|
2
|
+
|
3
|
+
class NullFinderTest < Minitest::Test
|
4
|
+
class FirstNameError < NameError; end
|
5
|
+
|
6
|
+
def setup
|
7
|
+
@error = assert_raises(FirstNameError) do
|
8
|
+
raise FirstNameError, "Other name error"
|
9
|
+
end
|
10
|
+
end
|
11
|
+
|
12
|
+
def test_did_you_mean?
|
13
|
+
assert_nil @error.did_you_mean?
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_message
|
17
|
+
refute_includes "Did you mean?", @error.message
|
18
|
+
end
|
19
|
+
end
|
@@ -7,15 +7,11 @@ class SimilarAttributeFinderTest < Minitest::Test
|
|
7
7
|
end
|
8
8
|
end
|
9
9
|
|
10
|
-
def
|
11
|
-
|
10
|
+
def test_similar_words
|
11
|
+
assert_suggestion @error.finder.similar_words, "first_name"
|
12
12
|
end
|
13
13
|
|
14
14
|
def test_did_you_mean?
|
15
15
|
assert_match "Did you mean? first_name: string", @error.did_you_mean?
|
16
16
|
end
|
17
|
-
|
18
|
-
def test_message
|
19
|
-
assert_match @error.did_you_mean?, @error.message
|
20
|
-
end
|
21
17
|
end
|
@@ -0,0 +1,85 @@
|
|
1
|
+
require_relative 'test_helper'
|
2
|
+
|
3
|
+
class Project
|
4
|
+
def self.bo0k
|
5
|
+
Bo0k
|
6
|
+
end
|
7
|
+
end
|
8
|
+
|
9
|
+
class Book
|
10
|
+
class TableOfContents; end
|
11
|
+
|
12
|
+
def tableof_contents
|
13
|
+
TableofContents
|
14
|
+
end
|
15
|
+
|
16
|
+
class Page
|
17
|
+
def tableof_contents
|
18
|
+
TableofContents
|
19
|
+
end
|
20
|
+
|
21
|
+
def self.tableof_contents
|
22
|
+
TableofContents
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
class SimpleSimilarClassFinderTest < Minitest::Test
|
28
|
+
def setup
|
29
|
+
@error = assert_raises(NameError) { ::Bo0k }
|
30
|
+
end
|
31
|
+
|
32
|
+
def test_similar_words
|
33
|
+
assert_suggestion @error.finder.similar_words, "Book"
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
class SimilarClassFinderInsideClassTest < Minitest::Test
|
38
|
+
def setup
|
39
|
+
@error = assert_raises(NameError) { Project.bo0k }
|
40
|
+
end
|
41
|
+
|
42
|
+
def test_similar_words
|
43
|
+
assert_suggestion @error.finder.similar_words, "Book"
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
class SimilarClassFinderInsideNestedClassTest < Minitest::Test
|
48
|
+
def setup
|
49
|
+
@error = assert_raises(NameError) { Book::Page.tableof_contents }
|
50
|
+
end
|
51
|
+
|
52
|
+
def test_similar_words
|
53
|
+
assert_suggestion @error.finder.similar_words, "Book::TableOfContents"
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
class SimilarClassFinderForClassWithNamespaceTest < Minitest::Test
|
58
|
+
def setup
|
59
|
+
@error = assert_raises(NameError) { ::Book::TableofContents }
|
60
|
+
end
|
61
|
+
|
62
|
+
def test_similar_words
|
63
|
+
assert_suggestion @error.finder.similar_words, "Book::TableOfContents"
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
class SimilarClassFinderFromInstanceTest < Minitest::Test
|
68
|
+
def setup
|
69
|
+
@error = assert_raises(NameError) { ::Book.new.tableof_contents }
|
70
|
+
end
|
71
|
+
|
72
|
+
def test_similar_words
|
73
|
+
assert_suggestion @error.finder.similar_words, "Book::TableOfContents"
|
74
|
+
end
|
75
|
+
end
|
76
|
+
|
77
|
+
class SimilarClassFinderFromNestedInstanceTest < Minitest::Test
|
78
|
+
def setup
|
79
|
+
@error = assert_raises(NameError) { ::Book::Page.new.tableof_contents }
|
80
|
+
end
|
81
|
+
|
82
|
+
def test_similar_words
|
83
|
+
assert_suggestion @error.finder.similar_words, "Book::TableOfContents"
|
84
|
+
end
|
85
|
+
end
|
@@ -22,47 +22,28 @@ class SimilarMethodFinderTest < Minitest::Test
|
|
22
22
|
def setup
|
23
23
|
user = User.new.extend(UserModule)
|
24
24
|
|
25
|
-
@
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
from_class_method: assert_raises(NoMethodError){ User.l0ad }
|
30
|
-
}
|
25
|
+
@error_from_instance_method = assert_raises(NoMethodError){ user.flrst_name }
|
26
|
+
@error_from_private_method = assert_raises(NoMethodError){ user.friend }
|
27
|
+
@error_from_module_method = assert_raises(NoMethodError){ user.fr0m_module }
|
28
|
+
@error_from_class_method = assert_raises(NoMethodError){ User.l0ad }
|
31
29
|
end
|
32
30
|
|
33
|
-
def
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
assert error.method_finder.similar_columns.include?("first_name")
|
39
|
-
assert_match "Did you mean? first_name", error.did_you_mean?
|
40
|
-
assert_match error.did_you_mean?, error.message
|
41
|
-
end
|
42
|
-
|
43
|
-
def test_similar_methods
|
44
|
-
assert @errors[:from_instance_method].method_finder.similar_methods.include?(:first_name)
|
45
|
-
assert @errors[:from_private_method].method_finder.similar_methods.include?(:friends)
|
46
|
-
assert @errors[:from_module_method].method_finder.similar_methods.include?(:from_module)
|
47
|
-
assert @errors[:from_class_method].method_finder.similar_methods.include?(:load)
|
48
|
-
end
|
49
|
-
|
50
|
-
def test_similar_methods_for_long_method_name
|
51
|
-
error = assert_raises(NoMethodError){ User.new.dependents }
|
52
|
-
assert error.method_finder.similar_methods.include?(:descendants)
|
31
|
+
def test_similar_words
|
32
|
+
assert_suggestion @error_from_instance_method.finder.similar_words, :first_name
|
33
|
+
assert_suggestion @error_from_private_method.finder.similar_words, :friends
|
34
|
+
assert_suggestion @error_from_module_method.finder.similar_words, :from_module
|
35
|
+
assert_suggestion @error_from_class_method.finder.similar_words, :load
|
53
36
|
end
|
54
37
|
|
55
38
|
def test_did_you_mean?
|
56
|
-
assert_match "Did you mean? #first_name", @
|
57
|
-
assert_match "Did you mean? #friends", @
|
58
|
-
assert_match "Did you mean? #from_module", @
|
59
|
-
assert_match "Did you mean? .load", @
|
39
|
+
assert_match "Did you mean? #first_name", @error_from_instance_method.did_you_mean?
|
40
|
+
assert_match "Did you mean? #friends", @error_from_private_method.did_you_mean?
|
41
|
+
assert_match "Did you mean? #from_module", @error_from_module_method.did_you_mean?
|
42
|
+
assert_match "Did you mean? .load", @error_from_class_method.did_you_mean?
|
60
43
|
end
|
61
44
|
|
62
|
-
def
|
63
|
-
|
64
|
-
|
65
|
-
assert_match @errors[:from_module_method].did_you_mean?, @errors[:from_module_method].message
|
66
|
-
assert_match @errors[:from_class_method].did_you_mean?, @errors[:from_class_method].message
|
45
|
+
def test_similar_words_for_long_method_name
|
46
|
+
error = assert_raises(NoMethodError){ User.new.dependents }
|
47
|
+
assert_suggestion error.finder.similar_words, :descendants
|
67
48
|
end
|
68
49
|
end
|
@@ -2,9 +2,16 @@ require_relative 'test_helper'
|
|
2
2
|
|
3
3
|
class SimilarNameFinderTest < Minitest::Test
|
4
4
|
class User
|
5
|
+
def initialize(options = {})
|
6
|
+
@email = options[:email]
|
7
|
+
end
|
8
|
+
|
5
9
|
def call_flrst_name; f1rst_name; end
|
6
10
|
def call_fr0m_module; fr0m_module; end
|
7
11
|
def first_name; end
|
12
|
+
def to_s
|
13
|
+
"#{@first_name} #{@last_name} <#{email}>"
|
14
|
+
end
|
8
15
|
end
|
9
16
|
|
10
17
|
module UserModule
|
@@ -14,41 +21,42 @@ class SimilarNameFinderTest < Minitest::Test
|
|
14
21
|
def setup
|
15
22
|
user = User.new.extend(UserModule)
|
16
23
|
|
17
|
-
@
|
18
|
-
|
19
|
-
|
20
|
-
}
|
24
|
+
@error_from_instance_method = assert_raises(NameError){ user.call_flrst_name }
|
25
|
+
@error_from_module_method = assert_raises(NameError){ user.call_fr0m_module }
|
26
|
+
@error_from_missing_at_sign = assert_raises(NameError){ user.to_s }
|
21
27
|
|
22
|
-
begin
|
28
|
+
# Use begin + rescue as #assert_raises changes a scope.
|
29
|
+
@error_from_local_variable = begin
|
23
30
|
userr
|
24
31
|
rescue NameError => e
|
25
|
-
|
32
|
+
e
|
26
33
|
end
|
27
34
|
end
|
28
35
|
|
29
|
-
def
|
30
|
-
|
31
|
-
|
36
|
+
def test_similar_words
|
37
|
+
assert_suggestion @error_from_instance_method.finder.similar_words, "first_name"
|
38
|
+
assert_suggestion @error_from_module_method.finder.similar_words, "from_module"
|
39
|
+
assert_suggestion @error_from_local_variable.finder.similar_words, "user"
|
40
|
+
assert_suggestion @error_from_missing_at_sign.finder.similar_words, "email"
|
32
41
|
end
|
33
42
|
|
34
|
-
def
|
35
|
-
|
43
|
+
def test_similar_instance_methods
|
44
|
+
assert_suggestion @error_from_instance_method.finder.similar_methods, "first_name"
|
45
|
+
assert_suggestion @error_from_module_method.finder.similar_methods, "from_module"
|
36
46
|
end
|
37
47
|
|
38
|
-
def
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
assert_match "Did you mean?", @errors[:from_module_method].did_you_mean?
|
43
|
-
assert_match "instance methods: #from_module", @errors[:from_module_method].did_you_mean?
|
48
|
+
def test_similar_local_variables
|
49
|
+
assert_suggestion @error_from_local_variable.finder.similar_local_variables, "user"
|
50
|
+
end
|
44
51
|
|
45
|
-
|
46
|
-
|
52
|
+
def test_similar_instance_variables
|
53
|
+
assert_suggestion @error_from_missing_at_sign.finder.similar_instance_variables, "email"
|
47
54
|
end
|
48
55
|
|
49
|
-
def
|
50
|
-
assert_match @
|
51
|
-
assert_match @
|
52
|
-
assert_match @
|
56
|
+
def test_did_you_mean?
|
57
|
+
assert_match "Did you mean? #first_name", @error_from_instance_method.did_you_mean?
|
58
|
+
assert_match "Did you mean? #from_module", @error_from_module_method.did_you_mean?
|
59
|
+
assert_match "Did you mean? user", @error_from_local_variable.did_you_mean?
|
60
|
+
assert_match "Did you mean? @email", @error_from_missing_at_sign.did_you_mean?
|
53
61
|
end
|
54
62
|
end
|