ronin-support 0.4.1 → 0.5.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (224) hide show
  1. checksums.yaml +7 -0
  2. data/.editorconfig +11 -0
  3. data/.github/workflows/ruby.yml +28 -0
  4. data/.ruby-version +1 -0
  5. data/.yardopts +1 -1
  6. data/ChangeLog.md +121 -33
  7. data/Gemfile +17 -18
  8. data/README.md +57 -33
  9. data/Rakefile +10 -3
  10. data/gemspec.yml +16 -7
  11. data/lib/ronin/binary.rb +21 -0
  12. data/lib/ronin/binary/hexdump.rb +20 -0
  13. data/lib/ronin/binary/hexdump/parser.rb +403 -0
  14. data/lib/ronin/binary/struct.rb +567 -0
  15. data/lib/ronin/binary/template.rb +454 -0
  16. data/lib/ronin/extensions.rb +5 -5
  17. data/lib/ronin/extensions/enumerable.rb +5 -5
  18. data/lib/ronin/extensions/file.rb +39 -33
  19. data/lib/ronin/extensions/ip_addr.rb +29 -31
  20. data/lib/ronin/extensions/kernel.rb +5 -5
  21. data/lib/ronin/extensions/meta.rb +5 -5
  22. data/lib/ronin/extensions/regexp.rb +50 -5
  23. data/lib/ronin/extensions/resolv.rb +7 -9
  24. data/lib/ronin/extensions/string.rb +10 -10
  25. data/lib/ronin/formatting.rb +5 -5
  26. data/lib/ronin/formatting/binary.rb +5 -5
  27. data/lib/ronin/formatting/digest.rb +5 -5
  28. data/lib/ronin/formatting/extensions.rb +5 -5
  29. data/lib/ronin/formatting/extensions/binary.rb +7 -5
  30. data/lib/ronin/formatting/extensions/binary/array.rb +61 -0
  31. data/lib/ronin/formatting/extensions/binary/base64.rb +106 -0
  32. data/lib/ronin/formatting/extensions/binary/file.rb +44 -11
  33. data/lib/ronin/formatting/extensions/binary/float.rb +65 -0
  34. data/lib/ronin/formatting/extensions/binary/integer.rb +66 -50
  35. data/lib/ronin/formatting/extensions/binary/string.rb +81 -205
  36. data/lib/ronin/formatting/extensions/digest.rb +5 -5
  37. data/lib/ronin/formatting/extensions/digest/file.rb +5 -5
  38. data/lib/ronin/formatting/extensions/digest/string.rb +5 -5
  39. data/lib/ronin/formatting/extensions/html.rb +5 -5
  40. data/lib/ronin/formatting/extensions/html/integer.rb +9 -13
  41. data/lib/ronin/formatting/extensions/html/string.rb +31 -39
  42. data/lib/ronin/formatting/extensions/http.rb +5 -5
  43. data/lib/ronin/formatting/extensions/http/integer.rb +6 -6
  44. data/lib/ronin/formatting/extensions/http/string.rb +7 -7
  45. data/lib/ronin/formatting/extensions/sql.rb +5 -5
  46. data/lib/ronin/formatting/extensions/sql/string.rb +22 -24
  47. data/lib/ronin/formatting/extensions/text.rb +5 -5
  48. data/lib/ronin/formatting/extensions/text/array.rb +13 -11
  49. data/lib/ronin/formatting/extensions/text/string.rb +70 -13
  50. data/lib/ronin/formatting/html.rb +5 -5
  51. data/lib/ronin/formatting/http.rb +5 -5
  52. data/lib/ronin/formatting/sql.rb +5 -5
  53. data/lib/ronin/formatting/text.rb +5 -5
  54. data/lib/ronin/fuzzing.rb +5 -5
  55. data/lib/ronin/fuzzing/extensions.rb +5 -5
  56. data/lib/ronin/fuzzing/extensions/string.rb +42 -213
  57. data/lib/ronin/fuzzing/fuzzer.rb +110 -0
  58. data/lib/ronin/fuzzing/fuzzing.rb +33 -26
  59. data/lib/ronin/fuzzing/mutator.rb +161 -0
  60. data/lib/ronin/fuzzing/repeater.rb +81 -0
  61. data/lib/ronin/fuzzing/template.rb +133 -0
  62. data/lib/ronin/mixin.rb +2 -2
  63. data/lib/ronin/network.rb +7 -5
  64. data/lib/ronin/network/dns.rb +64 -24
  65. data/lib/ronin/network/esmtp.rb +5 -5
  66. data/lib/ronin/network/extensions.rb +5 -5
  67. data/lib/ronin/network/extensions/dns.rb +5 -5
  68. data/lib/ronin/network/extensions/dns/net.rb +5 -5
  69. data/lib/ronin/network/extensions/esmtp.rb +5 -5
  70. data/lib/ronin/network/extensions/esmtp/net.rb +5 -5
  71. data/lib/ronin/network/extensions/http.rb +5 -5
  72. data/lib/ronin/network/extensions/http/net.rb +5 -5
  73. data/lib/ronin/network/extensions/http/uri/http.rb +5 -5
  74. data/lib/ronin/network/extensions/imap.rb +5 -5
  75. data/lib/ronin/network/extensions/imap/net.rb +5 -5
  76. data/lib/ronin/network/extensions/pop3.rb +5 -5
  77. data/lib/ronin/network/extensions/pop3/net.rb +5 -5
  78. data/lib/ronin/network/extensions/smtp.rb +5 -5
  79. data/lib/ronin/network/extensions/smtp/net.rb +5 -5
  80. data/lib/ronin/network/extensions/ssl.rb +5 -5
  81. data/lib/ronin/network/extensions/ssl/net.rb +5 -5
  82. data/lib/ronin/network/extensions/tcp.rb +5 -5
  83. data/lib/ronin/network/extensions/tcp/net.rb +5 -5
  84. data/lib/ronin/network/extensions/telnet.rb +5 -5
  85. data/lib/ronin/network/extensions/telnet/net.rb +5 -5
  86. data/lib/ronin/network/extensions/udp.rb +5 -5
  87. data/lib/ronin/network/extensions/udp/net.rb +5 -5
  88. data/lib/ronin/network/ftp.rb +149 -0
  89. data/lib/ronin/network/http.rb +5 -5
  90. data/lib/ronin/network/http/exceptions.rb +5 -5
  91. data/lib/ronin/network/http/exceptions/unknown_request.rb +5 -5
  92. data/lib/ronin/network/http/http.rb +65 -70
  93. data/lib/ronin/network/http/proxy.rb +5 -5
  94. data/lib/ronin/network/imap.rb +16 -15
  95. data/lib/ronin/network/mixins.rb +6 -5
  96. data/lib/ronin/network/mixins/dns.rb +5 -5
  97. data/lib/ronin/network/mixins/esmtp.rb +5 -5
  98. data/lib/ronin/network/mixins/ftp.rb +155 -0
  99. data/lib/ronin/network/mixins/http.rb +58 -587
  100. data/lib/ronin/network/mixins/imap.rb +5 -5
  101. data/lib/ronin/network/mixins/mixin.rb +5 -5
  102. data/lib/ronin/network/mixins/pop3.rb +5 -5
  103. data/lib/ronin/network/mixins/smtp.rb +5 -5
  104. data/lib/ronin/network/mixins/ssl.rb +5 -5
  105. data/lib/ronin/network/mixins/tcp.rb +43 -10
  106. data/lib/ronin/network/mixins/telnet.rb +5 -5
  107. data/lib/ronin/network/mixins/udp.rb +126 -6
  108. data/lib/ronin/network/mixins/unix.rb +279 -0
  109. data/lib/ronin/network/network.rb +5 -5
  110. data/lib/ronin/network/pop3.rb +10 -10
  111. data/lib/ronin/network/proxy.rb +578 -0
  112. data/lib/ronin/network/smtp.rb +5 -5
  113. data/lib/ronin/network/smtp/email.rb +6 -6
  114. data/lib/ronin/network/smtp/smtp.rb +12 -13
  115. data/lib/ronin/network/ssl.rb +16 -17
  116. data/lib/ronin/network/tcp.rb +7 -310
  117. data/lib/ronin/network/tcp/proxy.rb +417 -0
  118. data/lib/ronin/network/tcp/tcp.rb +452 -0
  119. data/lib/ronin/network/telnet.rb +34 -28
  120. data/lib/ronin/network/udp.rb +7 -271
  121. data/lib/ronin/network/udp/proxy.rb +191 -0
  122. data/lib/ronin/network/udp/udp.rb +452 -0
  123. data/lib/ronin/network/unix.rb +286 -0
  124. data/lib/ronin/path.rb +35 -39
  125. data/lib/ronin/spec/ui/output.rb +6 -12
  126. data/lib/ronin/support.rb +6 -5
  127. data/lib/ronin/support/inflector.rb +8 -12
  128. data/lib/ronin/support/support.rb +7 -5
  129. data/lib/ronin/support/version.rb +6 -6
  130. data/lib/ronin/templates.rb +5 -5
  131. data/lib/ronin/templates/erb.rb +5 -5
  132. data/lib/ronin/templates/template.rb +5 -5
  133. data/lib/ronin/ui/output.rb +5 -5
  134. data/lib/ronin/ui/output/helpers.rb +42 -28
  135. data/lib/ronin/ui/output/output.rb +17 -21
  136. data/lib/ronin/ui/output/terminal.rb +5 -5
  137. data/lib/ronin/ui/output/terminal/color.rb +15 -9
  138. data/lib/ronin/ui/output/terminal/raw.rb +5 -5
  139. data/lib/ronin/ui/shell.rb +8 -11
  140. data/lib/ronin/wordlist.rb +110 -30
  141. data/ronin-support.gemspec +39 -109
  142. data/spec/binary/hexdump/helpers/hexdumps.rb +13 -0
  143. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/ascii.bin +0 -0
  144. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_decimal_shorts.txt +0 -0
  145. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_hex_bytes.txt +0 -0
  146. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_hex_shorts.txt +0 -0
  147. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_octal_bytes.txt +0 -0
  148. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_octal_shorts.txt +0 -0
  149. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/hexdump_repeated.txt +0 -0
  150. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_decimal_bytes.txt +0 -0
  151. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_decimal_ints.txt +0 -0
  152. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_decimal_quads.txt +0 -0
  153. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_decimal_shorts.txt +0 -0
  154. data/spec/binary/hexdump/helpers/hexdumps/od_doubles.txt +17 -0
  155. data/spec/binary/hexdump/helpers/hexdumps/od_floats.txt +17 -0
  156. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_hex_bytes.txt +0 -0
  157. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_hex_ints.txt +0 -0
  158. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_hex_quads.txt +0 -0
  159. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_hex_shorts.txt +0 -0
  160. data/spec/binary/hexdump/helpers/hexdumps/od_named_chars.txt +17 -0
  161. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_octal_bytes.txt +0 -0
  162. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_octal_ints.txt +0 -0
  163. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_octal_quads.txt +0 -0
  164. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_octal_shorts.txt +0 -0
  165. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/od_repeated.txt +0 -0
  166. data/spec/{formatting/binary → binary/hexdump}/helpers/hexdumps/repeated.bin +0 -0
  167. data/spec/binary/hexdump/parser_spec.rb +302 -0
  168. data/spec/binary/struct_spec.rb +496 -0
  169. data/spec/binary/template_spec.rb +416 -0
  170. data/spec/extensions/enumerable_spec.rb +4 -4
  171. data/spec/extensions/file_spec.rb +12 -14
  172. data/spec/extensions/ip_addr_spec.rb +76 -50
  173. data/spec/extensions/kernel_spec.rb +7 -7
  174. data/spec/extensions/regexp_spec.rb +119 -59
  175. data/spec/extensions/resolv_spec.rb +2 -2
  176. data/spec/extensions/string_spec.rb +31 -30
  177. data/spec/formatting/binary/array_spec.rb +26 -0
  178. data/spec/formatting/binary/base64_spec.rb +50 -0
  179. data/spec/formatting/binary/float_spec.rb +36 -0
  180. data/spec/formatting/binary/integer_spec.rb +76 -50
  181. data/spec/formatting/binary/string_spec.rb +91 -198
  182. data/spec/formatting/digest/string_spec.rb +5 -5
  183. data/spec/formatting/html/integer_spec.rb +6 -6
  184. data/spec/formatting/html/string_spec.rb +10 -10
  185. data/spec/formatting/http/integer_spec.rb +3 -3
  186. data/spec/formatting/http/string_spec.rb +5 -5
  187. data/spec/formatting/sql/string_spec.rb +21 -19
  188. data/spec/formatting/text/array_spec.rb +15 -15
  189. data/spec/formatting/text/string_spec.rb +58 -28
  190. data/spec/fuzzing/extensions/string_spec.rb +87 -0
  191. data/spec/fuzzing/fuzzer_spec.rb +109 -0
  192. data/spec/fuzzing/fuzzing_spec.rb +24 -0
  193. data/spec/fuzzing/mutator_spec.rb +112 -0
  194. data/spec/fuzzing/repeater_spec.rb +57 -0
  195. data/spec/fuzzing/template_spec.rb +54 -0
  196. data/spec/mixin_spec.rb +10 -12
  197. data/spec/network/dns_spec.rb +89 -23
  198. data/spec/network/ftp_spec.rb +81 -0
  199. data/spec/network/http/http_spec.rb +237 -144
  200. data/spec/network/http/proxy_spec.rb +37 -37
  201. data/spec/network/network_spec.rb +2 -2
  202. data/spec/network/proxy_spec.rb +121 -0
  203. data/spec/network/shared/unix_server.rb +31 -0
  204. data/spec/network/smtp/email_spec.rb +14 -14
  205. data/spec/network/ssl_spec.rb +53 -3
  206. data/spec/network/tcp/proxy_spec.rb +118 -0
  207. data/spec/network/tcp/tcp_spec.rb +316 -0
  208. data/spec/network/telnet_spec.rb +67 -0
  209. data/spec/network/udp/udp_spec.rb +298 -0
  210. data/spec/network/unix_spec.rb +182 -0
  211. data/spec/path_spec.rb +43 -18
  212. data/spec/spec_helper.rb +2 -3
  213. data/spec/support/inflector_spec.rb +4 -4
  214. data/spec/support_spec.rb +1 -1
  215. data/spec/templates/erb_spec.rb +3 -3
  216. data/spec/templates/template_spec.rb +10 -10
  217. data/spec/ui/shell_spec.rb +15 -15
  218. data/spec/wordlist_spec.rb +80 -19
  219. metadata +176 -121
  220. data/.gemtest +0 -0
  221. data/spec/formatting/binary/helpers/hexdumps.rb +0 -16
  222. data/spec/fuzzing/string_spec.rb +0 -158
  223. data/spec/network/tcp_spec.rb +0 -247
  224. data/spec/network/udp_spec.rb +0 -248
@@ -0,0 +1,87 @@
1
+ require 'spec_helper'
2
+ require 'ronin/fuzzing/extensions/string'
3
+
4
+ describe String do
5
+ it "should provide String.generate" do
6
+ expect(described_class).to respond_to(:generate)
7
+ end
8
+
9
+ it "should provide String#repeating" do
10
+ expect(subject).to respond_to(:repeating)
11
+ end
12
+
13
+ it "should provide String#fuzz" do
14
+ expect(subject).to respond_to(:fuzz)
15
+ end
16
+
17
+ it "should provide String#mutate" do
18
+ expect(subject).to respond_to(:mutate)
19
+ end
20
+
21
+ describe "generate" do
22
+ subject { described_class }
23
+
24
+ it "should generate Strings from a template" do
25
+ strings = subject.generate([:numeric, 2]).to_a
26
+
27
+ expect(strings.grep(/^[0-9]{2}$/)).to eq(strings)
28
+ end
29
+ end
30
+
31
+ describe "#repeating" do
32
+ subject { 'A' }
33
+
34
+ context "when n is an Integer" do
35
+ let(:n) { 100 }
36
+
37
+ it "should multiply the String by n" do
38
+ expect(subject.repeating(n)).to eq(subject * n)
39
+ end
40
+ end
41
+
42
+ context "when n is Enumerable" do
43
+ let(:n) { [128, 512, 1024] }
44
+
45
+ it "should repeat the String by each length" do
46
+ strings = subject.repeating(n).to_a
47
+
48
+ expect(strings).to eq(n.map { |length| subject * length })
49
+ end
50
+ end
51
+ end
52
+
53
+ describe "#fuzz" do
54
+ subject { "foo bar" }
55
+
56
+ it "should apply each fuzzing rule individually" do
57
+ strings = subject.fuzz(/o/ => ['O', '0'], /a/ => ['A', '@']).to_a
58
+
59
+ expect(strings).to match_array([
60
+ "fOo bar",
61
+ "f0o bar",
62
+ "foO bar",
63
+ "fo0 bar",
64
+ "foo bAr",
65
+ "foo b@r"
66
+ ])
67
+ end
68
+ end
69
+
70
+ describe "#mutate" do
71
+ subject { "foo bar" }
72
+
73
+ it "should apply every combination of mutation rules" do
74
+ strings = subject.mutate(/o/ => ['0'], /a/ => ['@']).to_a
75
+
76
+ expect(strings).to match_array([
77
+ "f0o bar",
78
+ "fo0 bar",
79
+ "f00 bar",
80
+ "foo b@r",
81
+ "f0o b@r",
82
+ "fo0 b@r",
83
+ "f00 b@r"
84
+ ])
85
+ end
86
+ end
87
+ end
@@ -0,0 +1,109 @@
1
+ require 'spec_helper'
2
+ require 'ronin/fuzzing/fuzzer'
3
+
4
+ describe Fuzzing::Fuzzer do
5
+ let(:string) { 'GET /one/two/three' }
6
+
7
+ describe "#initialize" do
8
+ subject { described_class }
9
+
10
+ context "patterns" do
11
+ let(:substitutions) { ['bar'] }
12
+
13
+ it "should accept Regexps" do
14
+ fuzzer = subject.new(/foo/ => substitutions)
15
+
16
+ expect(fuzzer.rules).to have_key(/foo/)
17
+ end
18
+
19
+ context "when given Strings" do
20
+ subject { described_class.new('foo' => substitutions) }
21
+
22
+ it "should convert to Regexp" do
23
+ expect(subject.rules).to have_key(/foo/)
24
+ end
25
+ end
26
+
27
+ context "when given Symbols" do
28
+ subject { described_class.new(:word => substitutions) }
29
+
30
+ it "should lookup the Regexp constant" do
31
+ expect(subject.rules).to have_key(Regexp::WORD)
32
+ end
33
+ end
34
+
35
+ context "otherwise" do
36
+ it "should raise a TypeError" do
37
+ expect {
38
+ subject.new(Object.new => substitutions)
39
+ }.to raise_error(TypeError)
40
+ end
41
+ end
42
+ end
43
+
44
+ context "substitutions" do
45
+ let(:pattern) { /foo/ }
46
+
47
+ it "should accept Enumerable values" do
48
+ fuzzer = subject.new(pattern => ['bar'])
49
+
50
+ expect(fuzzer.rules[pattern]).to eq(['bar'])
51
+ end
52
+
53
+ context "when given Symbols" do
54
+ subject { described_class.new(pattern => :bad_strings) }
55
+
56
+ it "should map to an Enumerator for a Fuzzing method" do
57
+ expect(subject.rules[pattern]).to be_kind_of(Enumerable)
58
+ end
59
+ end
60
+
61
+ context "otherwise" do
62
+ it "should raise a TypeError" do
63
+ expect {
64
+ subject.new(pattern => Object.new)
65
+ }.to raise_error(TypeError)
66
+ end
67
+ end
68
+ end
69
+ end
70
+
71
+ describe "#each" do
72
+ let(:string) { "foo bar" }
73
+
74
+ subject { described_class.new(/o/ => ['O', '0'], /a/ => ['A', '@']) }
75
+
76
+ it "should apply each fuzzing rule individually" do
77
+ expect(subject.each(string).to_a).to match_array([
78
+ "fOo bar",
79
+ "f0o bar",
80
+ "foO bar",
81
+ "fo0 bar",
82
+ "foo bAr",
83
+ "foo b@r"
84
+ ])
85
+ end
86
+
87
+ context "when mutations contain Integers" do
88
+ subject { described_class.new(/o/ => [48]) }
89
+
90
+ it "should convert them to characters" do
91
+ expect(subject.each(string).to_a).to match_array([
92
+ "f0o bar",
93
+ "fo0 bar"
94
+ ])
95
+ end
96
+ end
97
+
98
+ context "when mutations contain Procs" do
99
+ subject { described_class.new(/o/ => [lambda { |str| str.upcase }]) }
100
+
101
+ it "should call them with the matched String" do
102
+ expect(subject.each(string).to_a).to match_array([
103
+ "fOo bar",
104
+ "foO bar"
105
+ ])
106
+ end
107
+ end
108
+ end
109
+ end
@@ -0,0 +1,24 @@
1
+ require 'spec_helper'
2
+ require 'ronin/fuzzing/fuzzing'
3
+
4
+ describe Fuzzing do
5
+ describe "[]" do
6
+ let(:method) { :bad_strings }
7
+
8
+ it "should return Enumerators for fuzzing methods" do
9
+ expect(subject[method]).to be_kind_of(Enumerable)
10
+ end
11
+
12
+ it "should raise NoMethodError for unknown methods" do
13
+ expect {
14
+ subject[:foo]
15
+ }.to raise_error(NoMethodError)
16
+ end
17
+
18
+ it "should not allow accessing inherited methods" do
19
+ expect {
20
+ subject[:instance_eval]
21
+ }.to raise_error(NoMethodError)
22
+ end
23
+ end
24
+ end
@@ -0,0 +1,112 @@
1
+ require 'spec_helper'
2
+ require 'ronin/fuzzing/mutator'
3
+
4
+ describe Fuzzing::Mutator do
5
+ let(:string) { 'GET /one/two/three' }
6
+
7
+ describe "#initialize" do
8
+ subject { described_class }
9
+
10
+ context "patterns" do
11
+ let(:substitutions) { ['bar'] }
12
+
13
+ it "should accept Regexps" do
14
+ fuzzer = subject.new(/foo/ => substitutions)
15
+
16
+ expect(fuzzer.rules).to have_key(/foo/)
17
+ end
18
+
19
+ context "when given Strings" do
20
+ subject { described_class.new('foo' => substitutions) }
21
+
22
+ it "should convert to Regexp" do
23
+ expect(subject.rules).to have_key(/foo/)
24
+ end
25
+ end
26
+
27
+ context "when given Symbols" do
28
+ subject { described_class.new(:word => substitutions) }
29
+
30
+ it "should lookup the Regexp constant" do
31
+ expect(subject.rules).to have_key(Regexp::WORD)
32
+ end
33
+ end
34
+
35
+ context "otherwise" do
36
+ it "should raise a TypeError" do
37
+ expect {
38
+ subject.new(Object.new => substitutions)
39
+ }.to raise_error(TypeError)
40
+ end
41
+ end
42
+ end
43
+
44
+ context "mutations" do
45
+ let(:pattern) { /foo/ }
46
+
47
+ it "should accept Enumerable values" do
48
+ fuzzer = subject.new(pattern => ['bar'])
49
+
50
+ expect(fuzzer.rules[pattern]).to eq(['bar'])
51
+ end
52
+
53
+ context "when given Symbols" do
54
+ subject { described_class.new(pattern => :bad_strings) }
55
+
56
+ it "should map to an Enumerator for a Fuzzing method" do
57
+ expect(subject.rules[pattern]).to be_kind_of(Enumerable)
58
+ end
59
+ end
60
+
61
+ context "otherwise" do
62
+ it "should raise a TypeError" do
63
+ expect {
64
+ subject.new(pattern => Object.new)
65
+ }.to raise_error(TypeError)
66
+ end
67
+ end
68
+ end
69
+ end
70
+
71
+ describe "#each" do
72
+ let(:string) { "foo bar" }
73
+
74
+ subject { described_class.new(/o/ => ['0'], /a/ => ['@']) }
75
+
76
+ it "should apply every combination of mutation rules" do
77
+ expect(subject.each(string).to_a).to match_array([
78
+ "f0o bar",
79
+ "fo0 bar",
80
+ "f00 bar",
81
+ "foo b@r",
82
+ "f0o b@r",
83
+ "fo0 b@r",
84
+ "f00 b@r"
85
+ ])
86
+ end
87
+
88
+ context "when mutations contain Integers" do
89
+ subject { described_class.new(/o/ => [48]) }
90
+
91
+ it "should convert them to characters" do
92
+ expect(subject.each(string).to_a).to match_array([
93
+ "f0o bar",
94
+ "fo0 bar",
95
+ "f00 bar"
96
+ ])
97
+ end
98
+ end
99
+
100
+ context "when mutations contain Procs" do
101
+ subject { described_class.new(/o/ => [lambda { |str| str.upcase }]) }
102
+
103
+ it "should call them with the matched String" do
104
+ expect(subject.each(string).to_a).to match_array([
105
+ "fOo bar",
106
+ "foO bar",
107
+ "fOO bar"
108
+ ])
109
+ end
110
+ end
111
+ end
112
+ end
@@ -0,0 +1,57 @@
1
+ require 'spec_helper'
2
+ require 'ronin/fuzzing/repeater'
3
+
4
+ describe Fuzzing::Repeater do
5
+ describe "#initialize" do
6
+ subject { described_class }
7
+
8
+ context "when lengths is an Integer" do
9
+ it "should coerce lengths to an Enumerable" do
10
+ repeator = subject.new(10)
11
+
12
+ expect(repeator.lengths).to be_kind_of(Enumerable)
13
+ end
14
+ end
15
+
16
+ context "when lengths is not Enumerable or an Integer" do
17
+ it "should raise a TypeError" do
18
+ expect {
19
+ subject.new(Object.new)
20
+ }.to raise_error(TypeError)
21
+ end
22
+ end
23
+ end
24
+
25
+ describe "#each" do
26
+ let(:repeatable) { 'A' }
27
+
28
+ context "when lengths was an Integer" do
29
+ let(:length) { 10 }
30
+
31
+ subject { described_class.new(length) }
32
+
33
+ it "should yield one repeated value" do
34
+ values = subject.each(repeatable).to_a
35
+
36
+ expect(values).to eq([repeatable * length])
37
+ end
38
+ end
39
+
40
+ context "when lengths was Enumerable" do
41
+ let(:lengths) { (1..4) }
42
+
43
+ subject { described_class.new(lengths) }
44
+
45
+ it "should yield repeated values for each length" do
46
+ values = subject.each(repeatable).to_a
47
+
48
+ expect(values).to eq([
49
+ repeatable * 1,
50
+ repeatable * 2,
51
+ repeatable * 3,
52
+ repeatable * 4
53
+ ])
54
+ end
55
+ end
56
+ end
57
+ end
@@ -0,0 +1,54 @@
1
+ require 'spec_helper'
2
+ require 'ronin/fuzzing/template'
3
+
4
+ describe Fuzzing::Template do
5
+ subject { described_class }
6
+
7
+ it "should generate Strings from CharSets" do
8
+ strings = subject.new([:lowercase_hexadecimal, :numeric]).to_a
9
+
10
+ expect(strings.grep(/^[0-9a-f][0-9]$/)).to eq(strings)
11
+ end
12
+
13
+ it "should generate Strings from lengths of CharSets" do
14
+ strings = subject.new([[:numeric, 2]]).to_a
15
+
16
+ expect(strings.grep(/^[0-9]{2}$/)).to eq(strings)
17
+ end
18
+
19
+ it "should generate Strings from varying lengths of CharSets" do
20
+ strings = subject.new([[:numeric, 1..2]]).to_a
21
+
22
+ expect(strings.grep(/^[0-9]{1,2}$/)).to eq(strings)
23
+ end
24
+
25
+ it "should generate Strings from custom CharSets" do
26
+ strings = subject.new([[%w[a b c], 2]]).to_a
27
+
28
+ expect(strings.grep(/^[abc]{2}$/)).to eq(strings)
29
+ end
30
+
31
+ it "should generate Strings containing known Strings" do
32
+ strings = subject.new(['foo', [%w[a b c], 2]]).to_a
33
+
34
+ expect(strings.grep(/^foo[abc]{2}$/)).to eq(strings)
35
+ end
36
+
37
+ it "should raise a TypeError for non String, Symbol, Enumerable CharSets" do
38
+ expect {
39
+ subject.new([[Object.new, 2]]).to_a
40
+ }.to raise_error(TypeError)
41
+ end
42
+
43
+ it "should raise an ArgumentError for unknown CharSets" do
44
+ expect {
45
+ subject.new([[:foo_bar, 2]]).to_a
46
+ }.to raise_error(ArgumentError)
47
+ end
48
+
49
+ it "should raise a TypeError for non Integer,Array,Range lengths" do
50
+ expect {
51
+ subject.new([[:numeric, 'foo']]).to_a
52
+ }.to raise_error(TypeError)
53
+ end
54
+ end