pio 0.30.0 → 0.30.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (535) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +3 -0
  3. data/README.md +6 -53
  4. data/Rakefile +8 -6
  5. data/features/{arp.feature → arp/arp.feature} +14 -30
  6. data/features/arp/arp_reply.feature +69 -0
  7. data/features/arp/arp_request.feature +67 -0
  8. data/features/dhcp.feature +157 -162
  9. data/features/ethernet_header.feature +149 -0
  10. data/features/icmp/icmp.feature +47 -0
  11. data/features/icmp/icmp_reply.feature +93 -0
  12. data/features/icmp/icmp_request.feature +89 -0
  13. data/features/ipv4_header.feature +89 -0
  14. data/features/lldp.feature +5 -8
  15. data/features/open_flow/header.feature +13 -0
  16. data/features/open_flow/nicira_resubmit.feature +4 -22
  17. data/features/open_flow/nicira_resubmit_table.feature +6 -16
  18. data/features/open_flow10/aggregate_stats_reply.feature +5 -7
  19. data/features/open_flow10/aggregate_stats_request.feature +12 -14
  20. data/features/open_flow10/bad_request.feature +7 -24
  21. data/features/open_flow10/barrier_reply.feature +14 -25
  22. data/features/open_flow10/barrier_request.feature +12 -25
  23. data/features/open_flow10/description_stats_reply.feature +9 -7
  24. data/features/open_flow10/description_stats_request.feature +12 -25
  25. data/features/open_flow10/echo_reply.feature +14 -35
  26. data/features/open_flow10/echo_request.feature +16 -39
  27. data/features/open_flow10/enqueue.feature +3 -4
  28. data/features/open_flow10/exact_match.feature +5 -5
  29. data/features/open_flow10/features_reply.feature +28 -73
  30. data/features/open_flow10/features_request.feature +10 -28
  31. data/features/open_flow10/flow_mod.feature +4 -188
  32. data/features/open_flow10/flow_removed.feature +28 -30
  33. data/features/open_flow10/flow_stats_reply.feature +5 -89
  34. data/features/open_flow10/flow_stats_request.feature +12 -42
  35. data/features/open_flow10/hello.feature +10 -32
  36. data/features/open_flow10/hello_failed.feature +7 -57
  37. data/features/open_flow10/packet_in.feature +130 -49
  38. data/features/open_flow10/packet_out.feature +29 -18
  39. data/features/open_flow10/port_stats_request.feature +8 -29
  40. data/features/open_flow10/port_status.feature +22 -21
  41. data/features/open_flow10/queue_stats_request.feature +12 -30
  42. data/features/open_flow10/send_out_port.feature +17 -25
  43. data/features/open_flow10/set_destination_mac_address.feature +3 -4
  44. data/features/open_flow10/set_ip_destination_address.feature +3 -4
  45. data/features/open_flow10/set_source_ip_address.feature +3 -4
  46. data/features/open_flow10/set_source_mac_address.feature +3 -4
  47. data/features/open_flow10/set_tos.feature +3 -4
  48. data/features/open_flow10/set_transport_destination_port.feature +3 -4
  49. data/features/open_flow10/set_transport_source_port.feature +3 -4
  50. data/features/open_flow10/set_vlan_priority.feature +3 -4
  51. data/features/open_flow10/set_vlan_vid.feature +3 -4
  52. data/features/open_flow10/strip_vlan_header.feature +3 -4
  53. data/features/open_flow10/table_stats_request.feature +11 -13
  54. data/features/open_flow10/vendor_action.feature +4 -5
  55. data/features/open_flow13/apply_actions.feature +15 -18
  56. data/features/open_flow13/bad_request.feature +7 -13
  57. data/features/open_flow13/copy_ttl_inwards.feature +13 -0
  58. data/features/open_flow13/copy_ttl_outwards.feature +13 -0
  59. data/features/open_flow13/decrement_ip_ttl.feature +11 -0
  60. data/features/open_flow13/echo_reply.feature +16 -42
  61. data/features/open_flow13/echo_request.feature +16 -42
  62. data/features/open_flow13/features_reply.feature +4 -25
  63. data/features/open_flow13/features_request.feature +7 -36
  64. data/features/open_flow13/flow_mod.feature +16 -76
  65. data/features/open_flow13/goto_table.feature +18 -20
  66. data/features/open_flow13/hello.feature +7 -37
  67. data/features/open_flow13/hello_failed.feature +7 -30
  68. data/features/open_flow13/match.feature +239 -248
  69. data/features/open_flow13/meter.feature +18 -20
  70. data/features/open_flow13/nicira_conjunction.feature +15 -0
  71. data/features/open_flow13/nicira_reg_load.feature +27 -42
  72. data/features/open_flow13/nicira_reg_move.feature +41 -35
  73. data/features/open_flow13/nicira_send_out_port.feature +21 -13
  74. data/features/open_flow13/nicira_stack_pop.feature +26 -0
  75. data/features/open_flow13/nicira_stack_push.feature +26 -0
  76. data/features/open_flow13/packet_in.feature +7 -34
  77. data/features/open_flow13/packet_out.feature +7 -45
  78. data/features/open_flow13/send_out_port.feature +19 -28
  79. data/features/open_flow13/set_arp_operation.feature +4 -5
  80. data/features/open_flow13/set_arp_sender_hardware_address.feature +3 -4
  81. data/features/open_flow13/set_arp_sender_protocol_address.feature +3 -4
  82. data/features/open_flow13/set_destination_mac_address.feature +3 -4
  83. data/features/open_flow13/set_ip_ttl.feature +12 -0
  84. data/features/open_flow13/set_metadata.feature +3 -4
  85. data/features/open_flow13/set_source_mac_address.feature +3 -4
  86. data/features/open_flow13/stats_request.feature +4 -7
  87. data/features/open_flow13/write_metadata.feature +20 -22
  88. data/features/open_flow_read.feature +24 -5
  89. data/features/open_flow_version.feature +1 -1
  90. data/features/parser.feature +8 -9
  91. data/features/step_definitions/Gemfile +2 -0
  92. data/features/step_definitions/Guardfile +2 -0
  93. data/features/step_definitions/Rakefile +2 -0
  94. data/features/step_definitions/dump_flows_steps.rb +2 -0
  95. data/features/step_definitions/open_flow_steps.rb +13 -16
  96. data/features/step_definitions/packet_data_steps.rb +19 -33
  97. data/features/step_definitions/rest_api_steps.rb +2 -0
  98. data/features/step_definitions/ruby_steps.rb +9 -0
  99. data/features/step_definitions/show_stats_steps.rb +5 -3
  100. data/features/step_definitions/trema_steps.rb +2 -0
  101. data/features/step_definitions/virtual_link_steps.rb +2 -0
  102. data/features/support/env.rb +2 -2
  103. data/features/support/hooks.rb +4 -2
  104. data/features/udp.feature +26 -27
  105. data/lib/pio/arp/format.rb +5 -7
  106. data/lib/pio/arp/message.rb +10 -4
  107. data/lib/pio/arp/reply.rb +11 -32
  108. data/lib/pio/arp/request.rb +11 -33
  109. data/lib/pio/arp.rb +11 -6
  110. data/lib/pio/class_inspector.rb +20 -0
  111. data/lib/pio/dhcp/ack.rb +2 -0
  112. data/lib/pio/dhcp/boot_reply.rb +2 -0
  113. data/lib/pio/dhcp/boot_reply_options.rb +2 -0
  114. data/lib/pio/dhcp/boot_request.rb +2 -0
  115. data/lib/pio/dhcp/boot_request_options.rb +2 -0
  116. data/lib/pio/dhcp/client_id.rb +2 -0
  117. data/lib/pio/dhcp/common_options.rb +2 -0
  118. data/lib/pio/dhcp/dhcp_field.rb +2 -0
  119. data/lib/pio/dhcp/dhcp_tlv_options.rb +30 -20
  120. data/lib/pio/dhcp/discover.rb +2 -0
  121. data/lib/pio/dhcp/field_util.rb +3 -1
  122. data/lib/pio/dhcp/frame.rb +6 -4
  123. data/lib/pio/dhcp/message.rb +2 -0
  124. data/lib/pio/dhcp/offer.rb +2 -0
  125. data/lib/pio/dhcp/optional_tlv.rb +4 -2
  126. data/lib/pio/dhcp/parameter_list.rb +2 -0
  127. data/lib/pio/dhcp/request.rb +2 -0
  128. data/lib/pio/dhcp.rb +4 -2
  129. data/lib/pio/ethernet_frame.rb +22 -0
  130. data/lib/pio/ethernet_header.rb +37 -13
  131. data/lib/pio/icmp/format.rb +21 -22
  132. data/lib/pio/icmp/message.rb +20 -4
  133. data/lib/pio/icmp/reply.rb +10 -34
  134. data/lib/pio/icmp/request.rb +10 -43
  135. data/lib/pio/icmp.rb +10 -5
  136. data/lib/pio/instance_inspector.rb +16 -0
  137. data/lib/pio/ipv4_address.rb +13 -11
  138. data/lib/pio/ipv4_header.rb +26 -2
  139. data/lib/pio/lldp/chassis_id_tlv.rb +2 -0
  140. data/lib/pio/lldp/end_of_lldpdu_value.rb +2 -0
  141. data/lib/pio/lldp/frame.rb +4 -2
  142. data/lib/pio/lldp/management_address_value.rb +2 -0
  143. data/lib/pio/lldp/optional_tlv.rb +4 -2
  144. data/lib/pio/lldp/options.rb +4 -2
  145. data/lib/pio/lldp/organizationally_specific_value.rb +2 -0
  146. data/lib/pio/lldp/port_description_value.rb +2 -0
  147. data/lib/pio/lldp/port_id_tlv.rb +2 -0
  148. data/lib/pio/lldp/system_capabilities_value.rb +2 -0
  149. data/lib/pio/lldp/system_description_value.rb +2 -0
  150. data/lib/pio/lldp/system_name_value.rb +2 -0
  151. data/lib/pio/lldp/ttl_tlv.rb +2 -0
  152. data/lib/pio/lldp.rb +2 -0
  153. data/lib/pio/mac.rb +9 -3
  154. data/lib/pio/message.rb +52 -0
  155. data/lib/pio/message_type_selector.rb +2 -0
  156. data/lib/pio/monkey_patch/bindata_record.rb +8 -0
  157. data/lib/pio/monkey_patch/bindata_string.rb +12 -0
  158. data/lib/pio/monkey_patch/integer/base_conversions.rb +3 -1
  159. data/lib/pio/monkey_patch/integer/ranges.rb +2 -0
  160. data/lib/pio/monkey_patch/integer.rb +2 -0
  161. data/lib/pio/monkey_patch/uint/base_conversions.rb +16 -0
  162. data/lib/pio/monkey_patch/uint.rb +11 -0
  163. data/lib/pio/open_flow/action.rb +10 -4
  164. data/lib/pio/open_flow/buffer_id.rb +21 -0
  165. data/lib/pio/open_flow/datapath_id.rb +5 -3
  166. data/lib/pio/open_flow/error_message.rb +34 -0
  167. data/lib/pio/open_flow/flags.rb +17 -6
  168. data/lib/pio/open_flow/flow_match.rb +12 -0
  169. data/lib/pio/open_flow/header.rb +28 -0
  170. data/lib/pio/open_flow/hello_failed_code.rb +3 -1
  171. data/lib/pio/open_flow/instruction.rb +12 -0
  172. data/lib/pio/open_flow/message.rb +51 -14
  173. data/lib/pio/open_flow/nicira_action.rb +2 -0
  174. data/lib/pio/open_flow/nicira_resubmit.rb +15 -11
  175. data/lib/pio/open_flow/nicira_resubmit_table.rb +19 -10
  176. data/lib/pio/open_flow/parser.rb +21 -0
  177. data/lib/pio/open_flow/port.rb +4 -2
  178. data/lib/pio/open_flow/transaction_id.rb +4 -2
  179. data/lib/pio/open_flow/version.rb +24 -0
  180. data/lib/pio/open_flow.rb +40 -52
  181. data/lib/pio/open_flow10/actions.rb +18 -16
  182. data/lib/pio/open_flow10/aggregate_stats/reply.rb +4 -1
  183. data/lib/pio/open_flow10/aggregate_stats/request.rb +3 -3
  184. data/lib/pio/open_flow10/barrier/reply.rb +3 -1
  185. data/lib/pio/open_flow10/barrier/request.rb +3 -1
  186. data/lib/pio/open_flow10/description_stats/reply.rb +3 -1
  187. data/lib/pio/open_flow10/description_stats/request.rb +3 -3
  188. data/lib/pio/open_flow10/echo/reply.rb +5 -3
  189. data/lib/pio/open_flow10/echo/request.rb +5 -3
  190. data/lib/pio/open_flow10/enqueue.rb +5 -3
  191. data/lib/pio/open_flow10/error/bad_request/bad_request_code.rb +37 -0
  192. data/lib/pio/open_flow10/error/bad_request.rb +7 -29
  193. data/lib/pio/open_flow10/error/error_type10.rb +3 -1
  194. data/lib/pio/open_flow10/error/hello_failed.rb +8 -4
  195. data/lib/pio/open_flow10/error.rb +5 -13
  196. data/lib/pio/open_flow10/exact_match.rb +14 -10
  197. data/lib/pio/open_flow10/features/reply.rb +35 -48
  198. data/lib/pio/open_flow10/features/request.rb +3 -4
  199. data/lib/pio/open_flow10/features.rb +2 -0
  200. data/lib/pio/open_flow10/flow_mod/command.rb +30 -0
  201. data/lib/pio/open_flow10/flow_mod.rb +10 -33
  202. data/lib/pio/open_flow10/flow_removed/reason.rb +24 -0
  203. data/lib/pio/open_flow10/flow_removed.rb +4 -17
  204. data/lib/pio/open_flow10/flow_stats/reply.rb +5 -4
  205. data/lib/pio/open_flow10/flow_stats/request.rb +3 -3
  206. data/lib/pio/open_flow10/hello.rb +3 -4
  207. data/lib/pio/open_flow10/match.rb +16 -13
  208. data/lib/pio/open_flow10/match10.rb +2 -0
  209. data/lib/pio/open_flow10/packet_in/reason.rb +27 -0
  210. data/lib/pio/open_flow10/packet_in.rb +34 -28
  211. data/lib/pio/open_flow10/packet_out.rb +7 -6
  212. data/lib/pio/open_flow10/phy_port16.rb +41 -61
  213. data/lib/pio/open_flow10/port16.rb +2 -0
  214. data/lib/pio/open_flow10/port_stats/request.rb +3 -3
  215. data/lib/pio/open_flow10/port_status/reason.rb +23 -0
  216. data/lib/pio/open_flow10/port_status.rb +25 -30
  217. data/lib/pio/open_flow10/queue_stats/request.rb +3 -3
  218. data/lib/pio/open_flow10/send_out_port.rb +4 -2
  219. data/lib/pio/open_flow10/set_destination_ip_address.rb +2 -0
  220. data/lib/pio/open_flow10/set_destination_mac_address.rb +2 -0
  221. data/lib/pio/open_flow10/set_source_ip_address.rb +2 -0
  222. data/lib/pio/open_flow10/set_source_mac_address.rb +2 -0
  223. data/lib/pio/open_flow10/set_tos.rb +4 -2
  224. data/lib/pio/open_flow10/set_transport_port.rb +6 -2
  225. data/lib/pio/open_flow10/set_vlan_priority.rb +3 -1
  226. data/lib/pio/open_flow10/set_vlan_vid.rb +3 -1
  227. data/lib/pio/open_flow10/stats_reply.rb +9 -10
  228. data/lib/pio/open_flow10/stats_request.rb +18 -15
  229. data/lib/pio/open_flow10/stats_type.rb +3 -1
  230. data/lib/pio/open_flow10/strip_vlan_header.rb +2 -0
  231. data/lib/pio/open_flow10/table_stats/request.rb +3 -3
  232. data/lib/pio/open_flow10/vendor_action.rb +24 -20
  233. data/lib/pio/open_flow10.rb +2 -0
  234. data/lib/pio/open_flow13/actions.rb +36 -32
  235. data/lib/pio/open_flow13/apply.rb +27 -22
  236. data/lib/pio/open_flow13/copy_ttl_inwards.rb +17 -0
  237. data/lib/pio/open_flow13/copy_ttl_outwards.rb +17 -0
  238. data/lib/pio/open_flow13/decrement_ip_ttl.rb +17 -0
  239. data/lib/pio/open_flow13/echo/reply.rb +5 -3
  240. data/lib/pio/open_flow13/echo/request.rb +5 -3
  241. data/lib/pio/open_flow13/error/bad_request.rb +6 -3
  242. data/lib/pio/open_flow13/error/error_type13.rb +3 -1
  243. data/lib/pio/open_flow13/error/hello_failed.rb +5 -2
  244. data/lib/pio/open_flow13/error.rb +9 -18
  245. data/lib/pio/open_flow13/features/reply.rb +15 -20
  246. data/lib/pio/open_flow13/features/request.rb +3 -1
  247. data/lib/pio/open_flow13/flow_mod.rb +16 -19
  248. data/lib/pio/open_flow13/goto_table.rb +28 -24
  249. data/lib/pio/open_flow13/hello.rb +5 -4
  250. data/lib/pio/open_flow13/match.rb +187 -21
  251. data/lib/pio/open_flow13/meter.rb +25 -20
  252. data/lib/pio/open_flow13/nicira_conjunction.rb +28 -0
  253. data/lib/pio/open_flow13/nicira_reg_load.rb +46 -24
  254. data/lib/pio/open_flow13/nicira_reg_move.rb +79 -35
  255. data/lib/pio/open_flow13/nicira_send_out_port.rb +39 -21
  256. data/lib/pio/open_flow13/nicira_stack_pop.rb +51 -0
  257. data/lib/pio/open_flow13/nicira_stack_push.rb +51 -0
  258. data/lib/pio/open_flow13/packet_in.rb +13 -8
  259. data/lib/pio/open_flow13/packet_out.rb +11 -8
  260. data/lib/pio/open_flow13/port32.rb +2 -0
  261. data/lib/pio/open_flow13/send_out_port.rb +2 -0
  262. data/lib/pio/open_flow13/set_arp_operation.rb +2 -0
  263. data/lib/pio/open_flow13/set_arp_sender_hardware_address.rb +2 -0
  264. data/lib/pio/open_flow13/set_arp_sender_protocol_address.rb +2 -0
  265. data/lib/pio/open_flow13/set_destination_mac_address.rb +2 -0
  266. data/lib/pio/open_flow13/set_ip_ttl.rb +18 -0
  267. data/lib/pio/open_flow13/set_metadata.rb +2 -0
  268. data/lib/pio/open_flow13/set_source_mac_address.rb +2 -0
  269. data/lib/pio/open_flow13/stats_request.rb +10 -10
  270. data/lib/pio/open_flow13/write_metadata.rb +42 -38
  271. data/lib/pio/open_flow13.rb +9 -0
  272. data/lib/pio/options.rb +10 -3
  273. data/lib/pio/parse_error.rb +2 -0
  274. data/lib/pio/parser.rb +9 -16
  275. data/lib/pio/payload.rb +2 -0
  276. data/lib/pio/pcap.rb +2 -0
  277. data/lib/pio/ruby_dumper.rb +71 -0
  278. data/lib/pio/type/ether_type.rb +33 -0
  279. data/lib/pio/type/ip_address.rb +10 -0
  280. data/lib/pio/type/ipv6_address.rb +2 -0
  281. data/lib/pio/type/mac_address.rb +12 -0
  282. data/lib/pio/udp.rb +5 -3
  283. data/lib/pio/udp_header.rb +3 -1
  284. data/lib/pio/version.rb +3 -1
  285. data/lib/pio.rb +3 -1
  286. data/pio.gemspec +7 -38
  287. data/spec/pio/arp/reply_spec.rb +2 -4
  288. data/spec/pio/arp/request_spec.rb +2 -4
  289. data/spec/pio/arp_spec.rb +2 -4
  290. data/spec/pio/dhcp/ack_spec.rb +2 -0
  291. data/spec/pio/dhcp/discover_spec.rb +2 -0
  292. data/spec/pio/dhcp/offer_spec.rb +2 -0
  293. data/spec/pio/dhcp/request_spec.rb +2 -0
  294. data/spec/pio/dhcp_spec.rb +2 -0
  295. data/spec/pio/icmp/reply_spec.rb +6 -8
  296. data/spec/pio/icmp/request_spec.rb +8 -10
  297. data/spec/pio/icmp_spec.rb +10 -12
  298. data/spec/pio/ipv4_address_spec.rb +2 -0
  299. data/spec/pio/lldp/options_spec.rb +2 -0
  300. data/spec/pio/mac_spec.rb +2 -0
  301. data/spec/pio/monkey_patch/integer_spec.rb +25 -0
  302. data/spec/pio/open_flow/nicira_resubmit_spec.rb +21 -0
  303. data/spec/pio/open_flow/nicira_resubmit_table_spec.rb +22 -0
  304. data/spec/pio/open_flow10/echo/reply_spec.rb +2 -0
  305. data/spec/pio/open_flow10/echo/request_spec.rb +2 -0
  306. data/spec/pio/open_flow10/enqueue_spec.rb +2 -0
  307. data/spec/pio/open_flow10/error/hello_failed_spec.rb +4 -2
  308. data/spec/pio/open_flow10/features/reply_spec.rb +2 -0
  309. data/spec/pio/open_flow10/features/request_spec.rb +2 -0
  310. data/spec/pio/open_flow10/flow_mod_spec.rb +53 -51
  311. data/spec/pio/open_flow10/flow_stats_reply_spec.rb +2 -0
  312. data/spec/pio/open_flow10/flow_stats_request_spec.rb +10 -8
  313. data/spec/pio/open_flow10/hello_spec.rb +2 -2
  314. data/spec/pio/open_flow10/match_spec.rb +106 -104
  315. data/spec/pio/open_flow10/packet_in_spec.rb +2 -0
  316. data/spec/pio/open_flow10/packet_out_spec.rb +2 -349
  317. data/spec/pio/open_flow10/phy_port16_spec.rb +9 -7
  318. data/spec/pio/open_flow10/send_out_port_spec.rb +2 -0
  319. data/spec/pio/open_flow10/set_destination_ip_address_spec.rb +2 -0
  320. data/spec/pio/open_flow10/set_destination_mac_address_spec.rb +2 -0
  321. data/spec/pio/open_flow10/set_source_ip_address_spec.rb +2 -0
  322. data/spec/pio/open_flow10/set_source_mac_address_spec.rb +2 -0
  323. data/spec/pio/open_flow10/set_tos_spec.rb +2 -0
  324. data/spec/pio/open_flow10/set_transport_destination_port_spec.rb +2 -0
  325. data/spec/pio/open_flow10/set_transport_source_port_spec.rb +2 -0
  326. data/spec/pio/open_flow10/set_vlan_priority_spec.rb +2 -0
  327. data/spec/pio/open_flow10/set_vlan_vid_spec.rb +2 -0
  328. data/spec/pio/open_flow10/strip_vlan_header_spec.rb +2 -0
  329. data/spec/pio/open_flow10/wildcards_spec.rb +2 -0
  330. data/spec/pio/open_flow13/echo_reply_spec.rb +2 -0
  331. data/spec/pio/open_flow13/echo_request_spec.rb +2 -0
  332. data/spec/pio/open_flow13/error/bad_request_spec.rb +2 -0
  333. data/spec/pio/open_flow13/error/hello_failed_spec.rb +4 -2
  334. data/spec/pio/open_flow13/features/reply_spec.rb +2 -0
  335. data/spec/pio/open_flow13/features/request_spec.rb +2 -0
  336. data/spec/pio/open_flow13/goto_table_spec.rb +4 -2
  337. data/spec/pio/open_flow13/hello_spec.rb +18 -16
  338. data/spec/pio/open_flow13/match_spec.rb +31 -29
  339. data/spec/pio/open_flow13/meter_spec.rb +4 -2
  340. data/spec/pio/open_flow13/nicira_reg_load_spec.rb +73 -0
  341. data/spec/pio/open_flow13/nicira_reg_move_spec.rb +42 -0
  342. data/spec/pio/open_flow13/nicira_send_out_port_spec.rb +31 -0
  343. data/spec/pio/open_flow13/packet_in_spec.rb +2 -0
  344. data/spec/pio/open_flow13/packet_out_spec.rb +2 -0
  345. data/spec/pio/open_flow13/write_metadata_spec.rb +5 -3
  346. data/spec/pio/open_flow_spec.rb +8 -6
  347. data/spec/spec_helper.rb +1 -12
  348. data/spec/support/shared_examples_for_openflow_messages.rb +7 -13
  349. metadata +83 -683
  350. data/LICENSE +0 -674
  351. data/bin/_guard-core +0 -16
  352. data/bin/byebug +0 -16
  353. data/bin/cc-tddium-post-worker +0 -16
  354. data/bin/cdiff +0 -16
  355. data/bin/coderay +0 -16
  356. data/bin/colortab +0 -16
  357. data/bin/coveralls +0 -16
  358. data/bin/cucumber +0 -16
  359. data/bin/decolor +0 -16
  360. data/bin/flay +0 -16
  361. data/bin/flog +0 -16
  362. data/bin/guard +0 -16
  363. data/bin/htmldiff +0 -16
  364. data/bin/inch +0 -16
  365. data/bin/ldiff +0 -16
  366. data/bin/listen +0 -16
  367. data/bin/minitar +0 -16
  368. data/bin/pry +0 -16
  369. data/bin/rake +0 -16
  370. data/bin/reek +0 -16
  371. data/bin/relish +0 -16
  372. data/bin/restclient +0 -16
  373. data/bin/rspec +0 -16
  374. data/bin/rubocop +0 -16
  375. data/bin/ruby-parse +0 -16
  376. data/bin/ruby-rewrite +0 -16
  377. data/bin/ruby_parse +0 -16
  378. data/bin/ruby_parse_extract_error +0 -16
  379. data/bin/sparkr +0 -16
  380. data/bin/term_display +0 -16
  381. data/bin/term_mandel +0 -16
  382. data/bin/terminal-notifier +0 -16
  383. data/bin/thor +0 -16
  384. data/bin/unparser +0 -16
  385. data/bin/yard +0 -16
  386. data/bin/yardoc +0 -16
  387. data/bin/yri +0 -16
  388. data/features/arp-storm.pcap +0 -0
  389. data/features/arp.pcap +0 -0
  390. data/features/dhcp.pcap +0 -0
  391. data/features/icmp.feature +0 -130
  392. data/features/icmp.pcap +0 -0
  393. data/features/icmpv6.pcap +0 -0
  394. data/features/lldp.detailed.pcap +0 -0
  395. data/features/lldp.minimal.pcap +0 -0
  396. data/features/open_flow10/aggregate_stats_reply.raw +0 -0
  397. data/features/open_flow10/aggregate_stats_request.raw +0 -0
  398. data/features/open_flow10/bad_request.raw +0 -0
  399. data/features/open_flow10/barrier_reply.raw +0 -0
  400. data/features/open_flow10/barrier_request.raw +0 -0
  401. data/features/open_flow10/description_stats_reply.raw +0 -0
  402. data/features/open_flow10/description_stats_request.raw +0 -0
  403. data/features/open_flow10/echo_reply.raw +0 -0
  404. data/features/open_flow10/echo_request.raw +0 -0
  405. data/features/open_flow10/error.raw +0 -0
  406. data/features/open_flow10/features_reply.raw +0 -0
  407. data/features/open_flow10/features_request.raw +0 -0
  408. data/features/open_flow10/flow_mod_add.raw +0 -0
  409. data/features/open_flow10/flow_mod_delete.raw +0 -0
  410. data/features/open_flow10/flow_mod_delete_strict.raw +0 -0
  411. data/features/open_flow10/flow_mod_modify.raw +0 -0
  412. data/features/open_flow10/flow_mod_modify_strict.raw +0 -0
  413. data/features/open_flow10/flow_removed.raw +0 -0
  414. data/features/open_flow10/flow_stats_reply.raw +0 -0
  415. data/features/open_flow10/flow_stats_request.raw +0 -0
  416. data/features/open_flow10/get_config_reply.raw +0 -0
  417. data/features/open_flow10/get_config_request.raw +0 -0
  418. data/features/open_flow10/hello.raw +0 -0
  419. data/features/open_flow10/hello_failed.raw +0 -0
  420. data/features/open_flow10/nx_flow_mod_add.raw +0 -0
  421. data/features/open_flow10/nx_flow_mod_delete.raw +0 -0
  422. data/features/open_flow10/nx_flow_mod_delete_strict.raw +0 -0
  423. data/features/open_flow10/nx_flow_mod_modify.raw +0 -0
  424. data/features/open_flow10/nx_flow_mod_modify_strict.raw +0 -0
  425. data/features/open_flow10/nxast_learn.raw +0 -0
  426. data/features/open_flow10/packet_in.raw +0 -0
  427. data/features/open_flow10/packet_in_arp_reply.raw +0 -0
  428. data/features/open_flow10/packet_in_arp_request.raw +0 -0
  429. data/features/open_flow10/packet_in_cbench.raw +0 -0
  430. data/features/open_flow10/packet_out.raw +0 -0
  431. data/features/open_flow10/port_mod.raw +0 -0
  432. data/features/open_flow10/port_stats_reply.raw +0 -0
  433. data/features/open_flow10/port_stats_request.raw +0 -0
  434. data/features/open_flow10/port_status.raw +0 -0
  435. data/features/open_flow10/queue_get_config_reply.raw +0 -0
  436. data/features/open_flow10/queue_get_config_request.raw +0 -0
  437. data/features/open_flow10/queue_stats_request.raw +0 -0
  438. data/features/open_flow10/set_config.raw +0 -0
  439. data/features/open_flow10/table_stats_reply.raw +0 -0
  440. data/features/open_flow10/table_stats_request.raw +0 -0
  441. data/features/open_flow10/vendor.raw +0 -0
  442. data/features/open_flow10/vendor_stats_request.raw +0 -0
  443. data/features/open_flow13/action_copy_ttl_in.raw +0 -0
  444. data/features/open_flow13/action_copy_ttl_out.raw +0 -0
  445. data/features/open_flow13/action_dec_mpls_ttl.raw +0 -0
  446. data/features/open_flow13/action_dec_nw_ttl.raw +0 -0
  447. data/features/open_flow13/action_group.raw +0 -0
  448. data/features/open_flow13/action_pop_mpls.raw +0 -0
  449. data/features/open_flow13/action_pop_pbb.raw +0 -0
  450. data/features/open_flow13/action_pop_vlan.raw +0 -0
  451. data/features/open_flow13/action_push_mpls.raw +0 -0
  452. data/features/open_flow13/action_push_pbb.raw +0 -0
  453. data/features/open_flow13/action_push_vlan.raw +0 -0
  454. data/features/open_flow13/action_set_field.raw +0 -0
  455. data/features/open_flow13/action_set_mpls_ttl.raw +0 -0
  456. data/features/open_flow13/action_set_nw_ttl.raw +0 -0
  457. data/features/open_flow13/action_set_queue.raw +0 -0
  458. data/features/open_flow13/apply_actions.raw +0 -0
  459. data/features/open_flow13/bad_request.raw +0 -0
  460. data/features/open_flow13/echo_reply_body.raw +0 -0
  461. data/features/open_flow13/echo_reply_no_body.raw +0 -0
  462. data/features/open_flow13/echo_request_body.raw +0 -0
  463. data/features/open_flow13/echo_request_no_body.raw +0 -0
  464. data/features/open_flow13/features_reply.raw +0 -0
  465. data/features/open_flow13/features_request.raw +0 -0
  466. data/features/open_flow13/flow_add_apply_no_match.raw +0 -0
  467. data/features/open_flow13/flow_mod_add_apply_no_match.raw +0 -0
  468. data/features/open_flow13/flow_mod_no_match_or_instructions.raw +0 -0
  469. data/features/open_flow13/hello_failed.raw +0 -0
  470. data/features/open_flow13/hello_no_version_bitmap.raw +0 -0
  471. data/features/open_flow13/hello_version_bitmap.raw +0 -0
  472. data/features/open_flow13/instruction_clear_actions.raw +0 -0
  473. data/features/open_flow13/instruction_goto_table.raw +0 -0
  474. data/features/open_flow13/instruction_meter.raw +0 -0
  475. data/features/open_flow13/instruction_write_actions.raw +0 -0
  476. data/features/open_flow13/instruction_write_metadata.raw +0 -0
  477. data/features/open_flow13/oxm_arp_op_field.raw +0 -0
  478. data/features/open_flow13/oxm_arp_sha_field.raw +0 -0
  479. data/features/open_flow13/oxm_arp_spa_field.raw +0 -0
  480. data/features/open_flow13/oxm_arp_tha_field.raw +0 -0
  481. data/features/open_flow13/oxm_arp_tpa_field.raw +0 -0
  482. data/features/open_flow13/oxm_ether_destination_field.raw +0 -0
  483. data/features/open_flow13/oxm_ether_source_field.raw +0 -0
  484. data/features/open_flow13/oxm_ether_type_field.raw +0 -0
  485. data/features/open_flow13/oxm_experimenter_stratos_basic_dot11.raw +0 -0
  486. data/features/open_flow13/oxm_icmpv4_code_field.raw +0 -0
  487. data/features/open_flow13/oxm_icmpv4_type_field.raw +0 -0
  488. data/features/open_flow13/oxm_in_phy_port_field.raw +0 -0
  489. data/features/open_flow13/oxm_in_port_field.raw +0 -0
  490. data/features/open_flow13/oxm_invalid_field.raw +0 -0
  491. data/features/open_flow13/oxm_ip_dscp_field.raw +0 -0
  492. data/features/open_flow13/oxm_ip_ecn_field.raw +0 -0
  493. data/features/open_flow13/oxm_ipv4_destination_field.raw +0 -0
  494. data/features/open_flow13/oxm_ipv4_source_field.raw +0 -0
  495. data/features/open_flow13/oxm_ipv6_destination_field.raw +0 -0
  496. data/features/open_flow13/oxm_ipv6_source_field.raw +0 -0
  497. data/features/open_flow13/oxm_masked_arp_sha_field.raw +0 -0
  498. data/features/open_flow13/oxm_masked_arp_spa_field.raw +0 -0
  499. data/features/open_flow13/oxm_masked_arp_tha_field.raw +0 -0
  500. data/features/open_flow13/oxm_masked_arp_tpa_field.raw +0 -0
  501. data/features/open_flow13/oxm_masked_ether_destination_field.raw +0 -0
  502. data/features/open_flow13/oxm_masked_ether_source_field.raw +0 -0
  503. data/features/open_flow13/oxm_masked_ipv4_destination_field.raw +0 -0
  504. data/features/open_flow13/oxm_masked_ipv4_source_field.raw +0 -0
  505. data/features/open_flow13/oxm_masked_ipv6_destination_field.raw +0 -0
  506. data/features/open_flow13/oxm_masked_ipv6_source_field.raw +0 -0
  507. data/features/open_flow13/oxm_masked_tunnel_id_field.raw +0 -0
  508. data/features/open_flow13/oxm_metadata_field.raw +0 -0
  509. data/features/open_flow13/oxm_metadata_masked_field.raw +0 -0
  510. data/features/open_flow13/oxm_no_fields.raw +0 -0
  511. data/features/open_flow13/oxm_sctp_destination_field.raw +0 -0
  512. data/features/open_flow13/oxm_sctp_source_field.raw +0 -0
  513. data/features/open_flow13/oxm_tcp_destination_field.raw +0 -0
  514. data/features/open_flow13/oxm_tcp_field.raw +0 -0
  515. data/features/open_flow13/oxm_tcp_source_field.raw +0 -0
  516. data/features/open_flow13/oxm_tunnel_id_field.raw +0 -0
  517. data/features/open_flow13/oxm_udp_destination_field.raw +0 -0
  518. data/features/open_flow13/oxm_udp_field.raw +0 -0
  519. data/features/open_flow13/oxm_udp_source_field.raw +0 -0
  520. data/features/open_flow13/oxm_vlan_pcp_field.raw +0 -0
  521. data/features/open_flow13/oxm_vlan_vid_field.raw +0 -0
  522. data/features/open_flow13/packet_in.raw +0 -0
  523. data/features/open_flow13/packet_out.raw +0 -0
  524. data/features/open_flow13/send_out_port.raw +0 -0
  525. data/features/open_flow13/table_stats_reply.raw +0 -0
  526. data/features/open_flow13/table_stats_request.raw +0 -0
  527. data/features/step_definitions/LICENSE +0 -675
  528. data/features/udp_no_payload.raw +0 -0
  529. data/features/udp_with_payload.raw +0 -0
  530. data/lib/pio/icmp/options.rb +0 -21
  531. data/lib/pio/open_flow/error.rb +0 -19
  532. data/lib/pio/open_flow/open_flow_header.rb +0 -31
  533. data/lib/pio/open_flow13/buffer_id.rb +0 -17
  534. data/spec/pio/arp/reply/options_spec.rb +0 -143
  535. data/spec/pio/arp/request/options_spec.rb +0 -113
@@ -0,0 +1,93 @@
1
+ Feature: Icmp::Reply
2
+ Scenario: create an ICMP reply
3
+ When I create a packet with:
4
+ """
5
+ Pio::Icmp::Reply.new(
6
+ destination_mac: '11:22:33:44:55:66',
7
+ source_mac: '66:55:44:33:22:11',
8
+ source_ip_address: '192.168.83.254',
9
+ destination_ip_address: '192.168.83.3',
10
+ icmp_identifier: 256,
11
+ icmp_sequence_number: 111,
12
+ echo_data: 'hello world'
13
+ )
14
+ """
15
+ Then the packet has the following fields and values:
16
+ | field | value |
17
+ | destination_mac | 11:22:33:44:55:66 |
18
+ | source_mac | 66:55:44:33:22:11 |
19
+ | ether_type.to_hex | 0x800 |
20
+ | ip_total_length | 50 |
21
+ | ip_protocol | 1 |
22
+ | source_ip_address | 192.168.83.254 |
23
+ | destination_ip_address | 192.168.83.3 |
24
+ | icmp_type | 0 |
25
+ | icmp_code | 0 |
26
+ | icmp_checksum | 53442 |
27
+ | icmp_identifier | 256 |
28
+ | icmp_sequence_number | 111 |
29
+ | echo_data | hello world |
30
+
31
+ Scenario: convert an ICMP reply to Ruby code
32
+ When I eval the following Ruby code:
33
+ """ruby
34
+ Pio::Icmp::Reply.new(
35
+ destination_mac: '11:22:33:44:55:66',
36
+ source_mac: '66:55:44:33:22:11',
37
+ source_ip_address: '192.168.83.254',
38
+ destination_ip_address: '192.168.83.3',
39
+ icmp_identifier: 256,
40
+ icmp_sequence_number: 0
41
+ ).to_ruby
42
+ """
43
+ Then the result of eval should be:
44
+ """ruby
45
+ [
46
+ 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, # destination_mac
47
+ 0x66, 0x55, 0x44, 0x33, 0x22, 0x11, # source_mac
48
+ 0x08, 0x00, # ether_type
49
+ 0b0100_0101, # ip_version, ip_header_length
50
+ 0x00, # ip_type_of_service
51
+ 0x00, 0x32, # ip_total_length
52
+ 0x00, 0x00, # ip_identifier
53
+ 0b000_0000000000000, # ip_flag, ip_fragment
54
+ 0x80, # ip_ttl
55
+ 0x01, # ip_protocol
56
+ 0x12, 0x79, # ip_header_checksum
57
+ 0xc0, 0xa8, 0x53, 0xfe, # source_ip_address
58
+ 0xc0, 0xa8, 0x53, 0x03, # destination_ip_address
59
+ 0x00, # icmp_type
60
+ 0x00, # icmp_code
61
+ 0xfe, 0xff, # icmp_checksum
62
+ 0x01, 0x00, # icmp_identifier
63
+ 0x00, 0x00, # icmp_sequence_number
64
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, # padding
65
+ ].pack('C20nC42')
66
+ """
67
+
68
+ Scenario: Icmp::Reply instance inspection
69
+ When I create a packet with:
70
+ """
71
+ Pio::Icmp::Reply.new(
72
+ destination_mac: '00:26:82:eb:ea:d1',
73
+ source_mac: '00:16:9d:1d:9c:c4',
74
+ source_ip_address: '1.2.3.4',
75
+ destination_ip_address: '4.3.2.1',
76
+ icmp_identifier: 256,
77
+ icmp_sequence_number: 0
78
+ ).inspect
79
+ """
80
+ Then the result of eval should be:
81
+ """
82
+ #<Pio::Icmp::Reply destination_mac: "00:26:82:eb:ea:d1", source_mac: "00:16:9d:1d:9c:c4", ether_type: 0x0800, ip_version: 4, ip_header_length: 5, ip_type_of_service: 0, ip_total_length: 50, ip_identifier: 0, ip_flag: 0, ip_fragment: 0, ip_ttl: 128, ip_protocol: 1, ip_header_checksum: 12482, source_ip_address: "1.2.3.4", destination_ip_address: "4.3.2.1", ip_option: "", icmp_type: 0, icmp_code: 0, icmp_checksum: 65279, icmp_identifier: 256, icmp_sequence_number: 0, echo_data: "">
83
+ """
84
+
85
+ Scenario: Icmp::Reply class inspection
86
+ When I eval the following Ruby code:
87
+ """ruby
88
+ Pio::Icmp::Reply.inspect
89
+ """
90
+ Then the result of eval should be:
91
+ """
92
+ Pio::Icmp::Reply(destination_mac: mac_address, source_mac: mac_address, ether_type: ether_type, vlan_pcp: bit3, vlan_cfi: bit1, vlan_vid: bit12, ether_type_vlan: uint16, ip_version: bit4, ip_header_length: bit4, ip_type_of_service: uint8, ip_total_length: uint16, ip_identifier: uint16, ip_flag: bit3, ip_fragment: bit13, ip_ttl: uint8, ip_protocol: uint8, ip_header_checksum: uint16, source_ip_address: ip_address, destination_ip_address: ip_address, ip_option: string, icmp_type: uint8, icmp_code: uint8, icmp_checksum: uint16, icmp_identifier: uint16, icmp_sequence_number: uint16, echo_data: string)
93
+ """
@@ -0,0 +1,89 @@
1
+ Feature: Icmp::Request
2
+ Scenario: create an ICMP request
3
+ When I create a packet with:
4
+ """ruby
5
+ Pio::Icmp::Request.new(
6
+ source_mac: '11:22:33:44:55:66',
7
+ destination_mac: '66:55:44:33:22:11',
8
+ source_ip_address: '192.168.83.3',
9
+ destination_ip_address: '192.168.83.254',
10
+ icmp_identifier: 256,
11
+ icmp_sequence_number: 111,
12
+ echo_data: 'hello world'
13
+ )
14
+ """
15
+ Then the packet has the following fields and values:
16
+ | field | value |
17
+ | source_mac | 11:22:33:44:55:66 |
18
+ | destination_mac | 66:55:44:33:22:11 |
19
+ | ether_type.to_hex | 0x800 |
20
+ | ip_total_length | 50 |
21
+ | ip_protocol | 1 |
22
+ | source_ip_address | 192.168.83.3 |
23
+ | destination_ip_address | 192.168.83.254 |
24
+ | icmp_type | 8 |
25
+ | icmp_code | 0 |
26
+ | icmp_checksum | 51394 |
27
+ | icmp_identifier | 256 |
28
+ | icmp_sequence_number | 111 |
29
+ | echo_data | hello world |
30
+
31
+ Scenario: convert an ICMP request to Ruby code
32
+ When I eval the following Ruby code:
33
+ """ruby
34
+ Pio::Icmp::Request.new(
35
+ destination_mac: '11:22:33:44:55:66',
36
+ source_mac: '66:55:44:33:22:11',
37
+ source_ip_address: '192.168.83.3',
38
+ destination_ip_address: '192.168.83.254'
39
+ ).to_ruby
40
+ """
41
+ Then the result of eval should be:
42
+ """ruby
43
+ [
44
+ 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, # destination_mac
45
+ 0x66, 0x55, 0x44, 0x33, 0x22, 0x11, # source_mac
46
+ 0x08, 0x00, # ether_type
47
+ 0b0100_0101, # ip_version, ip_header_length
48
+ 0x00, # ip_type_of_service
49
+ 0x00, 0x32, # ip_total_length
50
+ 0x00, 0x00, # ip_identifier
51
+ 0b000_0000000000000, # ip_flag, ip_fragment
52
+ 0x80, # ip_ttl
53
+ 0x01, # ip_protocol
54
+ 0x12, 0x79, # ip_header_checksum
55
+ 0xc0, 0xa8, 0x53, 0x03, # source_ip_address
56
+ 0xc0, 0xa8, 0x53, 0xfe, # destination_ip_address
57
+ 0x08, # icmp_type
58
+ 0x00, # icmp_code
59
+ 0xf7, 0xff, # icmp_checksum
60
+ 0x00, 0x00, # icmp_identifier
61
+ 0x00, 0x00, # icmp_sequence_number
62
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, # padding
63
+ ].pack('C20nC42')
64
+ """
65
+
66
+ Scenario: Icmp::Request instance inspection
67
+ When I create a packet with:
68
+ """ruby
69
+ Pio::Icmp::Request.new(
70
+ destination_mac: '00:26:82:eb:ea:d1',
71
+ source_mac: '00:16:9d:1d:9c:c4',
72
+ source_ip_address: '1.2.3.4',
73
+ destination_ip_address: '4.3.2.1'
74
+ ).inspect
75
+ """
76
+ Then the result of eval should be:
77
+ """
78
+ #<Pio::Icmp::Request destination_mac: "00:26:82:eb:ea:d1", source_mac: "00:16:9d:1d:9c:c4", ether_type: 0x0800, ip_version: 4, ip_header_length: 5, ip_type_of_service: 0, ip_total_length: 50, ip_identifier: 0, ip_flag: 0, ip_fragment: 0, ip_ttl: 128, ip_protocol: 1, ip_header_checksum: 12482, source_ip_address: "1.2.3.4", destination_ip_address: "4.3.2.1", ip_option: "", icmp_type: 8, icmp_code: 0, icmp_checksum: 63487, icmp_identifier: 0, icmp_sequence_number: 0, echo_data: "">
79
+ """
80
+
81
+ Scenario: Icmp::Request class inspection
82
+ When I eval the following Ruby code:
83
+ """ruby
84
+ Pio::Icmp::Request.inspect
85
+ """
86
+ Then the result of eval should be:
87
+ """
88
+ Pio::Icmp::Request(destination_mac: mac_address, source_mac: mac_address, ether_type: ether_type, vlan_pcp: bit3, vlan_cfi: bit1, vlan_vid: bit12, ether_type_vlan: uint16, ip_version: bit4, ip_header_length: bit4, ip_type_of_service: uint8, ip_total_length: uint16, ip_identifier: uint16, ip_flag: bit3, ip_fragment: bit13, ip_ttl: uint8, ip_protocol: uint8, ip_header_checksum: uint16, source_ip_address: ip_address, destination_ip_address: ip_address, ip_option: string, icmp_type: uint8, icmp_code: uint8, icmp_checksum: uint16, icmp_identifier: uint16, icmp_sequence_number: uint16, echo_data: string)
89
+ """
@@ -0,0 +1,89 @@
1
+ Feature: IPv4Header
2
+ Scenario: create an IPv4 header
3
+ When I create a packet with:
4
+ """ruby
5
+ IPv4Header.new(source_ip_address: '1.2.3.4',
6
+ destination_ip_address: '4.3.2.1')
7
+ """
8
+ Then the packet has the following fields and values:
9
+ | field | value |
10
+ | class | Pio::IPv4Header |
11
+ | ip_version | 4 |
12
+ | ip_header_length | 5 |
13
+ | ip_type_of_service | 0 |
14
+ | ip_total_length | 20 |
15
+ | ip_identifier | 0 |
16
+ | ip_flag | 0 |
17
+ | ip_fragment | 0 |
18
+ | ip_ttl | 128 |
19
+ | ip_protocol | 0 |
20
+ | ip_header_checksum | 12513 |
21
+ | source_ip_address | 1.2.3.4 |
22
+ | destination_ip_address | 4.3.2.1 |
23
+ | ip_option | |
24
+
25
+ Scenario: read an IPv4 header
26
+ Given I use the fixture "ipv4_header"
27
+ When I create a packet with:
28
+ """ruby
29
+ Pio::IPv4Header.read(eval(IO.read('ipv4_header.rb')))
30
+ """
31
+ Then the packet has the following fields and values:
32
+ | field | value |
33
+ | class | Pio::IPv4Header |
34
+ | ip_version | 4 |
35
+ | ip_header_length | 5 |
36
+ | ip_type_of_service | 0 |
37
+ | ip_total_length | 20 |
38
+ | ip_identifier | 0 |
39
+ | ip_flag | 0 |
40
+ | ip_fragment | 0 |
41
+ | ip_ttl | 128 |
42
+ | ip_protocol | 0 |
43
+ | ip_header_checksum | 12513 |
44
+ | source_ip_address | 1.2.3.4 |
45
+ | destination_ip_address | 4.3.2.1 |
46
+ | ip_option | |
47
+
48
+ Scenario: convert IPv4 header to Ruby code
49
+ When I eval the following Ruby code:
50
+ """ruby
51
+ IPv4Header.new(source_ip_address: '1.2.3.4',
52
+ destination_ip_address: '4.3.2.1').to_ruby
53
+ """
54
+ Then the result of eval should be:
55
+ """ruby
56
+ [
57
+ 0b0100_0101, # ip_version, ip_header_length
58
+ 0x00, # ip_type_of_service
59
+ 0x00, 0x14, # ip_total_length
60
+ 0x00, 0x00, # ip_identifier
61
+ 0b000_0000000000000, # ip_flag, ip_fragment
62
+ 0x80, # ip_ttl
63
+ 0x00, # ip_protocol
64
+ 0x30, 0xe1, # ip_header_checksum
65
+ 0x01, 0x02, 0x03, 0x04, # source_ip_address
66
+ 0x04, 0x03, 0x02, 0x01, # destination_ip_address
67
+ ].pack('C6nC12')
68
+ """
69
+
70
+ Scenario: IPv4Header instance inspection
71
+ When I eval the following Ruby code:
72
+ """ruby
73
+ IPv4Header.new(source_ip_address: '1.2.3.4',
74
+ destination_ip_address: '4.3.2.1').inspect
75
+ """
76
+ Then the result of eval should be:
77
+ """
78
+ #<Pio::IPv4Header ip_version: 4, ip_header_length: 5, ip_type_of_service: 0, ip_total_length: 20, ip_identifier: 0, ip_flag: 0, ip_fragment: 0, ip_ttl: 128, ip_protocol: 0, ip_header_checksum: 12513, source_ip_address: "1.2.3.4", destination_ip_address: "4.3.2.1", ip_option: "">
79
+ """
80
+
81
+ Scenario: IPv4Header class inspection
82
+ When I eval the following Ruby code:
83
+ """ruby
84
+ Pio::IPv4Header.inspect
85
+ """
86
+ Then the result of eval should be:
87
+ """
88
+ IPv4Header(ip_version: bit4, ip_header_length: bit4, ip_type_of_service: uint8, ip_total_length: uint16, ip_identifier: uint16, ip_flag: bit3, ip_fragment: bit13, ip_ttl: uint8, ip_protocol: uint8, ip_header_checksum: uint16, source_ip_address: ip_address, destination_ip_address: ip_address, ip_option: string)
89
+ """
@@ -1,11 +1,10 @@
1
- Feature: Pio::Lldp
1
+ Feature: Lldp
2
2
  Scenario: create
3
- When I try to create an OpenFlow message with:
3
+ When I create an OpenFlow message with:
4
4
  """
5
5
  Pio::Lldp.new(dpid: 0x123, port_number: 12, source_mac: '11:22:33:44:55:66')
6
6
  """
7
- Then it should finish successfully
8
- And the message has the following fields and values:
7
+ Then the message has the following fields and values:
9
8
  | field | value |
10
9
  | class | Pio::Lldp |
11
10
  | destination_mac | 01:80:c2:00:00:0e |
@@ -23,8 +22,7 @@ Feature: Pio::Lldp
23
22
  | organizationally_specific | |
24
23
 
25
24
  Scenario: parse lldp.minimal.pcap
26
- When I try to parse a file named "lldp.minimal.pcap" with "Pio::Lldp" class
27
- Then it should finish successfully
25
+ When I parse a file named "lldp.minimal.pcap" with "Pio::Lldp" class
28
26
  Then the message #1 have the following fields and values:
29
27
  | field | value |
30
28
  | class | Pio::Lldp |
@@ -43,5 +41,4 @@ Feature: Pio::Lldp
43
41
  | organizationally_specific | |
44
42
 
45
43
  Scenario: parse lldp.detailed.pcap
46
- When I try to parse a file named "lldp.detailed.pcap" with "Pio::Lldp" class
47
- Then it should finish successfully
44
+ Then I parse a file named "lldp.detailed.pcap" with "Pio::Lldp" class
@@ -0,0 +1,13 @@
1
+ Feature: OpenFlow::Header
2
+
3
+ Scenario: OpenFlow::Header#to_hex
4
+ When I create an OpenFlow message with:
5
+ """
6
+ Pio::OpenFlow::Header.new(version: :OpenFlow10,
7
+ type: 10,
8
+ message_length: 18,
9
+ transaction_id: 0xff)
10
+ """
11
+ Then the message has the following fields and values:
12
+ | field | value |
13
+ | to_bytes | 0x01, 0x0a, 0x00, 0x12, 0x00, 0x00, 0x00, 0xff |
@@ -1,29 +1,11 @@
1
- Feature: Pio::NiciraResubmit
1
+ @open_flow13
2
+ Feature: NiciraResubmit
2
3
 
3
4
  Scenario: new(1)
4
- When I try to create an OpenFlow action with:
5
+ When I create an OpenFlow action with:
5
6
  """
6
7
  Pio::NiciraResubmit.new(1)
7
8
  """
8
- Then it should finish successfully
9
- And the action has the following fields and values:
9
+ Then the action has the following fields and values:
10
10
  | field | value |
11
- | action_type.to_hex | 0xffff |
12
- | action_length | 16 |
13
- | vendor.to_hex | 0x2320 |
14
- | subtype | 1 |
15
11
  | in_port | 1 |
16
-
17
- Scenario: new(:in_port)
18
- When I try to create an OpenFlow action with:
19
- """
20
- Pio::NiciraResubmit.new(:in_port)
21
- """
22
- Then it should finish successfully
23
- And the action has the following fields and values:
24
- | field | value |
25
- | action_type.to_hex | 0xffff |
26
- | action_length | 16 |
27
- | vendor.to_hex | 0x2320 |
28
- | subtype | 1 |
29
- | in_port | :in_port |
@@ -1,31 +1,21 @@
1
- Feature: Pio::NiciraResubmitTable
1
+ Feature: NiciraResubmitTable
2
2
 
3
3
  Scenario: new(in_port: 1, table: 1)
4
- When I try to create an OpenFlow action with:
4
+ When I create an OpenFlow action with:
5
5
  """
6
6
  Pio::NiciraResubmitTable.new(in_port: 1, table: 1)
7
7
  """
8
- Then it should finish successfully
9
- And the action has the following fields and values:
8
+ Then the action has the following fields and values:
10
9
  | field | value |
11
- | action_type.to_hex | 0xffff |
12
- | action_length | 16 |
13
- | vendor.to_hex | 0x2320 |
14
- | subtype | 14 |
15
10
  | in_port | 1 |
16
11
  | table | 1 |
17
12
 
18
- Scenario: new(:in_port)
19
- When I try to create an OpenFlow action with:
13
+ Scenario: new(in_port: 1)
14
+ When I create an OpenFlow action with:
20
15
  """
21
16
  Pio::NiciraResubmitTable.new(in_port: 1)
22
17
  """
23
- Then it should finish successfully
24
- And the action has the following fields and values:
18
+ Then the action has the following fields and values:
25
19
  | field | value |
26
- | action_type.to_hex | 0xffff |
27
- | action_length | 16 |
28
- | vendor.to_hex | 0x2320 |
29
- | subtype | 14 |
30
20
  | in_port | 1 |
31
21
  | table.to_hex | 0xff |
@@ -1,13 +1,11 @@
1
1
  @open_flow10
2
- Feature: Pio::AggregateStats::Reply
2
+ Feature: AggregateStats::Reply
3
+
3
4
  Scenario: read
4
- When I try to parse a file named "open_flow10/aggregate_stats_reply.raw" with "AggregateStats::Reply" class
5
- Then it should finish successfully
6
- And the message has the following fields and values:
5
+ When I parse a file named "open_flow10/aggregate_stats_reply.raw" with "AggregateStats::Reply" class
6
+ Then the message has the following fields and values:
7
7
  | field | value |
8
- | ofp_version | 1 |
9
- | message_type | 17 |
10
- | message_length | 36 |
8
+ | version | 1 |
11
9
  | transaction_id | 15 |
12
10
  | xid | 15 |
13
11
  | stats_type | :aggregate |
@@ -1,16 +1,17 @@
1
1
  @open_flow10
2
- Feature: Pio::AggregateStats::Request
2
+ Feature: AggregateStats::Request
3
+
4
+ Aggregate information about multiple flows is requested with the
5
+ Aggregate Stats Request message
6
+
3
7
  Scenario: new
4
- When I try to create an OpenFlow message with:
8
+ When I create an OpenFlow message with:
5
9
  """
6
- Pio::AggregateStats::Request.new(match: Match.new(in_port: 1))
10
+ Pio::AggregateStats::Request.new(match: Pio::Match.new(in_port: 1))
7
11
  """
8
- Then it should finish successfully
9
- And the message has the following fields and values:
12
+ Then the message has the following fields and values:
10
13
  | field | value |
11
- | ofp_version | 1 |
12
- | message_type | 16 |
13
- | message_length | 56 |
14
+ | version | 1 |
14
15
  | transaction_id | 0 |
15
16
  | xid | 0 |
16
17
  | stats_type | :aggregate |
@@ -32,13 +33,10 @@ Feature: Pio::AggregateStats::Request
32
33
 
33
34
 
34
35
  Scenario: read
35
- When I try to parse a file named "open_flow10/aggregate_stats_request.raw" with "AggregateStats::Request" class
36
- Then it should finish successfully
37
- And the message has the following fields and values:
36
+ When I parse a file named "open_flow10/aggregate_stats_request.raw" with "Pio::AggregateStats::Request" class
37
+ Then the message has the following fields and values:
38
38
  | field | value |
39
- | ofp_version | 1 |
40
- | message_type | 16 |
41
- | message_length | 56 |
39
+ | version | 1 |
42
40
  | transaction_id | 14 |
43
41
  | xid | 14 |
44
42
  | stats_type | :aggregate |
@@ -1,33 +1,16 @@
1
1
  @open_flow10
2
- Feature: Pio::Error::BadRequest
2
+ Feature: Error::BadRequest
3
3
 
4
- Request was not understood error.
4
+ Request was not understood error
5
5
 
6
- Scenario: new (raw_data = Echo request 1.3)
7
- When I try to create an OpenFlow message with:
6
+ Scenario: new (error_code: :bad_version, raw_data: EchoRequest 1.3)
7
+ When I create an OpenFlow message with:
8
8
  """
9
- Pio::Error::BadRequest.new(raw_data: Pio::OpenFlow13::Echo::Request.new.to_binary)
9
+ Pio::Error::BadRequest.new(error_code: :bad_version,
10
+ raw_data: Pio::OpenFlow13::Echo::Request.new.to_binary)
10
11
  """
11
- Then it should finish successfully
12
- And the message has the following fields and values:
12
+ Then the message has the following fields and values:
13
13
  | field | value |
14
- | ofp_version | 1 |
15
- | message_type | 1 |
16
- | message_length | 20 |
17
- | transaction_id | 0 |
18
- | xid | 0 |
19
- | error_type | :bad_request |
20
- | error_code | :bad_version |
21
- | raw_data.length | 8 |
22
-
23
- Scenario: read
24
- When I try to parse a file named "open_flow10/bad_request.raw" with "Pio::Error::BadRequest" class
25
- Then it should finish successfully
26
- And the message has the following fields and values:
27
- | field | value |
28
- | ofp_version | 1 |
29
- | message_type | 1 |
30
- | message_length | 20 |
31
14
  | transaction_id | 0 |
32
15
  | xid | 0 |
33
16
  | error_type | :bad_request |
@@ -1,43 +1,32 @@
1
1
  @open_flow10
2
- Feature: Pio::Barrier::Reply
2
+ Feature: Barrier::Reply
3
+
4
+ When the switch received a Barrier Request message, the switch must
5
+ finish processing all previously-received messages before executing
6
+ any messages beyond the Barrier Request. When such processing is
7
+ complete, the switch must send an Barrier Reply message with the xid
8
+ of the original request.
9
+
3
10
  Scenario: new
4
- When I try to create an OpenFlow message with:
11
+ When I create an OpenFlow message with:
5
12
  """
6
13
  Pio::Barrier::Reply.new
7
14
  """
8
- Then it should finish successfully
9
- And the message has the following fields and values:
15
+ Then the message has the following fields and values:
10
16
  | field | value |
11
- | ofp_version | 1 |
12
- | message_type | 19 |
13
- | message_length | 8 |
17
+ | version | 1 |
14
18
  | transaction_id | 0 |
15
19
  | xid | 0 |
16
20
  | body | |
17
21
 
18
22
  Scenario: new(transaction_id: 123)
19
- When I try to create an OpenFlow message with:
23
+ When I create an OpenFlow message with:
20
24
  """
21
25
  Pio::Barrier::Reply.new(transaction_id: 123)
22
26
  """
23
- Then it should finish successfully
24
- And the message has the following fields and values:
27
+ Then the message has the following fields and values:
25
28
  | field | value |
26
- | ofp_version | 1 |
27
- | message_type | 19 |
28
- | message_length | 8 |
29
+ | version | 1 |
29
30
  | transaction_id | 123 |
30
31
  | xid | 123 |
31
32
  | body | |
32
-
33
- Scenario: read
34
- When I try to parse a file named "open_flow10/barrier_reply.raw" with "Barrier::Reply" class
35
- Then it should finish successfully
36
- And the message has the following fields and values:
37
- | field | value |
38
- | ofp_version | 1 |
39
- | message_type | 19 |
40
- | message_length | 8 |
41
- | transaction_id | 0 |
42
- | xid | 0 |
43
- | body | |
@@ -1,43 +1,30 @@
1
1
  @open_flow10
2
- Feature: Pio::Barrier::Request
2
+ Feature: Barrier::Request
3
+
4
+ When the controller wants to ensure message dependencies have been
5
+ met or wants to receive notifications for completed operations, it
6
+ may use an Barrier Request message. This message has no body.
7
+
3
8
  Scenario: new
4
- When I try to create an OpenFlow message with:
9
+ When I create an OpenFlow message with:
5
10
  """
6
11
  Pio::Barrier::Request.new
7
12
  """
8
- Then it should finish successfully
9
- And the message has the following fields and values:
13
+ Then the message has the following fields and values:
10
14
  | field | value |
11
- | ofp_version | 1 |
12
- | message_type | 18 |
13
- | message_length | 8 |
15
+ | version | 1 |
14
16
  | transaction_id | 0 |
15
17
  | xid | 0 |
16
18
  | body | |
17
19
 
18
20
  Scenario: new(transaction_id: 123)
19
- When I try to create an OpenFlow message with:
21
+ When I create an OpenFlow message with:
20
22
  """
21
23
  Pio::Barrier::Request.new(transaction_id: 123)
22
24
  """
23
- Then it should finish successfully
24
- And the message has the following fields and values:
25
+ Then the message has the following fields and values:
25
26
  | field | value |
26
- | ofp_version | 1 |
27
- | message_type | 18 |
28
- | message_length | 8 |
27
+ | version | 1 |
29
28
  | transaction_id | 123 |
30
29
  | xid | 123 |
31
30
  | body | |
32
-
33
- Scenario: read
34
- When I try to parse a file named "open_flow10/barrier_request.raw" with "Barrier::Request" class
35
- Then it should finish successfully
36
- And the message has the following fields and values:
37
- | field | value |
38
- | ofp_version | 1 |
39
- | message_type | 18 |
40
- | message_length | 8 |
41
- | transaction_id | 0 |
42
- | xid | 0 |
43
- | body | |
@@ -1,13 +1,15 @@
1
1
  @open_flow10
2
- Feature: Pio::DescriptionStats::Reply
2
+ Feature: DescriptionStats::Reply
3
+
4
+ Information about the switch manufacturer, hardware revision,
5
+ software revision, serial number, and a description field is
6
+ available from a Description Stats Reply.
7
+
3
8
  Scenario: read
4
- When I try to parse a file named "open_flow10/description_stats_reply.raw" with "DescriptionStats::Reply" class
5
- Then it should finish successfully
6
- And the message has the following fields and values:
9
+ When I parse a file named "open_flow10/description_stats_reply.raw" with "DescriptionStats::Reply" class
10
+ Then the message has the following fields and values:
7
11
  | field | value |
8
- | ofp_version | 1 |
9
- | message_type | 17 |
10
- | message_length | 1068 |
12
+ | version | 1 |
11
13
  | transaction_id | 12 |
12
14
  | xid | 12 |
13
15
  | stats_type | :description |