minmb-net-ssh 2.5.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (137) hide show
  1. data/CHANGELOG.rdoc +291 -0
  2. data/Manifest +132 -0
  3. data/README.rdoc +184 -0
  4. data/Rakefile +86 -0
  5. data/Rudyfile +96 -0
  6. data/THANKS.rdoc +19 -0
  7. data/lib/net/ssh.rb +223 -0
  8. data/lib/net/ssh/authentication/agent.rb +23 -0
  9. data/lib/net/ssh/authentication/agent/java_pageant.rb +85 -0
  10. data/lib/net/ssh/authentication/agent/socket.rb +170 -0
  11. data/lib/net/ssh/authentication/constants.rb +18 -0
  12. data/lib/net/ssh/authentication/key_manager.rb +253 -0
  13. data/lib/net/ssh/authentication/methods/abstract.rb +60 -0
  14. data/lib/net/ssh/authentication/methods/hostbased.rb +75 -0
  15. data/lib/net/ssh/authentication/methods/keyboard_interactive.rb +70 -0
  16. data/lib/net/ssh/authentication/methods/password.rb +43 -0
  17. data/lib/net/ssh/authentication/methods/publickey.rb +96 -0
  18. data/lib/net/ssh/authentication/pageant.rb +301 -0
  19. data/lib/net/ssh/authentication/session.rb +154 -0
  20. data/lib/net/ssh/buffer.rb +350 -0
  21. data/lib/net/ssh/buffered_io.rb +207 -0
  22. data/lib/net/ssh/config.rb +207 -0
  23. data/lib/net/ssh/connection/channel.rb +630 -0
  24. data/lib/net/ssh/connection/constants.rb +33 -0
  25. data/lib/net/ssh/connection/session.rb +603 -0
  26. data/lib/net/ssh/connection/term.rb +178 -0
  27. data/lib/net/ssh/errors.rb +88 -0
  28. data/lib/net/ssh/key_factory.rb +107 -0
  29. data/lib/net/ssh/known_hosts.rb +141 -0
  30. data/lib/net/ssh/loggable.rb +61 -0
  31. data/lib/net/ssh/packet.rb +102 -0
  32. data/lib/net/ssh/prompt.rb +93 -0
  33. data/lib/net/ssh/proxy/command.rb +75 -0
  34. data/lib/net/ssh/proxy/errors.rb +14 -0
  35. data/lib/net/ssh/proxy/http.rb +94 -0
  36. data/lib/net/ssh/proxy/socks4.rb +70 -0
  37. data/lib/net/ssh/proxy/socks5.rb +142 -0
  38. data/lib/net/ssh/ruby_compat.rb +77 -0
  39. data/lib/net/ssh/service/forward.rb +327 -0
  40. data/lib/net/ssh/test.rb +89 -0
  41. data/lib/net/ssh/test/channel.rb +129 -0
  42. data/lib/net/ssh/test/extensions.rb +152 -0
  43. data/lib/net/ssh/test/kex.rb +44 -0
  44. data/lib/net/ssh/test/local_packet.rb +51 -0
  45. data/lib/net/ssh/test/packet.rb +81 -0
  46. data/lib/net/ssh/test/remote_packet.rb +38 -0
  47. data/lib/net/ssh/test/script.rb +157 -0
  48. data/lib/net/ssh/test/socket.rb +64 -0
  49. data/lib/net/ssh/transport/algorithms.rb +407 -0
  50. data/lib/net/ssh/transport/cipher_factory.rb +106 -0
  51. data/lib/net/ssh/transport/constants.rb +32 -0
  52. data/lib/net/ssh/transport/ctr.rb +95 -0
  53. data/lib/net/ssh/transport/hmac.rb +45 -0
  54. data/lib/net/ssh/transport/hmac/abstract.rb +79 -0
  55. data/lib/net/ssh/transport/hmac/md5.rb +12 -0
  56. data/lib/net/ssh/transport/hmac/md5_96.rb +11 -0
  57. data/lib/net/ssh/transport/hmac/none.rb +15 -0
  58. data/lib/net/ssh/transport/hmac/ripemd160.rb +13 -0
  59. data/lib/net/ssh/transport/hmac/sha1.rb +13 -0
  60. data/lib/net/ssh/transport/hmac/sha1_96.rb +11 -0
  61. data/lib/net/ssh/transport/hmac/sha2_256.rb +15 -0
  62. data/lib/net/ssh/transport/hmac/sha2_256_96.rb +13 -0
  63. data/lib/net/ssh/transport/hmac/sha2_512.rb +14 -0
  64. data/lib/net/ssh/transport/hmac/sha2_512_96.rb +13 -0
  65. data/lib/net/ssh/transport/identity_cipher.rb +55 -0
  66. data/lib/net/ssh/transport/kex.rb +28 -0
  67. data/lib/net/ssh/transport/kex/diffie_hellman_group14_sha1.rb +44 -0
  68. data/lib/net/ssh/transport/kex/diffie_hellman_group1_sha1.rb +216 -0
  69. data/lib/net/ssh/transport/kex/diffie_hellman_group_exchange_sha1.rb +80 -0
  70. data/lib/net/ssh/transport/kex/diffie_hellman_group_exchange_sha256.rb +15 -0
  71. data/lib/net/ssh/transport/kex/ecdh_sha2_nistp256.rb +93 -0
  72. data/lib/net/ssh/transport/kex/ecdh_sha2_nistp384.rb +13 -0
  73. data/lib/net/ssh/transport/kex/ecdh_sha2_nistp521.rb +13 -0
  74. data/lib/net/ssh/transport/key_expander.rb +26 -0
  75. data/lib/net/ssh/transport/openssl.rb +237 -0
  76. data/lib/net/ssh/transport/packet_stream.rb +235 -0
  77. data/lib/net/ssh/transport/server_version.rb +71 -0
  78. data/lib/net/ssh/transport/session.rb +278 -0
  79. data/lib/net/ssh/transport/state.rb +206 -0
  80. data/lib/net/ssh/verifiers/lenient.rb +30 -0
  81. data/lib/net/ssh/verifiers/null.rb +12 -0
  82. data/lib/net/ssh/verifiers/strict.rb +53 -0
  83. data/lib/net/ssh/version.rb +62 -0
  84. data/net-ssh.gemspec +164 -0
  85. data/setup.rb +1585 -0
  86. data/support/arcfour_check.rb +20 -0
  87. data/support/ssh_tunnel_bug.rb +65 -0
  88. data/test/authentication/methods/common.rb +28 -0
  89. data/test/authentication/methods/test_abstract.rb +51 -0
  90. data/test/authentication/methods/test_hostbased.rb +114 -0
  91. data/test/authentication/methods/test_keyboard_interactive.rb +100 -0
  92. data/test/authentication/methods/test_password.rb +52 -0
  93. data/test/authentication/methods/test_publickey.rb +148 -0
  94. data/test/authentication/test_agent.rb +205 -0
  95. data/test/authentication/test_key_manager.rb +218 -0
  96. data/test/authentication/test_session.rb +106 -0
  97. data/test/common.rb +107 -0
  98. data/test/configs/eqsign +3 -0
  99. data/test/configs/exact_match +8 -0
  100. data/test/configs/host_plus +10 -0
  101. data/test/configs/multihost +4 -0
  102. data/test/configs/wild_cards +14 -0
  103. data/test/connection/test_channel.rb +467 -0
  104. data/test/connection/test_session.rb +488 -0
  105. data/test/known_hosts/github +1 -0
  106. data/test/test_all.rb +9 -0
  107. data/test/test_buffer.rb +426 -0
  108. data/test/test_buffered_io.rb +63 -0
  109. data/test/test_config.rb +120 -0
  110. data/test/test_key_factory.rb +121 -0
  111. data/test/test_known_hosts.rb +13 -0
  112. data/test/transport/hmac/test_md5.rb +39 -0
  113. data/test/transport/hmac/test_md5_96.rb +25 -0
  114. data/test/transport/hmac/test_none.rb +34 -0
  115. data/test/transport/hmac/test_ripemd160.rb +34 -0
  116. data/test/transport/hmac/test_sha1.rb +34 -0
  117. data/test/transport/hmac/test_sha1_96.rb +25 -0
  118. data/test/transport/hmac/test_sha2_256.rb +35 -0
  119. data/test/transport/hmac/test_sha2_256_96.rb +25 -0
  120. data/test/transport/hmac/test_sha2_512.rb +35 -0
  121. data/test/transport/hmac/test_sha2_512_96.rb +25 -0
  122. data/test/transport/kex/test_diffie_hellman_group14_sha1.rb +13 -0
  123. data/test/transport/kex/test_diffie_hellman_group1_sha1.rb +146 -0
  124. data/test/transport/kex/test_diffie_hellman_group_exchange_sha1.rb +92 -0
  125. data/test/transport/kex/test_diffie_hellman_group_exchange_sha256.rb +33 -0
  126. data/test/transport/kex/test_ecdh_sha2_nistp256.rb +161 -0
  127. data/test/transport/kex/test_ecdh_sha2_nistp384.rb +37 -0
  128. data/test/transport/kex/test_ecdh_sha2_nistp521.rb +37 -0
  129. data/test/transport/test_algorithms.rb +330 -0
  130. data/test/transport/test_cipher_factory.rb +441 -0
  131. data/test/transport/test_hmac.rb +34 -0
  132. data/test/transport/test_identity_cipher.rb +40 -0
  133. data/test/transport/test_packet_stream.rb +1745 -0
  134. data/test/transport/test_server_version.rb +78 -0
  135. data/test/transport/test_session.rb +315 -0
  136. data/test/transport/test_state.rb +179 -0
  137. metadata +208 -0
@@ -0,0 +1 @@
1
+ github.com ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAq2A7hRGmdnm9tUDbO9IDSwBK6TbQa+PXYPCPy6rbTrTtw7PHkccKrpp0yVhp5HdEIcKr6pLlVDBfOLX9QUsyCOV0wzfjIJNlGEYsdlLJizHhbn2mUjvSAHQqZETYP81eFzLQNnPHt4EVVUh7VfDESU84KezmD5QlWpXLmvU31/yMf+Se8xhHTvKSCZIFImWwoG6mbUoWf9nzpIoaSjB+weqqUUmpaaasXVal72J+UX2B+2RPW3RcT0eOzQgqlJL3RKrTJvdsjE3JEAvGq3lGHSZXy28G3skua2SmVi/w4yCE6gbODqnTWlg7+wC604ydGXA8VJiS5ap43JXiUFFAaQ==
data/test/test_all.rb ADDED
@@ -0,0 +1,9 @@
1
+ # $ ruby -Ilib -Itest -rrubygems test/test_all.rb
2
+ # $ ruby -Ilib -Itest -rrubygems test/transport/test_server_version.rb
3
+ Dir.chdir(File.dirname(__FILE__)) do
4
+ test_files = Dir['**/test_*.rb']-['test_all.rb'] # prevent circular require
5
+ test_files = test_files.reject { |f| f =~ /^manual/ }
6
+ test_files = test_files.select { |f| f =~ Regexp.new(ENV['ONLY']) } if ENV['ONLY']
7
+ test_files = test_files.reject { |f| f =~ Regexp.new(ENV['EXCEPT']) } if ENV['EXCEPT']
8
+ test_files.each { |file| require(file) }
9
+ end
@@ -0,0 +1,426 @@
1
+ require 'common'
2
+ require 'net/ssh/buffer'
3
+
4
+ class TestBuffer < Test::Unit::TestCase
5
+ def test_constructor_should_initialize_buffer_to_empty_by_default
6
+ buffer = new
7
+ assert buffer.empty?
8
+ assert_equal 0, buffer.position
9
+ end
10
+
11
+ def test_constructor_with_string_should_initialize_buffer_to_the_string
12
+ buffer = new("hello")
13
+ assert !buffer.empty?
14
+ assert_equal "hello", buffer.to_s
15
+ assert_equal 0, buffer.position
16
+ end
17
+
18
+ def test_from_should_require_an_even_number_of_arguments
19
+ assert_raises(ArgumentError) { Net::SSH::Buffer.from("this") }
20
+ end
21
+
22
+ def test_from_should_build_new_buffer_from_definition
23
+ buffer = Net::SSH::Buffer.from(:byte, 1, :long, 2, :int64, 3, :string, "4", :bool, true, :bool, false, :bignum, OpenSSL::BN.new("1234567890", 10), :raw, "something")
24
+ assert_equal "\1\0\0\0\2\0\0\0\0\0\0\0\3\0\0\0\0014\1\0\000\000\000\004I\226\002\322something", buffer.to_s
25
+ end
26
+
27
+ def test_from_with_array_argument_should_write_multiple_of_the_given_type
28
+ buffer = Net::SSH::Buffer.from(:byte, [1,2,3,4,5])
29
+ assert_equal "\1\2\3\4\5", buffer.to_s
30
+ end
31
+
32
+ def test_read_without_argument_should_read_to_end
33
+ buffer = new("hello world")
34
+ assert_equal "hello world", buffer.read
35
+ assert buffer.eof?
36
+ assert_equal 11, buffer.position
37
+ end
38
+
39
+ def test_read_with_argument_that_is_less_than_length_should_read_that_many_bytes
40
+ buffer = new "hello world"
41
+ assert_equal "hello", buffer.read(5)
42
+ assert_equal 5, buffer.position
43
+ end
44
+
45
+ def test_read_with_argument_that_is_more_than_length_should_read_no_more_than_length
46
+ buffer = new "hello world"
47
+ assert_equal "hello world", buffer.read(500)
48
+ assert_equal 11, buffer.position
49
+ end
50
+
51
+ def test_read_at_eof_should_return_empty_string
52
+ buffer = new "hello"
53
+ buffer.position = 5
54
+ assert_equal "", buffer.read
55
+ end
56
+
57
+ def test_consume_without_argument_should_resize_buffer_to_start_at_position
58
+ buffer = new "hello world"
59
+ buffer.read(5)
60
+ assert_equal 5, buffer.position
61
+ assert_equal 11, buffer.length
62
+ buffer.consume!
63
+ assert_equal 0, buffer.position
64
+ assert_equal 6, buffer.length
65
+ assert_equal " world", buffer.to_s
66
+ end
67
+
68
+ def test_consume_with_argument_should_resize_buffer_starting_at_n
69
+ buffer = new "hello world"
70
+ assert_equal 0, buffer.position
71
+ buffer.consume!(5)
72
+ assert_equal 0, buffer.position
73
+ assert_equal 6, buffer.length
74
+ assert_equal " world", buffer.to_s
75
+ end
76
+
77
+ def test_read_bang_should_read_and_consume_and_return_read_portion
78
+ buffer = new "hello world"
79
+ assert_equal "hello", buffer.read!(5)
80
+ assert_equal 0, buffer.position
81
+ assert_equal 6, buffer.length
82
+ assert_equal " world", buffer.to_s
83
+ end
84
+
85
+ def test_available_should_return_length_after_position_to_end_of_string
86
+ buffer = new "hello world"
87
+ buffer.read(5)
88
+ assert_equal 6, buffer.available
89
+ end
90
+
91
+ def test_clear_bang_should_reset_buffer_contents_and_counters
92
+ buffer = new "hello world"
93
+ buffer.read(5)
94
+ buffer.clear!
95
+ assert_equal 0, buffer.length
96
+ assert_equal 0, buffer.position
97
+ assert_equal "", buffer.to_s
98
+ end
99
+
100
+ def test_append_should_append_argument_without_changing_position_and_should_return_self
101
+ buffer = new "hello world"
102
+ buffer.read(5)
103
+ buffer.append(" again")
104
+ assert_equal 5, buffer.position
105
+ assert_equal 12, buffer.available
106
+ assert_equal 17, buffer.length
107
+ assert_equal "hello world again", buffer.to_s
108
+ end
109
+
110
+ def test_remainder_as_buffer_should_return_a_new_buffer_filled_with_the_text_after_the_current_position
111
+ buffer = new "hello world"
112
+ buffer.read(6)
113
+ b2 = buffer.remainder_as_buffer
114
+ assert_equal 6, buffer.position
115
+ assert_equal 0, b2.position
116
+ assert_equal "world", b2.to_s
117
+ end
118
+
119
+ def test_read_int64_should_return_8_byte_integer
120
+ buffer = new "\xff\xee\xdd\xcc\xbb\xaa\x99\x88"
121
+ assert_equal 0xffeeddccbbaa9988, buffer.read_int64
122
+ assert_equal 8, buffer.position
123
+ end
124
+
125
+ def test_read_int64_should_return_nil_on_partial_read
126
+ buffer = new "\0\0\0\0\0\0\0"
127
+ assert_nil buffer.read_int64
128
+ assert buffer.eof?
129
+ end
130
+
131
+ def test_read_long_should_return_4_byte_integer
132
+ buffer = new "\xff\xee\xdd\xcc\xbb\xaa\x99\x88"
133
+ assert_equal 0xffeeddcc, buffer.read_long
134
+ assert_equal 4, buffer.position
135
+ end
136
+
137
+ def test_read_long_should_return_nil_on_partial_read
138
+ buffer = new "\0\0\0"
139
+ assert_nil buffer.read_long
140
+ assert buffer.eof?
141
+ end
142
+
143
+ def test_read_byte_should_return_single_byte_integer
144
+ buffer = new "\xfe\xdc"
145
+ assert_equal 0xfe, buffer.read_byte
146
+ assert_equal 1, buffer.position
147
+ end
148
+
149
+ def test_read_byte_should_return_nil_at_eof
150
+ assert_nil new.read_byte
151
+ end
152
+
153
+ def test_read_string_should_read_length_and_data_from_buffer
154
+ buffer = new "\0\0\0\x0bhello world"
155
+ assert_equal "hello world", buffer.read_string
156
+ end
157
+
158
+ def test_read_string_should_return_nil_if_4_byte_length_cannot_be_read
159
+ assert_nil new("\0\1").read_string
160
+ end
161
+
162
+ def test_read_bool_should_return_true_if_non_zero_byte_is_read
163
+ buffer = new "\1\2\3\4\5\6"
164
+ 6.times { assert_equal true, buffer.read_bool }
165
+ end
166
+
167
+ def test_read_bool_should_return_false_if_zero_byte_is_read
168
+ buffer = new "\0"
169
+ assert_equal false, buffer.read_bool
170
+ end
171
+
172
+ def test_read_bool_should_return_nil_at_eof
173
+ assert_nil new.read_bool
174
+ end
175
+
176
+ def test_read_bignum_should_read_openssl_formatted_bignum
177
+ buffer = new("\000\000\000\004I\226\002\322")
178
+ assert_equal OpenSSL::BN.new("1234567890", 10), buffer.read_bignum
179
+ end
180
+
181
+ def test_read_bignum_should_return_nil_if_length_cannot_be_read
182
+ assert_nil new("\0\1\2").read_bignum
183
+ end
184
+
185
+ def test_read_key_blob_should_read_dsa_keys
186
+ random_dss { |buffer| buffer.read_keyblob("ssh-dss") }
187
+ end
188
+
189
+ def test_read_key_blob_should_read_rsa_keys
190
+ random_rsa { |buffer| buffer.read_keyblob("ssh-rsa") }
191
+ end
192
+
193
+ def test_read_key_should_read_dsa_key_type_and_keyblob
194
+ random_dss do |buffer|
195
+ b2 = Net::SSH::Buffer.from(:string, "ssh-dss", :raw, buffer)
196
+ b2.read_key
197
+ end
198
+ end
199
+
200
+ def test_read_key_should_read_rsa_key_type_and_keyblob
201
+ random_rsa do |buffer|
202
+ b2 = Net::SSH::Buffer.from(:string, "ssh-rsa", :raw, buffer)
203
+ b2.read_key
204
+ end
205
+ end
206
+
207
+ def test_read_buffer_should_read_a_string_and_return_it_wrapped_in_a_buffer
208
+ buffer = new("\0\0\0\x0bhello world")
209
+ b2 = buffer.read_buffer
210
+ assert_equal 0, b2.position
211
+ assert_equal 11, b2.length
212
+ assert_equal "hello world", b2.read
213
+ end
214
+
215
+ def test_read_to_should_return_nil_if_pattern_does_not_exist_in_buffer
216
+ buffer = new("one two three")
217
+ assert_nil buffer.read_to("\n")
218
+ end
219
+
220
+ def test_read_to_should_grok_string_patterns
221
+ buffer = new("one two three")
222
+ assert_equal "one tw", buffer.read_to("tw")
223
+ assert_equal 6, buffer.position
224
+ end
225
+
226
+ def test_read_to_should_grok_regex_patterns
227
+ buffer = new("one two three")
228
+ assert_equal "one tw", buffer.read_to(/tw/)
229
+ assert_equal 6, buffer.position
230
+ end
231
+
232
+ def test_read_to_should_grok_fixnum_patterns
233
+ buffer = new("one two three")
234
+ assert_equal "one tw", buffer.read_to(?w)
235
+ assert_equal 6, buffer.position
236
+ end
237
+
238
+ def test_reset_bang_should_reset_position_to_0
239
+ buffer = new("hello world")
240
+ buffer.read(5)
241
+ assert_equal 5, buffer.position
242
+ buffer.reset!
243
+ assert_equal 0, buffer.position
244
+ end
245
+
246
+ def test_write_should_write_arguments_directly_to_end_buffer
247
+ buffer = new("start")
248
+ buffer.write "hello", " ", "world"
249
+ assert_equal "starthello world", buffer.to_s
250
+ assert_equal 0, buffer.position
251
+ end
252
+
253
+ def test_write_int64_should_write_arguments_as_8_byte_integers_to_end_of_buffer
254
+ buffer = new("start")
255
+ buffer.write_int64 0xffeeddccbbaa9988, 0x7766554433221100
256
+ assert_equal "start\xff\xee\xdd\xcc\xbb\xaa\x99\x88\x77\x66\x55\x44\x33\x22\x11\x00", buffer.to_s
257
+ end
258
+
259
+ def test_write_long_should_write_arguments_as_4_byte_integers_to_end_of_buffer
260
+ buffer = new("start")
261
+ buffer.write_long 0xffeeddcc, 0xbbaa9988
262
+ assert_equal "start\xff\xee\xdd\xcc\xbb\xaa\x99\x88", buffer.to_s
263
+ end
264
+
265
+ def test_write_byte_should_write_arguments_as_1_byte_integers_to_end_of_buffer
266
+ buffer = new("start")
267
+ buffer.write_byte 1, 2, 3, 4, 5
268
+ assert_equal "start\1\2\3\4\5", buffer.to_s
269
+ end
270
+
271
+ def test_write_bool_should_write_arguments_as_1_byte_boolean_values_to_end_of_buffer
272
+ buffer = new("start")
273
+ buffer.write_bool nil, false, true, 1, Object.new
274
+ assert_equal "start\0\0\1\1\1", buffer.to_s
275
+ end
276
+
277
+ def test_write_bignum_should_write_arguments_as_ssh_formatted_bignum_values_to_end_of_buffer
278
+ buffer = new("start")
279
+ buffer.write_bignum OpenSSL::BN.new('1234567890', 10)
280
+ assert_equal "start\000\000\000\004I\226\002\322", buffer.to_s
281
+ end
282
+
283
+ def test_write_dss_key_should_write_argument_to_end_of_buffer
284
+ buffer = new("start")
285
+
286
+ key = OpenSSL::PKey::DSA.new
287
+ key.p = 0xffeeddccbbaa9988
288
+ key.q = 0x7766554433221100
289
+ key.g = 0xffddbb9977553311
290
+ key.pub_key = 0xeeccaa8866442200
291
+
292
+ buffer.write_key(key)
293
+ assert_equal "start\0\0\0\7ssh-dss\0\0\0\011\0\xff\xee\xdd\xcc\xbb\xaa\x99\x88\0\0\0\010\x77\x66\x55\x44\x33\x22\x11\x00\0\0\0\011\0\xff\xdd\xbb\x99\x77\x55\x33\x11\0\0\0\011\0\xee\xcc\xaa\x88\x66\x44\x22\x00", buffer.to_s
294
+ end
295
+
296
+ def test_write_rsa_key_should_write_argument_to_end_of_buffer
297
+ buffer = new("start")
298
+
299
+ key = OpenSSL::PKey::RSA.new
300
+ key.e = 0xffeeddccbbaa9988
301
+ key.n = 0x7766554433221100
302
+
303
+ buffer.write_key(key)
304
+ assert_equal "start\0\0\0\7ssh-rsa\0\0\0\011\0\xff\xee\xdd\xcc\xbb\xaa\x99\x88\0\0\0\010\x77\x66\x55\x44\x33\x22\x11\x00", buffer.to_s
305
+ end
306
+
307
+ if defined?(OpenSSL::PKey::EC)
308
+ def test_read_key_blob_should_read_ecdsa_sha2_nistp256_keys
309
+ random_ecdsa_sha2_nistp256 { |buffer|
310
+ buffer.read_keyblob("ecdsa-sha2-nistp256")
311
+ }
312
+ end
313
+ def test_read_key_blob_should_read_ecdsa_sha2_nistp384_keys
314
+ random_ecdsa_sha2_nistp384 { |buffer|
315
+ buffer.read_keyblob("ecdsa-sha2-nistp384")
316
+ }
317
+ end
318
+ def test_read_key_blob_should_read_ecdsa_sha2_nistp521_keys
319
+ random_ecdsa_sha2_nistp521 { |buffer|
320
+ buffer.read_keyblob("ecdsa-sha2-nistp521")
321
+ }
322
+ end
323
+
324
+ def test_read_key_should_read_ecdsa_sha2_nistp256_key_type_and_keyblob
325
+ random_ecdsa_sha2_nistp256 do |buffer|
326
+ b2 = Net::SSH::Buffer.from(:string, "ecdsa-sha2-nistp256", :raw, buffer)
327
+ b2.read_key
328
+ end
329
+ end
330
+ def test_read_key_should_read_ecdsa_sha2_nistp384_key_type_and_keyblob
331
+ random_ecdsa_sha2_nistp384 do |buffer|
332
+ b2 = Net::SSH::Buffer.from(:string, "ecdsa-sha2-nistp384", :raw, buffer)
333
+ b2.read_key
334
+ end
335
+ end
336
+ def test_read_key_should_read_ecdsa_sha2_nistp521_key_type_and_keyblob
337
+ random_ecdsa_sha2_nistp521 do |buffer|
338
+ b2 = Net::SSH::Buffer.from(:string, "ecdsa-sha2-nistp521", :raw, buffer)
339
+ b2.read_key
340
+ end
341
+ end
342
+
343
+ def test_write_ecdsa_sha2_nistp256_key_should_write_argument_to_end_of_buffer
344
+ buffer = new("start")
345
+ key = OpenSSL::PKey::EC.new("-----BEGIN EC PRIVATE KEY-----\nMHcCAQEEIISGj5vAJCWt2KPI8NwaWVDSNLl2vbRxDIOkY+n6O0VVoAoGCCqGSM49\nAwEHoUQDQgAEnKbs0yEogTKT4QRu8T9nb2svl2mEWXb6g224oCpD2o6TYNXNw54H\nmWkdCv+kFCqSlfSi5fqFhrXdfEY6zSzQYQ==\n-----END EC PRIVATE KEY-----\n")
346
+
347
+ buffer.write_key(key)
348
+ assert_equal "start\000\000\000\023ecdsa-sha2-nistp256\000\000\000\bnistp256\000\000\000A\004\234\246\354\323!(\2012\223\341\004n\361?gok/\227i\204Yv\372\203m\270\240*C\332\216\223`\325\315\303\236\a\231i\035\n\377\244\024*\222\225\364\242\345\372\205\206\265\335|F:\315,\320a", buffer.to_s
349
+ end
350
+
351
+ def test_write_ecdsa_sha2_nistp384_key_should_write_argument_to_end_of_buffer
352
+ buffer = new("start")
353
+ key = OpenSSL::PKey::EC.new("-----BEGIN EC PRIVATE KEY-----\nMIGkAgEBBDBAfxJpzhsR7O+wMol6BcDgualR8rJBvYegUDYbBUrDnPzDx2/gD1lZ\nnwG1FuD2s9igBwYFK4EEACKhZANiAATsfiU4Kxyvvj1DdvFYsdDnZIT7loRlan9I\n8geCWPPl6x7NFRP+awrnTaarMgieGqxG8IQaIA0SsDOICfbDBkuatRi0S1Et/in4\nZwVEZvO81Ro5YSrjuUDAsytnI6OXS28=\n-----END EC PRIVATE KEY-----\n")
354
+
355
+ buffer.write_key(key)
356
+ assert_equal "start\000\000\000\023ecdsa-sha2-nistp384\000\000\000\bnistp384\000\000\000a\004\354~%8+\034\257\276=Cv\361X\261\320\347d\204\373\226\204ej\177H\362\a\202X\363\345\353\036\315\025\023\376k\n\347M\246\2532\b\236\032\254F\360\204\032 \r\022\2603\210\t\366\303\006K\232\265\030\264KQ-\376)\370g\005Df\363\274\325\0329a*\343\271@\300\263+g#\243\227Ko", buffer.to_s
357
+ end
358
+
359
+ def test_write_ecdsa_sha2_nistp521_key_should_write_argument_to_end_of_buffer
360
+ buffer = new("start")
361
+ key = OpenSSL::PKey::EC.new("-----BEGIN EC PRIVATE KEY-----\nMIHbAgEBBEGhnQF/SFo4Vym88HnCfc6BR8WwYqDh9wNTPeqzR8auxIpp0GKQlCG2\nuHzyteJX5/YalV8empYhEzNmNLNn8x7j0aAHBgUrgQQAI6GBiQOBhgAEAYygOgV9\nVI8UyLQ3BDlv+rb3es+ufrIcj++cqcc9QcmRn237NiWRr/1NKy2AKijsEdACtZXo\nxPC0x9Vs9ieC2oR+ANOBubcxPl2giDnBYm8ywAmmlXsP5ByAM17k97CzW5O+Z/uO\nbxGUzzhoXTNcjqpAckhRVKdnh6FL/rKelT0tBYi+\n-----END EC PRIVATE KEY-----\n")
362
+
363
+ buffer.write_key(key)
364
+ assert_equal "start\000\000\000\023ecdsa-sha2-nistp521\000\000\000\bnistp521\000\000\000\205\004\001\214\240:\005}T\217\024\310\2647\0049o\372\266\367z\317\256~\262\034\217\357\234\251\307=A\311\221\237m\3736%\221\257\375M+-\200*(\354\021\320\002\265\225\350\304\360\264\307\325l\366'\202\332\204~\000\323\201\271\2671>]\240\2109\301bo2\300\t\246\225{\017\344\034\2003^\344\367\260\263[\223\276g\373\216o\021\224\3178h]3\\\216\252@rHQT\247g\207\241K\376\262\236\225=-\005\210\276", buffer.to_s
365
+ end
366
+ end
367
+
368
+ private
369
+
370
+ def random_rsa
371
+ n1 = OpenSSL::BN.new(rand(0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF).to_s, 10)
372
+ n2 = OpenSSL::BN.new(rand(0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF).to_s, 10)
373
+ buffer = Net::SSH::Buffer.from(:bignum, [n1, n2])
374
+ key = yield(buffer)
375
+ assert_equal "ssh-rsa", key.ssh_type
376
+ assert_equal n1, key.e
377
+ assert_equal n2, key.n
378
+ end
379
+
380
+ def random_dss
381
+ n1 = OpenSSL::BN.new(rand(0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF).to_s, 10)
382
+ n2 = OpenSSL::BN.new(rand(0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF).to_s, 10)
383
+ n3 = OpenSSL::BN.new(rand(0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF).to_s, 10)
384
+ n4 = OpenSSL::BN.new(rand(0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF).to_s, 10)
385
+ buffer = Net::SSH::Buffer.from(:bignum, [n1, n2, n3, n4])
386
+ key = yield(buffer)
387
+ assert_equal "ssh-dss", key.ssh_type
388
+ assert_equal n1, key.p
389
+ assert_equal n2, key.q
390
+ assert_equal n3, key.g
391
+ assert_equal n4, key.pub_key
392
+ end
393
+
394
+ if defined?(OpenSSL::PKey::EC)
395
+ def random_ecdsa_sha2_nistp256
396
+ k = OpenSSL::PKey::EC.new("prime256v1").generate_key
397
+ buffer = Net::SSH::Buffer.from(:string, "nistp256",
398
+ :string, k.public_key.to_bn.to_s(2))
399
+ key = yield(buffer)
400
+ assert_equal "ecdsa-sha2-nistp256", key.ssh_type
401
+ assert_equal k.public_key, key.public_key
402
+ end
403
+
404
+ def random_ecdsa_sha2_nistp384
405
+ k = OpenSSL::PKey::EC.new("secp384r1").generate_key
406
+ buffer = Net::SSH::Buffer.from(:string, "nistp384",
407
+ :string, k.public_key.to_bn.to_s(2))
408
+ key = yield(buffer)
409
+ assert_equal "ecdsa-sha2-nistp384", key.ssh_type
410
+ assert_equal k.public_key, key.public_key
411
+ end
412
+
413
+ def random_ecdsa_sha2_nistp521
414
+ k = OpenSSL::PKey::EC.new("secp521r1").generate_key
415
+ buffer = Net::SSH::Buffer.from(:string, "nistp521",
416
+ :string, k.public_key.to_bn.to_s(2))
417
+ key = yield(buffer)
418
+ assert_equal "ecdsa-sha2-nistp521", key.ssh_type
419
+ assert_equal k.public_key, key.public_key
420
+ end
421
+ end
422
+
423
+ def new(*args)
424
+ Net::SSH::Buffer.new(*args)
425
+ end
426
+ end
@@ -0,0 +1,63 @@
1
+ require 'common'
2
+ require 'net/ssh/buffered_io'
3
+
4
+ class TestBufferedIo < Test::Unit::TestCase
5
+ def test_fill_should_pull_from_underlying_io
6
+ io.expects(:recv).with(8192).returns("here is some data")
7
+ assert_equal 17, io.fill
8
+ assert_equal 17, io.available
9
+ assert_equal "here is some data", io.read_available(20)
10
+ end
11
+
12
+ def test_enqueue_should_not_write_to_underlying_io
13
+ assert !io.pending_write?
14
+ io.expects(:send).never
15
+ io.enqueue("here is some data")
16
+ assert io.pending_write?
17
+ end
18
+
19
+ def test_send_pending_should_not_fail_when_no_writes_are_pending
20
+ assert !io.pending_write?
21
+ io.expects(:send).never
22
+ assert_nothing_raised { io.send_pending }
23
+ end
24
+
25
+ def test_send_pending_with_pending_writes_should_write_to_underlying_io
26
+ io.enqueue("here is some data")
27
+ io.expects(:send).with("here is some data", 0).returns(17)
28
+ assert io.pending_write?
29
+ assert_nothing_raised { io.send_pending }
30
+ assert !io.pending_write?
31
+ end
32
+
33
+ def test_wait_for_pending_sends_should_write_only_once_if_all_can_be_written_at_once
34
+ io.enqueue("here is some data")
35
+ io.expects(:send).with("here is some data", 0).returns(17)
36
+ assert io.pending_write?
37
+ assert_nothing_raised { io.wait_for_pending_sends }
38
+ assert !io.pending_write?
39
+ end
40
+
41
+ def test_wait_for_pending_sends_should_write_multiple_times_if_first_write_was_partial
42
+ io.enqueue("here is some data")
43
+
44
+ io.expects(:send).with("here is some data", 0).returns(10)
45
+ io.expects(:send).with("me data", 0).returns(4)
46
+ io.expects(:send).with("ata", 0).returns(3)
47
+
48
+ IO.expects(:select).times(2).with(nil, [io]).returns([[], [io]])
49
+
50
+ assert_nothing_raised { io.wait_for_pending_sends }
51
+ assert !io.pending_write?
52
+ end
53
+
54
+ private
55
+
56
+ def io
57
+ @io ||= begin
58
+ io = mock("io")
59
+ io.extend(Net::SSH::BufferedIo)
60
+ io
61
+ end
62
+ end
63
+ end