diff options
author | Hansong Zhang <hsz@google.com> | 2019-11-11 11:07:03 -0800 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2019-11-11 11:07:03 -0800 |
commit | 0d8445de7ddaccc28ebf1f7211d5388053662447 (patch) | |
tree | 4d4fb7f6e43b30c9a5df9d037b66c52ec2c2b2e8 | |
parent | 7613f2d5b316adae709c2fd7f6baef8f70f42434 (diff) | |
parent | 1c28f9d4b76955e5f55bb02599091b75bdd45db2 (diff) | |
download | bt-0d8445de7ddaccc28ebf1f7211d5388053662447.tar.gz |
Merge "L2CAP: Reverse order in disconnection response" am: ebe8fa195c
am: 1c28f9d4b7
Change-Id: I722d48c1d64e67e368c4458ce6066296ce8d0ddf
-rw-r--r-- | gd/l2cap/classic/cert/simple_l2cap_test.py | 28 | ||||
-rw-r--r-- | gd/l2cap/classic/internal/signalling_manager.cc | 2 |
2 files changed, 29 insertions, 1 deletions
diff --git a/gd/l2cap/classic/cert/simple_l2cap_test.py b/gd/l2cap/classic/cert/simple_l2cap_test.py index 5a033f16f..d8a52cd7c 100644 --- a/gd/l2cap/classic/cert/simple_l2cap_test.py +++ b/gd/l2cap/classic/cert/simple_l2cap_test.py @@ -133,6 +133,33 @@ class SimpleL2capTest(GdBaseTestClass): open_channels = self.cert_device.l2cap.FetchOpenedChannels(l2cap_cert_pb2.FetchOpenedChannelsRequest()) assert len(open_channels.dcid) == 2 + def test_accept_disconnect(self): + """ + L2CAP/COS/CED/BV-07-C + """ + self.device_under_test.l2cap.OpenChannel(l2cap_facade_pb2.OpenChannelRequest(remote=self.cert_address, psm=0x01)) + cert_connection_stream = self.cert_device.l2cap.connection_complete_stream + cert_connection_stream.subscribe() + self.device_under_test.l2cap.Connect(self.cert_address) + cert_connection_stream.assert_event_occurs( + lambda device: device.remote == self.dut_address + ) + cert_connection_stream.unsubscribe() + time.sleep(ASYNC_OP_TIME_SECONDS) + cert_packet_stream = self.cert_device.l2cap.packet_stream + cert_packet_stream.subscribe() + open_channels = self.cert_device.l2cap.FetchOpenedChannels(l2cap_cert_pb2.FetchOpenedChannelsRequest()) + cid = open_channels.dcid[0] + disconnection_request_packet = b"\x06\x01\x04\x00\x40\x00\x40\x01" + disconnection_response_packet = b"\x07\x01\x04\x00\x40\x00\x40\x01" + #TODO(b/143374372): Instead of hardcoding this, use packet builder + self.cert_device.l2cap.SendL2capPacket(l2cap_facade_pb2.L2capPacket(channel=1, payload=disconnection_request_packet)) + cert_packet_stream.assert_event_occurs( + lambda packet: disconnection_response_packet in packet.payload + ) + cert_packet_stream.unsubscribe() + time.sleep(ASYNC_OP_TIME_SECONDS) # TODO(b/144186649): Remove this line + def test_basic_operation_request_connection(self): """ L2CAP/COS/CED/BV-01-C [Request Connection] @@ -169,6 +196,7 @@ class SimpleL2capTest(GdBaseTestClass): lambda packet: echo_response_packet in packet.payload ) cert_packet_stream.unsubscribe() + time.sleep(ASYNC_OP_TIME_SECONDS) # TODO(b/144186649): Remove this line def test_reject_unknown_command(self): """ diff --git a/gd/l2cap/classic/internal/signalling_manager.cc b/gd/l2cap/classic/internal/signalling_manager.cc index 73c027db1..47792b08f 100644 --- a/gd/l2cap/classic/internal/signalling_manager.cc +++ b/gd/l2cap/classic/internal/signalling_manager.cc @@ -234,7 +234,7 @@ void ClassicSignallingManager::OnDisconnectionRequest(SignalId signal_id, Cid ci LOG_WARN("Disconnect request for an unknown channel"); return; } - auto builder = DisconnectionResponseBuilder::Create(signal_id.Value(), remote_cid, cid); + auto builder = DisconnectionResponseBuilder::Create(signal_id.Value(), cid, remote_cid); enqueue_buffer_->Enqueue(std::move(builder), handler_); channel->OnClosed(hci::ErrorCode::SUCCESS); link_->FreeDynamicChannel(cid); |