sequence! { procedure, context, // ACL Connection Established Upper Tester -> IUT: AuthenticationRequested { connection_handle: context.peer_handle() } IUT -> Upper Tester: AuthenticationRequestedStatus { num_hci_command_packets: 1, status: ErrorCode::Success, } IUT -> Upper Tester: LinkKeyRequest { bd_addr: context.peer_address(), } Upper Tester -> IUT: LinkKeyRequestNegativeReply { bd_addr: context.peer_address(), } IUT -> Upper Tester: LinkKeyRequestNegativeReplyComplete { num_hci_command_packets: 1, status: ErrorCode::Success, bd_addr: context.peer_address(), } IUT -> Upper Tester: IoCapabilityRequest { bd_addr: context.peer_address(), } Upper Tester -> IUT: IoCapabilityRequestReply { bd_addr: context.peer_address(), io_capability: IoCapability::DisplayYesNo, oob_present: OobDataPresent::NotPresent, authentication_requirements: AuthenticationRequirements::NoBondingMitmProtection, } IUT -> Upper Tester: IoCapabilityRequestReplyComplete { num_hci_command_packets: 1, status: ErrorCode::Success, bd_addr: context.peer_address(), } IUT -> Lower Tester: IoCapabilityReq { transaction_id: 0, io_capabilities: 0x01, oob_authentication_data: 0x00, authentication_requirement: 0x01, } Lower Tester -> IUT: IoCapabilityRes { transaction_id: 0, io_capabilities: 0x01, oob_authentication_data: 0x00, authentication_requirement: 0x01, } IUT -> Upper Tester: IoCapabilityResponse { bd_addr: context.peer_address(), io_capability: IoCapability::DisplayYesNo, oob_data_present: OobDataPresent::NotPresent, authentication_requirements: AuthenticationRequirements::NoBondingMitmProtection, } // Public Key Exchange IUT -> Lower Tester: EncapsulatedHeader { transaction_id: 0, major_type: 1, minor_type: 1, payload_length: 48, } Lower Tester -> IUT: Accepted { transaction_id: 0, accepted_opcode: Opcode::EncapsulatedHeader, } repeat 3 times with (part in local_p192_public_key(&context)) { IUT -> Lower Tester: EncapsulatedPayload { transaction_id: 0, data: part, } Lower Tester -> IUT: Accepted { transaction_id: 0, accepted_opcode: Opcode::EncapsulatedPayload, } } Lower Tester -> IUT: EncapsulatedHeader { transaction_id: 0, major_type: 1, minor_type: 1, payload_length: 48, } IUT -> Lower Tester: Accepted { transaction_id: 0, accepted_opcode: Opcode::EncapsulatedHeader, } repeat 3 times with (part in peer_p192_public_key()) { Lower Tester -> IUT: EncapsulatedPayload { transaction_id: 0, data: part, } IUT -> Lower Tester: Accepted { transaction_id: 0, accepted_opcode: Opcode::EncapsulatedPayload, } } // Authentication Stage 1: Numeric Comparison Protocol Lower Tester -> IUT: SimplePairingConfirm { transaction_id: 0, commitment_value: [0; 16], } IUT -> Lower Tester: SimplePairingNumber { transaction_id: 0, nonce: [0; 16], } Lower Tester -> IUT: Accepted { transaction_id: 0, accepted_opcode: Opcode::SimplePairingNumber, } Lower Tester -> IUT: SimplePairingNumber { transaction_id: 0, nonce: [0; 16], } IUT -> Upper Tester: UserConfirmationRequest { bd_addr: context.peer_address(), numeric_value: 0 } IUT -> Lower Tester: Accepted { transaction_id: 0, accepted_opcode: Opcode::SimplePairingNumber, } Upper Tester -> IUT: UserConfirmationRequestReply { bd_addr: context.peer_address() } IUT -> Upper Tester: UserConfirmationRequestReplyComplete { num_hci_command_packets: 1, status: ErrorCode::Success, bd_addr: context.peer_address(), } IUT -> Lower Tester: DhkeyCheck { transaction_id: 0, confirmation_value: [0; 16], } Lower Tester -> IUT: NotAccepted { transaction_id: 0, not_accepted_opcode: Opcode::DhkeyCheck, error_code: 0x05 } IUT -> Upper Tester: SimplePairingComplete { status: ErrorCode::AuthenticationFailure, bd_addr: context.peer_address(), } IUT -> Upper Tester: AuthenticationComplete { status: ErrorCode::AuthenticationFailure, connection_handle: context.peer_handle(), } }