pio 0.30.0 → 0.30.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +3 -0
- data/README.md +6 -53
- data/Rakefile +8 -6
- data/features/{arp.feature → arp/arp.feature} +14 -30
- data/features/arp/arp_reply.feature +69 -0
- data/features/arp/arp_request.feature +67 -0
- data/features/dhcp.feature +157 -162
- data/features/ethernet_header.feature +149 -0
- data/features/icmp/icmp.feature +47 -0
- data/features/icmp/icmp_reply.feature +93 -0
- data/features/icmp/icmp_request.feature +89 -0
- data/features/ipv4_header.feature +89 -0
- data/features/lldp.feature +5 -8
- data/features/open_flow/header.feature +13 -0
- data/features/open_flow/nicira_resubmit.feature +4 -22
- data/features/open_flow/nicira_resubmit_table.feature +6 -16
- data/features/open_flow10/aggregate_stats_reply.feature +5 -7
- data/features/open_flow10/aggregate_stats_request.feature +12 -14
- data/features/open_flow10/bad_request.feature +7 -24
- data/features/open_flow10/barrier_reply.feature +14 -25
- data/features/open_flow10/barrier_request.feature +12 -25
- data/features/open_flow10/description_stats_reply.feature +9 -7
- data/features/open_flow10/description_stats_request.feature +12 -25
- data/features/open_flow10/echo_reply.feature +14 -35
- data/features/open_flow10/echo_request.feature +16 -39
- data/features/open_flow10/enqueue.feature +3 -4
- data/features/open_flow10/exact_match.feature +5 -5
- data/features/open_flow10/features_reply.feature +28 -73
- data/features/open_flow10/features_request.feature +10 -28
- data/features/open_flow10/flow_mod.feature +4 -188
- data/features/open_flow10/flow_removed.feature +28 -30
- data/features/open_flow10/flow_stats_reply.feature +5 -89
- data/features/open_flow10/flow_stats_request.feature +12 -42
- data/features/open_flow10/hello.feature +10 -32
- data/features/open_flow10/hello_failed.feature +7 -57
- data/features/open_flow10/packet_in.feature +130 -49
- data/features/open_flow10/packet_out.feature +29 -18
- data/features/open_flow10/port_stats_request.feature +8 -29
- data/features/open_flow10/port_status.feature +22 -21
- data/features/open_flow10/queue_stats_request.feature +12 -30
- data/features/open_flow10/send_out_port.feature +17 -25
- data/features/open_flow10/set_destination_mac_address.feature +3 -4
- data/features/open_flow10/set_ip_destination_address.feature +3 -4
- data/features/open_flow10/set_source_ip_address.feature +3 -4
- data/features/open_flow10/set_source_mac_address.feature +3 -4
- data/features/open_flow10/set_tos.feature +3 -4
- data/features/open_flow10/set_transport_destination_port.feature +3 -4
- data/features/open_flow10/set_transport_source_port.feature +3 -4
- data/features/open_flow10/set_vlan_priority.feature +3 -4
- data/features/open_flow10/set_vlan_vid.feature +3 -4
- data/features/open_flow10/strip_vlan_header.feature +3 -4
- data/features/open_flow10/table_stats_request.feature +11 -13
- data/features/open_flow10/vendor_action.feature +4 -5
- data/features/open_flow13/apply_actions.feature +15 -18
- data/features/open_flow13/bad_request.feature +7 -13
- data/features/open_flow13/copy_ttl_inwards.feature +13 -0
- data/features/open_flow13/copy_ttl_outwards.feature +13 -0
- data/features/open_flow13/decrement_ip_ttl.feature +11 -0
- data/features/open_flow13/echo_reply.feature +16 -42
- data/features/open_flow13/echo_request.feature +16 -42
- data/features/open_flow13/features_reply.feature +4 -25
- data/features/open_flow13/features_request.feature +7 -36
- data/features/open_flow13/flow_mod.feature +16 -76
- data/features/open_flow13/goto_table.feature +18 -20
- data/features/open_flow13/hello.feature +7 -37
- data/features/open_flow13/hello_failed.feature +7 -30
- data/features/open_flow13/match.feature +239 -248
- data/features/open_flow13/meter.feature +18 -20
- data/features/open_flow13/nicira_conjunction.feature +15 -0
- data/features/open_flow13/nicira_reg_load.feature +27 -42
- data/features/open_flow13/nicira_reg_move.feature +41 -35
- data/features/open_flow13/nicira_send_out_port.feature +21 -13
- data/features/open_flow13/nicira_stack_pop.feature +26 -0
- data/features/open_flow13/nicira_stack_push.feature +26 -0
- data/features/open_flow13/packet_in.feature +7 -34
- data/features/open_flow13/packet_out.feature +7 -45
- data/features/open_flow13/send_out_port.feature +19 -28
- data/features/open_flow13/set_arp_operation.feature +4 -5
- data/features/open_flow13/set_arp_sender_hardware_address.feature +3 -4
- data/features/open_flow13/set_arp_sender_protocol_address.feature +3 -4
- data/features/open_flow13/set_destination_mac_address.feature +3 -4
- data/features/open_flow13/set_ip_ttl.feature +12 -0
- data/features/open_flow13/set_metadata.feature +3 -4
- data/features/open_flow13/set_source_mac_address.feature +3 -4
- data/features/open_flow13/stats_request.feature +4 -7
- data/features/open_flow13/write_metadata.feature +20 -22
- data/features/open_flow_read.feature +24 -5
- data/features/open_flow_version.feature +1 -1
- data/features/parser.feature +8 -9
- data/features/step_definitions/Gemfile +2 -0
- data/features/step_definitions/Guardfile +2 -0
- data/features/step_definitions/Rakefile +2 -0
- data/features/step_definitions/dump_flows_steps.rb +2 -0
- data/features/step_definitions/open_flow_steps.rb +13 -16
- data/features/step_definitions/packet_data_steps.rb +19 -33
- data/features/step_definitions/rest_api_steps.rb +2 -0
- data/features/step_definitions/ruby_steps.rb +9 -0
- data/features/step_definitions/show_stats_steps.rb +5 -3
- data/features/step_definitions/trema_steps.rb +2 -0
- data/features/step_definitions/virtual_link_steps.rb +2 -0
- data/features/support/env.rb +2 -2
- data/features/support/hooks.rb +4 -2
- data/features/udp.feature +26 -27
- data/lib/pio/arp/format.rb +5 -7
- data/lib/pio/arp/message.rb +10 -4
- data/lib/pio/arp/reply.rb +11 -32
- data/lib/pio/arp/request.rb +11 -33
- data/lib/pio/arp.rb +11 -6
- data/lib/pio/class_inspector.rb +20 -0
- data/lib/pio/dhcp/ack.rb +2 -0
- data/lib/pio/dhcp/boot_reply.rb +2 -0
- data/lib/pio/dhcp/boot_reply_options.rb +2 -0
- data/lib/pio/dhcp/boot_request.rb +2 -0
- data/lib/pio/dhcp/boot_request_options.rb +2 -0
- data/lib/pio/dhcp/client_id.rb +2 -0
- data/lib/pio/dhcp/common_options.rb +2 -0
- data/lib/pio/dhcp/dhcp_field.rb +2 -0
- data/lib/pio/dhcp/dhcp_tlv_options.rb +30 -20
- data/lib/pio/dhcp/discover.rb +2 -0
- data/lib/pio/dhcp/field_util.rb +3 -1
- data/lib/pio/dhcp/frame.rb +6 -4
- data/lib/pio/dhcp/message.rb +2 -0
- data/lib/pio/dhcp/offer.rb +2 -0
- data/lib/pio/dhcp/optional_tlv.rb +4 -2
- data/lib/pio/dhcp/parameter_list.rb +2 -0
- data/lib/pio/dhcp/request.rb +2 -0
- data/lib/pio/dhcp.rb +4 -2
- data/lib/pio/ethernet_frame.rb +22 -0
- data/lib/pio/ethernet_header.rb +37 -13
- data/lib/pio/icmp/format.rb +21 -22
- data/lib/pio/icmp/message.rb +20 -4
- data/lib/pio/icmp/reply.rb +10 -34
- data/lib/pio/icmp/request.rb +10 -43
- data/lib/pio/icmp.rb +10 -5
- data/lib/pio/instance_inspector.rb +16 -0
- data/lib/pio/ipv4_address.rb +13 -11
- data/lib/pio/ipv4_header.rb +26 -2
- data/lib/pio/lldp/chassis_id_tlv.rb +2 -0
- data/lib/pio/lldp/end_of_lldpdu_value.rb +2 -0
- data/lib/pio/lldp/frame.rb +4 -2
- data/lib/pio/lldp/management_address_value.rb +2 -0
- data/lib/pio/lldp/optional_tlv.rb +4 -2
- data/lib/pio/lldp/options.rb +4 -2
- data/lib/pio/lldp/organizationally_specific_value.rb +2 -0
- data/lib/pio/lldp/port_description_value.rb +2 -0
- data/lib/pio/lldp/port_id_tlv.rb +2 -0
- data/lib/pio/lldp/system_capabilities_value.rb +2 -0
- data/lib/pio/lldp/system_description_value.rb +2 -0
- data/lib/pio/lldp/system_name_value.rb +2 -0
- data/lib/pio/lldp/ttl_tlv.rb +2 -0
- data/lib/pio/lldp.rb +2 -0
- data/lib/pio/mac.rb +9 -3
- data/lib/pio/message.rb +52 -0
- data/lib/pio/message_type_selector.rb +2 -0
- data/lib/pio/monkey_patch/bindata_record.rb +8 -0
- data/lib/pio/monkey_patch/bindata_string.rb +12 -0
- data/lib/pio/monkey_patch/integer/base_conversions.rb +3 -1
- data/lib/pio/monkey_patch/integer/ranges.rb +2 -0
- data/lib/pio/monkey_patch/integer.rb +2 -0
- data/lib/pio/monkey_patch/uint/base_conversions.rb +16 -0
- data/lib/pio/monkey_patch/uint.rb +11 -0
- data/lib/pio/open_flow/action.rb +10 -4
- data/lib/pio/open_flow/buffer_id.rb +21 -0
- data/lib/pio/open_flow/datapath_id.rb +5 -3
- data/lib/pio/open_flow/error_message.rb +34 -0
- data/lib/pio/open_flow/flags.rb +17 -6
- data/lib/pio/open_flow/flow_match.rb +12 -0
- data/lib/pio/open_flow/header.rb +28 -0
- data/lib/pio/open_flow/hello_failed_code.rb +3 -1
- data/lib/pio/open_flow/instruction.rb +12 -0
- data/lib/pio/open_flow/message.rb +51 -14
- data/lib/pio/open_flow/nicira_action.rb +2 -0
- data/lib/pio/open_flow/nicira_resubmit.rb +15 -11
- data/lib/pio/open_flow/nicira_resubmit_table.rb +19 -10
- data/lib/pio/open_flow/parser.rb +21 -0
- data/lib/pio/open_flow/port.rb +4 -2
- data/lib/pio/open_flow/transaction_id.rb +4 -2
- data/lib/pio/open_flow/version.rb +24 -0
- data/lib/pio/open_flow.rb +40 -52
- data/lib/pio/open_flow10/actions.rb +18 -16
- data/lib/pio/open_flow10/aggregate_stats/reply.rb +4 -1
- data/lib/pio/open_flow10/aggregate_stats/request.rb +3 -3
- data/lib/pio/open_flow10/barrier/reply.rb +3 -1
- data/lib/pio/open_flow10/barrier/request.rb +3 -1
- data/lib/pio/open_flow10/description_stats/reply.rb +3 -1
- data/lib/pio/open_flow10/description_stats/request.rb +3 -3
- data/lib/pio/open_flow10/echo/reply.rb +5 -3
- data/lib/pio/open_flow10/echo/request.rb +5 -3
- data/lib/pio/open_flow10/enqueue.rb +5 -3
- data/lib/pio/open_flow10/error/bad_request/bad_request_code.rb +37 -0
- data/lib/pio/open_flow10/error/bad_request.rb +7 -29
- data/lib/pio/open_flow10/error/error_type10.rb +3 -1
- data/lib/pio/open_flow10/error/hello_failed.rb +8 -4
- data/lib/pio/open_flow10/error.rb +5 -13
- data/lib/pio/open_flow10/exact_match.rb +14 -10
- data/lib/pio/open_flow10/features/reply.rb +35 -48
- data/lib/pio/open_flow10/features/request.rb +3 -4
- data/lib/pio/open_flow10/features.rb +2 -0
- data/lib/pio/open_flow10/flow_mod/command.rb +30 -0
- data/lib/pio/open_flow10/flow_mod.rb +10 -33
- data/lib/pio/open_flow10/flow_removed/reason.rb +24 -0
- data/lib/pio/open_flow10/flow_removed.rb +4 -17
- data/lib/pio/open_flow10/flow_stats/reply.rb +5 -4
- data/lib/pio/open_flow10/flow_stats/request.rb +3 -3
- data/lib/pio/open_flow10/hello.rb +3 -4
- data/lib/pio/open_flow10/match.rb +16 -13
- data/lib/pio/open_flow10/match10.rb +2 -0
- data/lib/pio/open_flow10/packet_in/reason.rb +27 -0
- data/lib/pio/open_flow10/packet_in.rb +34 -28
- data/lib/pio/open_flow10/packet_out.rb +7 -6
- data/lib/pio/open_flow10/phy_port16.rb +41 -61
- data/lib/pio/open_flow10/port16.rb +2 -0
- data/lib/pio/open_flow10/port_stats/request.rb +3 -3
- data/lib/pio/open_flow10/port_status/reason.rb +23 -0
- data/lib/pio/open_flow10/port_status.rb +25 -30
- data/lib/pio/open_flow10/queue_stats/request.rb +3 -3
- data/lib/pio/open_flow10/send_out_port.rb +4 -2
- data/lib/pio/open_flow10/set_destination_ip_address.rb +2 -0
- data/lib/pio/open_flow10/set_destination_mac_address.rb +2 -0
- data/lib/pio/open_flow10/set_source_ip_address.rb +2 -0
- data/lib/pio/open_flow10/set_source_mac_address.rb +2 -0
- data/lib/pio/open_flow10/set_tos.rb +4 -2
- data/lib/pio/open_flow10/set_transport_port.rb +6 -2
- data/lib/pio/open_flow10/set_vlan_priority.rb +3 -1
- data/lib/pio/open_flow10/set_vlan_vid.rb +3 -1
- data/lib/pio/open_flow10/stats_reply.rb +9 -10
- data/lib/pio/open_flow10/stats_request.rb +18 -15
- data/lib/pio/open_flow10/stats_type.rb +3 -1
- data/lib/pio/open_flow10/strip_vlan_header.rb +2 -0
- data/lib/pio/open_flow10/table_stats/request.rb +3 -3
- data/lib/pio/open_flow10/vendor_action.rb +24 -20
- data/lib/pio/open_flow10.rb +2 -0
- data/lib/pio/open_flow13/actions.rb +36 -32
- data/lib/pio/open_flow13/apply.rb +27 -22
- data/lib/pio/open_flow13/copy_ttl_inwards.rb +17 -0
- data/lib/pio/open_flow13/copy_ttl_outwards.rb +17 -0
- data/lib/pio/open_flow13/decrement_ip_ttl.rb +17 -0
- data/lib/pio/open_flow13/echo/reply.rb +5 -3
- data/lib/pio/open_flow13/echo/request.rb +5 -3
- data/lib/pio/open_flow13/error/bad_request.rb +6 -3
- data/lib/pio/open_flow13/error/error_type13.rb +3 -1
- data/lib/pio/open_flow13/error/hello_failed.rb +5 -2
- data/lib/pio/open_flow13/error.rb +9 -18
- data/lib/pio/open_flow13/features/reply.rb +15 -20
- data/lib/pio/open_flow13/features/request.rb +3 -1
- data/lib/pio/open_flow13/flow_mod.rb +16 -19
- data/lib/pio/open_flow13/goto_table.rb +28 -24
- data/lib/pio/open_flow13/hello.rb +5 -4
- data/lib/pio/open_flow13/match.rb +187 -21
- data/lib/pio/open_flow13/meter.rb +25 -20
- data/lib/pio/open_flow13/nicira_conjunction.rb +28 -0
- data/lib/pio/open_flow13/nicira_reg_load.rb +46 -24
- data/lib/pio/open_flow13/nicira_reg_move.rb +79 -35
- data/lib/pio/open_flow13/nicira_send_out_port.rb +39 -21
- data/lib/pio/open_flow13/nicira_stack_pop.rb +51 -0
- data/lib/pio/open_flow13/nicira_stack_push.rb +51 -0
- data/lib/pio/open_flow13/packet_in.rb +13 -8
- data/lib/pio/open_flow13/packet_out.rb +11 -8
- data/lib/pio/open_flow13/port32.rb +2 -0
- data/lib/pio/open_flow13/send_out_port.rb +2 -0
- data/lib/pio/open_flow13/set_arp_operation.rb +2 -0
- data/lib/pio/open_flow13/set_arp_sender_hardware_address.rb +2 -0
- data/lib/pio/open_flow13/set_arp_sender_protocol_address.rb +2 -0
- data/lib/pio/open_flow13/set_destination_mac_address.rb +2 -0
- data/lib/pio/open_flow13/set_ip_ttl.rb +18 -0
- data/lib/pio/open_flow13/set_metadata.rb +2 -0
- data/lib/pio/open_flow13/set_source_mac_address.rb +2 -0
- data/lib/pio/open_flow13/stats_request.rb +10 -10
- data/lib/pio/open_flow13/write_metadata.rb +42 -38
- data/lib/pio/open_flow13.rb +9 -0
- data/lib/pio/options.rb +10 -3
- data/lib/pio/parse_error.rb +2 -0
- data/lib/pio/parser.rb +9 -16
- data/lib/pio/payload.rb +2 -0
- data/lib/pio/pcap.rb +2 -0
- data/lib/pio/ruby_dumper.rb +71 -0
- data/lib/pio/type/ether_type.rb +33 -0
- data/lib/pio/type/ip_address.rb +10 -0
- data/lib/pio/type/ipv6_address.rb +2 -0
- data/lib/pio/type/mac_address.rb +12 -0
- data/lib/pio/udp.rb +5 -3
- data/lib/pio/udp_header.rb +3 -1
- data/lib/pio/version.rb +3 -1
- data/lib/pio.rb +3 -1
- data/pio.gemspec +7 -38
- data/spec/pio/arp/reply_spec.rb +2 -4
- data/spec/pio/arp/request_spec.rb +2 -4
- data/spec/pio/arp_spec.rb +2 -4
- data/spec/pio/dhcp/ack_spec.rb +2 -0
- data/spec/pio/dhcp/discover_spec.rb +2 -0
- data/spec/pio/dhcp/offer_spec.rb +2 -0
- data/spec/pio/dhcp/request_spec.rb +2 -0
- data/spec/pio/dhcp_spec.rb +2 -0
- data/spec/pio/icmp/reply_spec.rb +6 -8
- data/spec/pio/icmp/request_spec.rb +8 -10
- data/spec/pio/icmp_spec.rb +10 -12
- data/spec/pio/ipv4_address_spec.rb +2 -0
- data/spec/pio/lldp/options_spec.rb +2 -0
- data/spec/pio/mac_spec.rb +2 -0
- data/spec/pio/monkey_patch/integer_spec.rb +25 -0
- data/spec/pio/open_flow/nicira_resubmit_spec.rb +21 -0
- data/spec/pio/open_flow/nicira_resubmit_table_spec.rb +22 -0
- data/spec/pio/open_flow10/echo/reply_spec.rb +2 -0
- data/spec/pio/open_flow10/echo/request_spec.rb +2 -0
- data/spec/pio/open_flow10/enqueue_spec.rb +2 -0
- data/spec/pio/open_flow10/error/hello_failed_spec.rb +4 -2
- data/spec/pio/open_flow10/features/reply_spec.rb +2 -0
- data/spec/pio/open_flow10/features/request_spec.rb +2 -0
- data/spec/pio/open_flow10/flow_mod_spec.rb +53 -51
- data/spec/pio/open_flow10/flow_stats_reply_spec.rb +2 -0
- data/spec/pio/open_flow10/flow_stats_request_spec.rb +10 -8
- data/spec/pio/open_flow10/hello_spec.rb +2 -2
- data/spec/pio/open_flow10/match_spec.rb +106 -104
- data/spec/pio/open_flow10/packet_in_spec.rb +2 -0
- data/spec/pio/open_flow10/packet_out_spec.rb +2 -349
- data/spec/pio/open_flow10/phy_port16_spec.rb +9 -7
- data/spec/pio/open_flow10/send_out_port_spec.rb +2 -0
- data/spec/pio/open_flow10/set_destination_ip_address_spec.rb +2 -0
- data/spec/pio/open_flow10/set_destination_mac_address_spec.rb +2 -0
- data/spec/pio/open_flow10/set_source_ip_address_spec.rb +2 -0
- data/spec/pio/open_flow10/set_source_mac_address_spec.rb +2 -0
- data/spec/pio/open_flow10/set_tos_spec.rb +2 -0
- data/spec/pio/open_flow10/set_transport_destination_port_spec.rb +2 -0
- data/spec/pio/open_flow10/set_transport_source_port_spec.rb +2 -0
- data/spec/pio/open_flow10/set_vlan_priority_spec.rb +2 -0
- data/spec/pio/open_flow10/set_vlan_vid_spec.rb +2 -0
- data/spec/pio/open_flow10/strip_vlan_header_spec.rb +2 -0
- data/spec/pio/open_flow10/wildcards_spec.rb +2 -0
- data/spec/pio/open_flow13/echo_reply_spec.rb +2 -0
- data/spec/pio/open_flow13/echo_request_spec.rb +2 -0
- data/spec/pio/open_flow13/error/bad_request_spec.rb +2 -0
- data/spec/pio/open_flow13/error/hello_failed_spec.rb +4 -2
- data/spec/pio/open_flow13/features/reply_spec.rb +2 -0
- data/spec/pio/open_flow13/features/request_spec.rb +2 -0
- data/spec/pio/open_flow13/goto_table_spec.rb +4 -2
- data/spec/pio/open_flow13/hello_spec.rb +18 -16
- data/spec/pio/open_flow13/match_spec.rb +31 -29
- data/spec/pio/open_flow13/meter_spec.rb +4 -2
- data/spec/pio/open_flow13/nicira_reg_load_spec.rb +73 -0
- data/spec/pio/open_flow13/nicira_reg_move_spec.rb +42 -0
- data/spec/pio/open_flow13/nicira_send_out_port_spec.rb +31 -0
- data/spec/pio/open_flow13/packet_in_spec.rb +2 -0
- data/spec/pio/open_flow13/packet_out_spec.rb +2 -0
- data/spec/pio/open_flow13/write_metadata_spec.rb +5 -3
- data/spec/pio/open_flow_spec.rb +8 -6
- data/spec/spec_helper.rb +1 -12
- data/spec/support/shared_examples_for_openflow_messages.rb +7 -13
- metadata +83 -683
- data/LICENSE +0 -674
- data/bin/_guard-core +0 -16
- data/bin/byebug +0 -16
- data/bin/cc-tddium-post-worker +0 -16
- data/bin/cdiff +0 -16
- data/bin/coderay +0 -16
- data/bin/colortab +0 -16
- data/bin/coveralls +0 -16
- data/bin/cucumber +0 -16
- data/bin/decolor +0 -16
- data/bin/flay +0 -16
- data/bin/flog +0 -16
- data/bin/guard +0 -16
- data/bin/htmldiff +0 -16
- data/bin/inch +0 -16
- data/bin/ldiff +0 -16
- data/bin/listen +0 -16
- data/bin/minitar +0 -16
- data/bin/pry +0 -16
- data/bin/rake +0 -16
- data/bin/reek +0 -16
- data/bin/relish +0 -16
- data/bin/restclient +0 -16
- data/bin/rspec +0 -16
- data/bin/rubocop +0 -16
- data/bin/ruby-parse +0 -16
- data/bin/ruby-rewrite +0 -16
- data/bin/ruby_parse +0 -16
- data/bin/ruby_parse_extract_error +0 -16
- data/bin/sparkr +0 -16
- data/bin/term_display +0 -16
- data/bin/term_mandel +0 -16
- data/bin/terminal-notifier +0 -16
- data/bin/thor +0 -16
- data/bin/unparser +0 -16
- data/bin/yard +0 -16
- data/bin/yardoc +0 -16
- data/bin/yri +0 -16
- data/features/arp-storm.pcap +0 -0
- data/features/arp.pcap +0 -0
- data/features/dhcp.pcap +0 -0
- data/features/icmp.feature +0 -130
- data/features/icmp.pcap +0 -0
- data/features/icmpv6.pcap +0 -0
- data/features/lldp.detailed.pcap +0 -0
- data/features/lldp.minimal.pcap +0 -0
- data/features/open_flow10/aggregate_stats_reply.raw +0 -0
- data/features/open_flow10/aggregate_stats_request.raw +0 -0
- data/features/open_flow10/bad_request.raw +0 -0
- data/features/open_flow10/barrier_reply.raw +0 -0
- data/features/open_flow10/barrier_request.raw +0 -0
- data/features/open_flow10/description_stats_reply.raw +0 -0
- data/features/open_flow10/description_stats_request.raw +0 -0
- data/features/open_flow10/echo_reply.raw +0 -0
- data/features/open_flow10/echo_request.raw +0 -0
- data/features/open_flow10/error.raw +0 -0
- data/features/open_flow10/features_reply.raw +0 -0
- data/features/open_flow10/features_request.raw +0 -0
- data/features/open_flow10/flow_mod_add.raw +0 -0
- data/features/open_flow10/flow_mod_delete.raw +0 -0
- data/features/open_flow10/flow_mod_delete_strict.raw +0 -0
- data/features/open_flow10/flow_mod_modify.raw +0 -0
- data/features/open_flow10/flow_mod_modify_strict.raw +0 -0
- data/features/open_flow10/flow_removed.raw +0 -0
- data/features/open_flow10/flow_stats_reply.raw +0 -0
- data/features/open_flow10/flow_stats_request.raw +0 -0
- data/features/open_flow10/get_config_reply.raw +0 -0
- data/features/open_flow10/get_config_request.raw +0 -0
- data/features/open_flow10/hello.raw +0 -0
- data/features/open_flow10/hello_failed.raw +0 -0
- data/features/open_flow10/nx_flow_mod_add.raw +0 -0
- data/features/open_flow10/nx_flow_mod_delete.raw +0 -0
- data/features/open_flow10/nx_flow_mod_delete_strict.raw +0 -0
- data/features/open_flow10/nx_flow_mod_modify.raw +0 -0
- data/features/open_flow10/nx_flow_mod_modify_strict.raw +0 -0
- data/features/open_flow10/nxast_learn.raw +0 -0
- data/features/open_flow10/packet_in.raw +0 -0
- data/features/open_flow10/packet_in_arp_reply.raw +0 -0
- data/features/open_flow10/packet_in_arp_request.raw +0 -0
- data/features/open_flow10/packet_in_cbench.raw +0 -0
- data/features/open_flow10/packet_out.raw +0 -0
- data/features/open_flow10/port_mod.raw +0 -0
- data/features/open_flow10/port_stats_reply.raw +0 -0
- data/features/open_flow10/port_stats_request.raw +0 -0
- data/features/open_flow10/port_status.raw +0 -0
- data/features/open_flow10/queue_get_config_reply.raw +0 -0
- data/features/open_flow10/queue_get_config_request.raw +0 -0
- data/features/open_flow10/queue_stats_request.raw +0 -0
- data/features/open_flow10/set_config.raw +0 -0
- data/features/open_flow10/table_stats_reply.raw +0 -0
- data/features/open_flow10/table_stats_request.raw +0 -0
- data/features/open_flow10/vendor.raw +0 -0
- data/features/open_flow10/vendor_stats_request.raw +0 -0
- data/features/open_flow13/action_copy_ttl_in.raw +0 -0
- data/features/open_flow13/action_copy_ttl_out.raw +0 -0
- data/features/open_flow13/action_dec_mpls_ttl.raw +0 -0
- data/features/open_flow13/action_dec_nw_ttl.raw +0 -0
- data/features/open_flow13/action_group.raw +0 -0
- data/features/open_flow13/action_pop_mpls.raw +0 -0
- data/features/open_flow13/action_pop_pbb.raw +0 -0
- data/features/open_flow13/action_pop_vlan.raw +0 -0
- data/features/open_flow13/action_push_mpls.raw +0 -0
- data/features/open_flow13/action_push_pbb.raw +0 -0
- data/features/open_flow13/action_push_vlan.raw +0 -0
- data/features/open_flow13/action_set_field.raw +0 -0
- data/features/open_flow13/action_set_mpls_ttl.raw +0 -0
- data/features/open_flow13/action_set_nw_ttl.raw +0 -0
- data/features/open_flow13/action_set_queue.raw +0 -0
- data/features/open_flow13/apply_actions.raw +0 -0
- data/features/open_flow13/bad_request.raw +0 -0
- data/features/open_flow13/echo_reply_body.raw +0 -0
- data/features/open_flow13/echo_reply_no_body.raw +0 -0
- data/features/open_flow13/echo_request_body.raw +0 -0
- data/features/open_flow13/echo_request_no_body.raw +0 -0
- data/features/open_flow13/features_reply.raw +0 -0
- data/features/open_flow13/features_request.raw +0 -0
- data/features/open_flow13/flow_add_apply_no_match.raw +0 -0
- data/features/open_flow13/flow_mod_add_apply_no_match.raw +0 -0
- data/features/open_flow13/flow_mod_no_match_or_instructions.raw +0 -0
- data/features/open_flow13/hello_failed.raw +0 -0
- data/features/open_flow13/hello_no_version_bitmap.raw +0 -0
- data/features/open_flow13/hello_version_bitmap.raw +0 -0
- data/features/open_flow13/instruction_clear_actions.raw +0 -0
- data/features/open_flow13/instruction_goto_table.raw +0 -0
- data/features/open_flow13/instruction_meter.raw +0 -0
- data/features/open_flow13/instruction_write_actions.raw +0 -0
- data/features/open_flow13/instruction_write_metadata.raw +0 -0
- data/features/open_flow13/oxm_arp_op_field.raw +0 -0
- data/features/open_flow13/oxm_arp_sha_field.raw +0 -0
- data/features/open_flow13/oxm_arp_spa_field.raw +0 -0
- data/features/open_flow13/oxm_arp_tha_field.raw +0 -0
- data/features/open_flow13/oxm_arp_tpa_field.raw +0 -0
- data/features/open_flow13/oxm_ether_destination_field.raw +0 -0
- data/features/open_flow13/oxm_ether_source_field.raw +0 -0
- data/features/open_flow13/oxm_ether_type_field.raw +0 -0
- data/features/open_flow13/oxm_experimenter_stratos_basic_dot11.raw +0 -0
- data/features/open_flow13/oxm_icmpv4_code_field.raw +0 -0
- data/features/open_flow13/oxm_icmpv4_type_field.raw +0 -0
- data/features/open_flow13/oxm_in_phy_port_field.raw +0 -0
- data/features/open_flow13/oxm_in_port_field.raw +0 -0
- data/features/open_flow13/oxm_invalid_field.raw +0 -0
- data/features/open_flow13/oxm_ip_dscp_field.raw +0 -0
- data/features/open_flow13/oxm_ip_ecn_field.raw +0 -0
- data/features/open_flow13/oxm_ipv4_destination_field.raw +0 -0
- data/features/open_flow13/oxm_ipv4_source_field.raw +0 -0
- data/features/open_flow13/oxm_ipv6_destination_field.raw +0 -0
- data/features/open_flow13/oxm_ipv6_source_field.raw +0 -0
- data/features/open_flow13/oxm_masked_arp_sha_field.raw +0 -0
- data/features/open_flow13/oxm_masked_arp_spa_field.raw +0 -0
- data/features/open_flow13/oxm_masked_arp_tha_field.raw +0 -0
- data/features/open_flow13/oxm_masked_arp_tpa_field.raw +0 -0
- data/features/open_flow13/oxm_masked_ether_destination_field.raw +0 -0
- data/features/open_flow13/oxm_masked_ether_source_field.raw +0 -0
- data/features/open_flow13/oxm_masked_ipv4_destination_field.raw +0 -0
- data/features/open_flow13/oxm_masked_ipv4_source_field.raw +0 -0
- data/features/open_flow13/oxm_masked_ipv6_destination_field.raw +0 -0
- data/features/open_flow13/oxm_masked_ipv6_source_field.raw +0 -0
- data/features/open_flow13/oxm_masked_tunnel_id_field.raw +0 -0
- data/features/open_flow13/oxm_metadata_field.raw +0 -0
- data/features/open_flow13/oxm_metadata_masked_field.raw +0 -0
- data/features/open_flow13/oxm_no_fields.raw +0 -0
- data/features/open_flow13/oxm_sctp_destination_field.raw +0 -0
- data/features/open_flow13/oxm_sctp_source_field.raw +0 -0
- data/features/open_flow13/oxm_tcp_destination_field.raw +0 -0
- data/features/open_flow13/oxm_tcp_field.raw +0 -0
- data/features/open_flow13/oxm_tcp_source_field.raw +0 -0
- data/features/open_flow13/oxm_tunnel_id_field.raw +0 -0
- data/features/open_flow13/oxm_udp_destination_field.raw +0 -0
- data/features/open_flow13/oxm_udp_field.raw +0 -0
- data/features/open_flow13/oxm_udp_source_field.raw +0 -0
- data/features/open_flow13/oxm_vlan_pcp_field.raw +0 -0
- data/features/open_flow13/oxm_vlan_vid_field.raw +0 -0
- data/features/open_flow13/packet_in.raw +0 -0
- data/features/open_flow13/packet_out.raw +0 -0
- data/features/open_flow13/send_out_port.raw +0 -0
- data/features/open_flow13/table_stats_reply.raw +0 -0
- data/features/open_flow13/table_stats_request.raw +0 -0
- data/features/step_definitions/LICENSE +0 -675
- data/features/udp_no_payload.raw +0 -0
- data/features/udp_with_payload.raw +0 -0
- data/lib/pio/icmp/options.rb +0 -21
- data/lib/pio/open_flow/error.rb +0 -19
- data/lib/pio/open_flow/open_flow_header.rb +0 -31
- data/lib/pio/open_flow13/buffer_id.rb +0 -17
- data/spec/pio/arp/reply/options_spec.rb +0 -143
- 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
|
+
"""
|
data/features/lldp.feature
CHANGED
@@ -1,11 +1,10 @@
|
|
1
|
-
Feature:
|
1
|
+
Feature: Lldp
|
2
2
|
Scenario: create
|
3
|
-
When I
|
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
|
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
|
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
|
-
|
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
|
-
|
1
|
+
@open_flow13
|
2
|
+
Feature: NiciraResubmit
|
2
3
|
|
3
4
|
Scenario: new(1)
|
4
|
-
When I
|
5
|
+
When I create an OpenFlow action with:
|
5
6
|
"""
|
6
7
|
Pio::NiciraResubmit.new(1)
|
7
8
|
"""
|
8
|
-
Then
|
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:
|
1
|
+
Feature: NiciraResubmitTable
|
2
2
|
|
3
3
|
Scenario: new(in_port: 1, table: 1)
|
4
|
-
When I
|
4
|
+
When I create an OpenFlow action with:
|
5
5
|
"""
|
6
6
|
Pio::NiciraResubmitTable.new(in_port: 1, table: 1)
|
7
7
|
"""
|
8
|
-
Then
|
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(:
|
19
|
-
When I
|
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
|
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:
|
2
|
+
Feature: AggregateStats::Reply
|
3
|
+
|
3
4
|
Scenario: read
|
4
|
-
When I
|
5
|
-
Then
|
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
|
-
|
|
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:
|
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
|
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
|
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
|
-
|
|
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
|
36
|
-
Then
|
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
|
-
|
|
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:
|
2
|
+
Feature: Error::BadRequest
|
3
3
|
|
4
|
-
Request was not understood error
|
4
|
+
Request was not understood error
|
5
5
|
|
6
|
-
Scenario: new (
|
7
|
-
When I
|
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(
|
9
|
+
Pio::Error::BadRequest.new(error_code: :bad_version,
|
10
|
+
raw_data: Pio::OpenFlow13::Echo::Request.new.to_binary)
|
10
11
|
"""
|
11
|
-
Then
|
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:
|
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
|
11
|
+
When I create an OpenFlow message with:
|
5
12
|
"""
|
6
13
|
Pio::Barrier::Reply.new
|
7
14
|
"""
|
8
|
-
Then
|
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
|
-
|
|
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
|
23
|
+
When I create an OpenFlow message with:
|
20
24
|
"""
|
21
25
|
Pio::Barrier::Reply.new(transaction_id: 123)
|
22
26
|
"""
|
23
|
-
Then
|
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
|
-
|
|
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:
|
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
|
9
|
+
When I create an OpenFlow message with:
|
5
10
|
"""
|
6
11
|
Pio::Barrier::Request.new
|
7
12
|
"""
|
8
|
-
Then
|
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
|
-
|
|
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
|
21
|
+
When I create an OpenFlow message with:
|
20
22
|
"""
|
21
23
|
Pio::Barrier::Request.new(transaction_id: 123)
|
22
24
|
"""
|
23
|
-
Then
|
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
|
-
|
|
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:
|
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
|
5
|
-
Then
|
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
|
-
|
|
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 |
|