packetfu 1.1.10 → 1.1.11

Sign up to get free protection for your applications and to get access to all the features.
Files changed (98) hide show
  1. checksums.yaml +7 -0
  2. checksums.yaml.gz.sig +0 -0
  3. data.tar.gz.sig +2 -0
  4. data/.gitignore +3 -0
  5. data/.travis.yml +8 -0
  6. data/CONTRIBUTING.md +47 -0
  7. data/Gemfile +4 -0
  8. data/LICENSE.txt +1 -1
  9. data/README.rdoc +35 -30
  10. data/Rakefile +4 -4
  11. data/bench/octets.rb +9 -9
  12. data/examples/100kpackets.rb +12 -12
  13. data/examples/ackscan.rb +16 -16
  14. data/examples/arp.rb +35 -35
  15. data/examples/arphood.rb +36 -36
  16. data/examples/dissect_thinger.rb +6 -6
  17. data/examples/new-simple-stats.rb +23 -23
  18. data/examples/packetfu-shell.rb +25 -25
  19. data/examples/simple-sniffer.rb +9 -9
  20. data/examples/simple-stats.rb +23 -23
  21. data/examples/slammer.rb +3 -3
  22. data/gem-public_cert.pem +21 -0
  23. data/lib/packetfu.rb +149 -127
  24. data/lib/packetfu/capture.rb +169 -169
  25. data/lib/packetfu/config.rb +52 -52
  26. data/lib/packetfu/inject.rb +56 -56
  27. data/lib/packetfu/packet.rb +531 -528
  28. data/lib/packetfu/pcap.rb +579 -579
  29. data/lib/packetfu/protos/arp.rb +90 -90
  30. data/lib/packetfu/protos/arp/header.rb +158 -158
  31. data/lib/packetfu/protos/arp/mixin.rb +36 -36
  32. data/lib/packetfu/protos/eth.rb +44 -44
  33. data/lib/packetfu/protos/eth/header.rb +243 -243
  34. data/lib/packetfu/protos/eth/mixin.rb +3 -3
  35. data/lib/packetfu/protos/hsrp.rb +69 -69
  36. data/lib/packetfu/protos/hsrp/header.rb +107 -107
  37. data/lib/packetfu/protos/hsrp/mixin.rb +29 -29
  38. data/lib/packetfu/protos/icmp.rb +71 -71
  39. data/lib/packetfu/protos/icmp/header.rb +82 -82
  40. data/lib/packetfu/protos/icmp/mixin.rb +14 -14
  41. data/lib/packetfu/protos/invalid.rb +49 -49
  42. data/lib/packetfu/protos/ip.rb +69 -69
  43. data/lib/packetfu/protos/ip/header.rb +291 -291
  44. data/lib/packetfu/protos/ip/mixin.rb +40 -40
  45. data/lib/packetfu/protos/ipv6.rb +50 -50
  46. data/lib/packetfu/protos/ipv6/header.rb +188 -188
  47. data/lib/packetfu/protos/ipv6/mixin.rb +29 -29
  48. data/lib/packetfu/protos/tcp.rb +176 -176
  49. data/lib/packetfu/protos/tcp/ecn.rb +35 -35
  50. data/lib/packetfu/protos/tcp/flags.rb +74 -74
  51. data/lib/packetfu/protos/tcp/header.rb +268 -268
  52. data/lib/packetfu/protos/tcp/hlen.rb +32 -32
  53. data/lib/packetfu/protos/tcp/mixin.rb +46 -46
  54. data/lib/packetfu/protos/tcp/option.rb +321 -321
  55. data/lib/packetfu/protos/tcp/options.rb +95 -95
  56. data/lib/packetfu/protos/tcp/reserved.rb +35 -35
  57. data/lib/packetfu/protos/udp.rb +159 -123
  58. data/lib/packetfu/protos/udp/header.rb +91 -91
  59. data/lib/packetfu/protos/udp/mixin.rb +3 -3
  60. data/lib/packetfu/structfu.rb +280 -280
  61. data/lib/packetfu/utils.rb +292 -225
  62. data/lib/packetfu/version.rb +41 -41
  63. data/packetfu.gemspec +14 -3
  64. data/spec/arp_spec.rb +191 -0
  65. data/spec/eth_spec.rb +148 -0
  66. data/spec/icmp_spec.rb +97 -0
  67. data/spec/ip_spec.rb +78 -0
  68. data/spec/ipv6_spec.rb +81 -0
  69. data/spec/packet_spec.rb +61 -59
  70. data/spec/packet_subclasses_spec.rb +9 -10
  71. data/spec/packetfu_spec.rb +55 -62
  72. data/spec/sample3.pcap +0 -0
  73. data/spec/spec_helper.rb +44 -0
  74. data/spec/structfu_spec.rb +270 -271
  75. data/spec/tcp_spec.rb +76 -77
  76. data/spec/udp_spec.rb +32 -0
  77. data/spec/utils_spec.rb +95 -0
  78. data/test/all_tests.rb +14 -17
  79. data/test/func_lldp.rb +3 -3
  80. data/test/ptest.rb +2 -2
  81. data/test/test_capture.rb +45 -45
  82. data/test/test_eth.rb +70 -68
  83. data/test/test_hsrp.rb +9 -9
  84. data/test/test_inject.rb +18 -18
  85. data/test/test_invalid.rb +16 -16
  86. data/test/test_octets.rb +23 -21
  87. data/test/test_packet.rb +156 -154
  88. data/test/test_pcap.rb +172 -170
  89. data/test/test_structfu.rb +99 -97
  90. data/test/test_tcp.rb +322 -320
  91. data/test/test_udp.rb +78 -76
  92. metadata +108 -44
  93. metadata.gz.sig +2 -0
  94. data/spec/ethpacket_spec.rb +0 -74
  95. data/test/test_arp.rb +0 -135
  96. data/test/test_icmp.rb +0 -62
  97. data/test/test_ip.rb +0 -50
  98. data/test/test_ip6.rb +0 -68
@@ -1,208 +1,210 @@
1
1
  #!/usr/bin/env ruby
2
+ # -*- coding: binary -*-
3
+
2
4
  require 'test/unit'
3
5
  $:.unshift File.join(File.expand_path(File.dirname(__FILE__)), "..", "lib")
4
6
  require 'packetfu'
5
7
 
6
8
  class PcapHeaderTest < Test::Unit::TestCase
7
- include PacketFu
8
- def setup
9
- @file = File.open('sample.pcap') {|f| f.read}
10
- @file.force_encoding "binary" if @file.respond_to? :force_encoding
11
- @file_magic = @file[0,4]
12
- @file_header = @file[0,24]
13
- end
14
-
15
- def test_header_size
16
- assert_equal(24, PcapHeader.new.sz)
17
- assert_equal(24, PcapHeader.new.sz)
18
- end
19
-
20
- # If this fails, the rest is pretty much for naught.
21
- def test_read_file
22
- assert_equal("\xd4\xc3\xb2\xa1", @file_magic) # yep, it's libpcap.
23
- end
24
-
25
- def test_endian_magic
26
- p = PcapHeader.new # usual case
27
- assert_equal(@file_magic, p.to_s[0,4])
28
- p = PcapHeader.new(:endian => :big)
29
- assert_equal("\xa1\xb2\xc3\xd4", p.to_s[0,4])
30
- end
31
-
32
- def test_header
33
- p = PcapHeader.new
34
- assert_equal(@file_header, p.to_s[0,24])
35
- p = PcapHeader.new(:endian => :big)
36
- assert_not_equal(@file_header, p.to_s[0,24])
37
- # We want to ensure our endianness is little or big.
38
- assert_raise(ArgumentError) {PcapHeader.new(:endian => :just_right)}
39
- end
40
-
41
- def test_header_read
42
- p = PcapHeader.new
43
- p.read @file
44
- assert_equal(@file_header,p.to_s)
45
- end
9
+ include PacketFu
10
+ def setup
11
+ @file = File.open('sample.pcap') {|f| f.read}
12
+ @file.force_encoding "binary" if @file.respond_to? :force_encoding
13
+ @file_magic = @file[0,4]
14
+ @file_header = @file[0,24]
15
+ end
16
+
17
+ def test_header_size
18
+ assert_equal(24, PcapHeader.new.sz)
19
+ assert_equal(24, PcapHeader.new.sz)
20
+ end
21
+
22
+ # If this fails, the rest is pretty much for naught.
23
+ def test_read_file
24
+ assert_equal("\xd4\xc3\xb2\xa1", @file_magic) # yep, it's libpcap.
25
+ end
26
+
27
+ def test_endian_magic
28
+ p = PcapHeader.new # usual case
29
+ assert_equal(@file_magic, p.to_s[0,4])
30
+ p = PcapHeader.new(:endian => :big)
31
+ assert_equal("\xa1\xb2\xc3\xd4", p.to_s[0,4])
32
+ end
33
+
34
+ def test_header
35
+ p = PcapHeader.new
36
+ assert_equal(@file_header, p.to_s[0,24])
37
+ p = PcapHeader.new(:endian => :big)
38
+ assert_not_equal(@file_header, p.to_s[0,24])
39
+ # We want to ensure our endianness is little or big.
40
+ assert_raise(ArgumentError) {PcapHeader.new(:endian => :just_right)}
41
+ end
42
+
43
+ def test_header_read
44
+ p = PcapHeader.new
45
+ p.read @file
46
+ assert_equal(@file_header,p.to_s)
47
+ end
46
48
 
47
49
  end
48
50
 
49
51
  class TimestampTest < Test::Unit::TestCase
50
- include PacketFu
51
- def setup
52
- @file = File.open('sample.pcap') {|f| f.read}
53
- @ts = @file[24,8]
54
- end
55
-
56
- def test_timestamp_size
57
- assert_equal(3, Timestamp.new.size) # Number of elements
58
- assert_equal(8, Timestamp.new.sz) # Length of the string (in PacketFu)
59
- end
60
-
61
- def test_timestamp_read
62
- t = Timestamp.new
63
- t.read(@ts)
64
- assert_equal(@ts, t.to_s)
65
- end
52
+ include PacketFu
53
+ def setup
54
+ @file = File.open('sample.pcap') {|f| f.read}
55
+ @ts = @file[24,8]
56
+ end
57
+
58
+ def test_timestamp_size
59
+ assert_equal(3, Timestamp.new.size) # Number of elements
60
+ assert_equal(8, Timestamp.new.sz) # Length of the string (in PacketFu)
61
+ end
62
+
63
+ def test_timestamp_read
64
+ t = Timestamp.new
65
+ t.read(@ts)
66
+ assert_equal(@ts, t.to_s)
67
+ end
66
68
  end
67
69
 
68
70
  class PcapPacketTest < Test::Unit::TestCase
69
- include PacketFu
70
- def setup
71
- @file = File.open('sample.pcap') {|f| f.read}
72
- @file.force_encoding "binary" if @file.respond_to? :force_encoding
73
- @header = @file[0,24]
74
- @packet = @file[24,100] # pkt is 78 bytes + 16 bytes pcap hdr == 94
75
- end
76
-
77
- def test_pcappacket_read
78
- p = PcapPacket.new :endian => :little
79
- p.read(@packet)
80
- assert_equal(78,@packet[8,4].unpack("V").first)
81
- assert_equal(@packet[8,4].unpack("V").first,p[:incl_len].to_i)
82
- assert_equal(@packet[0,94],p.to_s)
83
- end
71
+ include PacketFu
72
+ def setup
73
+ @file = File.open('sample.pcap') {|f| f.read}
74
+ @file.force_encoding "binary" if @file.respond_to? :force_encoding
75
+ @header = @file[0,24]
76
+ @packet = @file[24,100] # pkt is 78 bytes + 16 bytes pcap hdr == 94
77
+ end
78
+
79
+ def test_pcappacket_read
80
+ p = PcapPacket.new :endian => :little
81
+ p.read(@packet)
82
+ assert_equal(78,@packet[8,4].unpack("V").first)
83
+ assert_equal(@packet[8,4].unpack("V").first,p[:incl_len].to_i)
84
+ assert_equal(@packet[0,94],p.to_s)
85
+ end
84
86
 
85
87
  end
86
88
 
87
89
  class PcapPacketsTest < Test::Unit::TestCase
88
90
 
89
- include PacketFu
90
- def setup
91
- @file = File.open('sample.pcap') {|f| f.read}
92
- end
91
+ include PacketFu
92
+ def setup
93
+ @file = File.open('sample.pcap') {|f| f.read}
94
+ end
93
95
 
94
- def test_pcappackets_read
95
- p = PcapPackets.new
96
- p.read @file
97
- assert_equal(11,p.size)
98
- assert_equal(@file[24,@file.size],p.to_s)
99
- end
96
+ def test_pcappackets_read
97
+ p = PcapPackets.new
98
+ p.read @file
99
+ assert_equal(11,p.size)
100
+ assert_equal(@file[24,@file.size],p.to_s)
101
+ end
100
102
 
101
103
  end
102
104
 
103
105
  class PcapFileTest < Test::Unit::TestCase
104
- require 'digest/md5'
105
-
106
- include PacketFu
107
- def setup
108
- @file = File.open('sample.pcap') {|f| f.read}
109
- @md5 = '1be3b5082bb135c6f22de8801feb3495'
110
- end
111
-
112
- def test_pcapfile_read
113
- p = PcapFile.new
114
- p.read @file
115
- assert_equal(3,p.size)
116
- assert_equal(@file.size, p.sz)
117
- assert_equal(@file, p.to_s)
118
- end
119
-
120
- def test_pcapfile_file_to_array
121
- p = PcapFile.new.file_to_array(:filename => 'sample.pcap')
122
- assert_equal(@md5.downcase, Digest::MD5.hexdigest(@file).downcase)
123
- assert_instance_of(Array, p)
124
- assert_instance_of(String, p[0])
125
- assert_equal(11,p.size)
126
- assert_equal(78,p[0].size)
127
- assert_equal(94,p[1].size)
128
- assert_equal(74,p[10].size)
129
- end
130
-
131
- def test_pcapfile_read_and_write
132
- File.unlink('out.pcap') if File.exists? 'out.pcap'
133
- p = PcapFile.new
134
- p.read @file
135
- p.to_file(:filename => 'out.pcap')
136
- @newfile = File.open('out.pcap') {|f| f.read(f.stat.size)}
137
- @newfile.force_encoding "binary" if @newfile.respond_to? :force_encoding
138
- assert_equal(@file, @newfile)
139
- p.to_file(:filename => 'out.pcap', :append => true)
140
- packet_array = PcapFile.new.f2a(:filename => 'out.pcap')
141
- assert_equal(22, packet_array.size)
142
- end
143
-
144
- def test_pcapfile_write_after_recalc
145
- File.unlink('out.pcap') if File.exists? 'out.pcap'
146
- pcaps = PcapFile.new.file_to_array(:filename => 'sample.pcap')
147
- pcaps.each {|pkt|
148
- p = Packet.parse pkt
149
- p.recalc
150
- p.to_f('out.pcap','a')
151
- }
152
- packet_array = PcapFile.new.f2a(:filename => 'out.pcap')
153
- assert_equal(11, packet_array.size)
154
- File.unlink('out.pcap')
155
- end
156
-
157
- def test_pcapfile_read_and_write_timestamps
158
- File.unlink('out.pcap') if File.exists? 'out.pcap'
159
- pf = PcapFile.new
160
- arr = pf.file_to_array(:filename => 'sample.pcap')
161
- assert_equal(11, arr.size)
162
- pf = PcapFile.new
163
- pf.a2f(:array => arr, :f => 'out.pcap', :ts_inc => 4,
164
- :timestamp => Time.now.to_i - 1_000_000)
165
- diff_time = pf.body[0].timestamp.sec.to_i - pf.body[1].timestamp.sec.to_i
166
- assert_equal(-4, diff_time)
167
- File.unlink('out.pcap')
168
- end
106
+ require 'digest/md5'
107
+
108
+ include PacketFu
109
+ def setup
110
+ @file = File.open('sample.pcap') {|f| f.read}
111
+ @md5 = '1be3b5082bb135c6f22de8801feb3495'
112
+ end
113
+
114
+ def test_pcapfile_read
115
+ p = PcapFile.new
116
+ p.read @file
117
+ assert_equal(3,p.size)
118
+ assert_equal(@file.size, p.sz)
119
+ assert_equal(@file, p.to_s)
120
+ end
121
+
122
+ def test_pcapfile_file_to_array
123
+ p = PcapFile.new.file_to_array(:filename => 'sample.pcap')
124
+ assert_equal(@md5.downcase, Digest::MD5.hexdigest(@file).downcase)
125
+ assert_instance_of(Array, p)
126
+ assert_instance_of(String, p[0])
127
+ assert_equal(11,p.size)
128
+ assert_equal(78,p[0].size)
129
+ assert_equal(94,p[1].size)
130
+ assert_equal(74,p[10].size)
131
+ end
132
+
133
+ def test_pcapfile_read_and_write
134
+ File.unlink('out.pcap') if File.exists? 'out.pcap'
135
+ p = PcapFile.new
136
+ p.read @file
137
+ p.to_file(:filename => 'out.pcap')
138
+ @newfile = File.open('out.pcap') {|f| f.read(f.stat.size)}
139
+ @newfile.force_encoding "binary" if @newfile.respond_to? :force_encoding
140
+ assert_equal(@file, @newfile)
141
+ p.to_file(:filename => 'out.pcap', :append => true)
142
+ packet_array = PcapFile.new.f2a(:filename => 'out.pcap')
143
+ assert_equal(22, packet_array.size)
144
+ end
145
+
146
+ def test_pcapfile_write_after_recalc
147
+ File.unlink('out.pcap') if File.exists? 'out.pcap'
148
+ pcaps = PcapFile.new.file_to_array(:filename => 'sample.pcap')
149
+ pcaps.each {|pkt|
150
+ p = Packet.parse pkt
151
+ p.recalc
152
+ p.to_f('out.pcap','a')
153
+ }
154
+ packet_array = PcapFile.new.f2a(:filename => 'out.pcap')
155
+ assert_equal(11, packet_array.size)
156
+ File.unlink('out.pcap')
157
+ end
158
+
159
+ def test_pcapfile_read_and_write_timestamps
160
+ File.unlink('out.pcap') if File.exists? 'out.pcap'
161
+ pf = PcapFile.new
162
+ arr = pf.file_to_array(:filename => 'sample.pcap')
163
+ assert_equal(11, arr.size)
164
+ pf = PcapFile.new
165
+ pf.a2f(:array => arr, :f => 'out.pcap', :ts_inc => 4,
166
+ :timestamp => Time.now.to_i - 1_000_000)
167
+ diff_time = pf.body[0].timestamp.sec.to_i - pf.body[1].timestamp.sec.to_i
168
+ assert_equal(-4, diff_time)
169
+ File.unlink('out.pcap')
170
+ end
169
171
 
170
172
  end
171
-
173
+
172
174
  # Test the legacy Read objects.
173
175
  class ReadTest < Test::Unit::TestCase
174
176
 
175
- include PacketFu
176
-
177
- def test_read_string
178
- pkts = Read.file_to_array(:file => 'sample.pcap')
179
- assert_kind_of Array, pkts
180
- assert_equal 11, pkts.size
181
- this_packet = Packet.parse pkts[0]
182
- assert_kind_of UDPPacket, this_packet
183
- that_packet = Packet.parse pkts[3]
184
- assert_kind_of ICMPPacket, that_packet
185
- end
186
-
187
- def test_read_hash
188
- pkts = Read.file_to_array(:file => 'sample.pcap', :ts => true)
189
- assert_kind_of Array, pkts
190
- assert_equal 11, pkts.size
191
- this_packet = Packet.parse pkts[0].values.first
192
- assert_kind_of UDPPacket, this_packet
193
- that_packet = Packet.parse pkts[3].values.first
194
- assert_kind_of ICMPPacket, that_packet
195
- end
177
+ include PacketFu
178
+
179
+ def test_read_string
180
+ pkts = Read.file_to_array(:file => 'sample.pcap')
181
+ assert_kind_of Array, pkts
182
+ assert_equal 11, pkts.size
183
+ this_packet = Packet.parse pkts[0]
184
+ assert_kind_of UDPPacket, this_packet
185
+ that_packet = Packet.parse pkts[3]
186
+ assert_kind_of ICMPPacket, that_packet
187
+ end
188
+
189
+ def test_read_hash
190
+ pkts = Read.file_to_array(:file => 'sample.pcap', :ts => true)
191
+ assert_kind_of Array, pkts
192
+ assert_equal 11, pkts.size
193
+ this_packet = Packet.parse pkts[0].values.first
194
+ assert_kind_of UDPPacket, this_packet
195
+ that_packet = Packet.parse pkts[3].values.first
196
+ assert_kind_of ICMPPacket, that_packet
197
+ end
196
198
 
197
199
  end
198
200
 
199
201
  class WriteTest < Test::Unit::TestCase
200
202
 
201
- include PacketFu
203
+ include PacketFu
202
204
 
203
- def test_write
205
+ def test_write
204
206
 
205
- end
207
+ end
206
208
 
207
209
  end
208
210
 
@@ -1,111 +1,113 @@
1
1
  #!/usr/bin/env ruby
2
+ # -*- coding: binary -*-
3
+
2
4
  require 'test/unit'
3
5
  $:.unshift File.join(File.expand_path(File.dirname(__FILE__)), "..", "lib")
4
6
  require 'packetfu'
5
7
 
6
8
  # Whee unit testing.
7
9
  class IntStringTest < Test::Unit::TestCase
8
- include StructFu
9
-
10
- def test_intstring_len
11
- s = IntString.new("hello!", Int32)
12
- assert_equal(s.len, s.int.v)
13
- assert_not_equal(s.len, s.length)
14
- s.len=10
15
- assert_equal(s.len, s[:int][:value])
16
- end
17
-
18
- def test_intstring_to_s
19
- s = IntString.new("hello!", Int16)
20
- assert_equal("\x00\x06hello!",s.to_s)
21
- s.len=10
22
- assert_equal("\x00\x0ahello!",s.to_s)
23
- s = IntString.new("hello!", Int16, :parse)
24
- s.len=10
25
- assert_equal("\x00\x0ahello!\x00\x00\x00\x00",s.to_s)
26
- s = IntString.new("hello!", Int16, :fix)
27
- s.len=10
28
- assert_equal("\x00\x06hello!",s.to_s)
29
- end
30
-
31
- def test_intstring_new
32
- assert_equal("\x06Hello!",IntString.new("Hello!").to_s)
33
- assert_equal("\x00\x06Hello!",IntString.new("Hello!",Int16).to_s)
34
- assert_equal("\x06\x00\x00\x00Hello!",IntString.new("Hello!",Int32le).to_s)
35
- end
36
-
37
- def test_intstring_read
38
- s = IntString.new
39
- s.read("\x06Hello!")
40
- assert_equal("Hello!", s.string)
41
- assert_equal("Hello!", s[:string])
42
- assert_equal(6, s.int.value)
43
- assert_equal(6, s.len)
44
- end
45
-
46
- def test_intstring_parse
47
- s = IntString.new
48
- s[:mode] = :parse
49
- s.parse("\x02Hello!")
50
- assert_equal("He", s.string)
51
- assert_equal(2, s.int.v)
52
- s.parse("\x0aHello!")
53
- assert_equal("Hello!\x00\x00\x00\x00", s.string)
54
- s[:mode] = :fix
55
- s.parse("\x0aHello!")
56
- assert_equal("Hello!", s.string)
57
- end
58
-
59
- def test_intstring_nocalc
60
- s = IntString.new
61
- s[:string] = "Hello"
62
- assert_equal(0,s.int.value)
63
- end
10
+ include StructFu
11
+
12
+ def test_intstring_len
13
+ s = IntString.new("hello!", Int32)
14
+ assert_equal(s.len, s.int.v)
15
+ assert_not_equal(s.len, s.length)
16
+ s.len=10
17
+ assert_equal(s.len, s[:int][:value])
18
+ end
19
+
20
+ def test_intstring_to_s
21
+ s = IntString.new("hello!", Int16)
22
+ assert_equal("\x00\x06hello!",s.to_s)
23
+ s.len=10
24
+ assert_equal("\x00\x0ahello!",s.to_s)
25
+ s = IntString.new("hello!", Int16, :parse)
26
+ s.len=10
27
+ assert_equal("\x00\x0ahello!\x00\x00\x00\x00",s.to_s)
28
+ s = IntString.new("hello!", Int16, :fix)
29
+ s.len=10
30
+ assert_equal("\x00\x06hello!",s.to_s)
31
+ end
32
+
33
+ def test_intstring_new
34
+ assert_equal("\x06Hello!",IntString.new("Hello!").to_s)
35
+ assert_equal("\x00\x06Hello!",IntString.new("Hello!",Int16).to_s)
36
+ assert_equal("\x06\x00\x00\x00Hello!",IntString.new("Hello!",Int32le).to_s)
37
+ end
38
+
39
+ def test_intstring_read
40
+ s = IntString.new
41
+ s.read("\x06Hello!")
42
+ assert_equal("Hello!", s.string)
43
+ assert_equal("Hello!", s[:string])
44
+ assert_equal(6, s.int.value)
45
+ assert_equal(6, s.len)
46
+ end
47
+
48
+ def test_intstring_parse
49
+ s = IntString.new
50
+ s[:mode] = :parse
51
+ s.parse("\x02Hello!")
52
+ assert_equal("He", s.string)
53
+ assert_equal(2, s.int.v)
54
+ s.parse("\x0aHello!")
55
+ assert_equal("Hello!\x00\x00\x00\x00", s.string)
56
+ s[:mode] = :fix
57
+ s.parse("\x0aHello!")
58
+ assert_equal("Hello!", s.string)
59
+ end
60
+
61
+ def test_intstring_nocalc
62
+ s = IntString.new
63
+ s[:string] = "Hello"
64
+ assert_equal(0,s.int.value)
65
+ end
64
66
 
65
67
  end
66
68
 
67
69
  class IntTest < Test::Unit::TestCase
68
- include StructFu
69
-
70
- def test_int_to_s
71
- assert_equal("\x02",Int8.new(2).to_s)
72
- assert_equal("\x00\x07",Int16.new(7).to_s)
73
- assert_equal("\x00\x00\x00\x0a",Int32.new(10).to_s)
74
- end
75
-
76
- def test_int_big
77
- assert_equal("\x00\x07",Int16be.new(7).to_s)
78
- assert_equal("\x00\x00\x00\x0a",Int32be.new(10).to_s)
79
- end
80
-
81
- def test_int_little
82
- assert_equal("\x07\x00",Int16le.new(7).to_s)
83
- assert_equal("\x01\x04\x00\x00",Int32le.new(1025).to_s)
84
- end
85
-
86
- def test_read
87
- assert_equal(7,Int16.new.read("\x00\x07").to_i)
88
- assert_equal(Int32.new.read("\x00\x00\x00\x0a").to_i,10)
89
- i = Int32.new
90
- i.read("\x00\x00\x00\xff")
91
- assert_equal(i.v, 255)
92
- assert_equal(7, Int16le.new.read("\x07\x00").to_i)
93
- assert_equal(1025,Int32le.new.read("\x01\x04\x00\x00").to_i)
94
- i = Int32le.new
95
- i.read("\xff\x00\x00\x00")
96
- assert_equal(i.v, 255)
97
- end
98
-
99
- def test_int_compare
100
- little = Int32le.new
101
- big = Int32be.new
102
- little.v = 128
103
- big.v = 0x80
104
- assert_not_equal(little.to_s, big.to_s)
105
- assert_equal(little.v, big.v)
106
- assert_equal(little[:value], big[:value])
107
- assert_equal(little.value, big.value)
108
- end
70
+ include StructFu
71
+
72
+ def test_int_to_s
73
+ assert_equal("\x02",Int8.new(2).to_s)
74
+ assert_equal("\x00\x07",Int16.new(7).to_s)
75
+ assert_equal("\x00\x00\x00\x0a",Int32.new(10).to_s)
76
+ end
77
+
78
+ def test_int_big
79
+ assert_equal("\x00\x07",Int16be.new(7).to_s)
80
+ assert_equal("\x00\x00\x00\x0a",Int32be.new(10).to_s)
81
+ end
82
+
83
+ def test_int_little
84
+ assert_equal("\x07\x00",Int16le.new(7).to_s)
85
+ assert_equal("\x01\x04\x00\x00",Int32le.new(1025).to_s)
86
+ end
87
+
88
+ def test_read
89
+ assert_equal(7,Int16.new.read("\x00\x07").to_i)
90
+ assert_equal(Int32.new.read("\x00\x00\x00\x0a").to_i,10)
91
+ i = Int32.new
92
+ i.read("\x00\x00\x00\xff")
93
+ assert_equal(i.v, 255)
94
+ assert_equal(7, Int16le.new.read("\x07\x00").to_i)
95
+ assert_equal(1025,Int32le.new.read("\x01\x04\x00\x00").to_i)
96
+ i = Int32le.new
97
+ i.read("\xff\x00\x00\x00")
98
+ assert_equal(i.v, 255)
99
+ end
100
+
101
+ def test_int_compare
102
+ little = Int32le.new
103
+ big = Int32be.new
104
+ little.v = 128
105
+ big.v = 0x80
106
+ assert_not_equal(little.to_s, big.to_s)
107
+ assert_equal(little.v, big.v)
108
+ assert_equal(little[:value], big[:value])
109
+ assert_equal(little.value, big.value)
110
+ end
109
111
 
110
112
  end
111
113