diff options
| author | 2022-11-14 21:07:20 +0000 | |
|---|---|---|
| committer | 2022-11-14 21:07:20 +0000 | |
| commit | cf9df6a611e6bd4eb14f1fded1ed66f6b1497231 (patch) | |
| tree | 09fa042dc61bffc2f5bd4196772f63e5bdc5ac6f | |
| parent | e3e071bbc70d3ca9bf270e793f0821a3b4513658 (diff) | |
Revert "RootCanal: Implement rootcanal_ll_test"
This reverts commit e3e071bbc70d3ca9bf270e793f0821a3b4513658.
Reason for revert: Breaks host_unit_tests
Change-Id: I0cb0523a4cf9b6d2423e914e8879d6d44b920b86
| -rw-r--r-- | tools/rootcanal/Android.bp | 101 | ||||
| -rw-r--r-- | tools/rootcanal/model/controller/dual_mode_controller_python3.cc | 225 | ||||
| -rw-r--r-- | tools/rootcanal/model/controller/link_layer_controller.cc | 5 | ||||
| -rw-r--r-- | tools/rootcanal/model/controller/link_layer_controller.h | 4 | ||||
| -rw-r--r-- | tools/rootcanal/py/bluetooth.py | 48 | ||||
| -rw-r--r-- | tools/rootcanal/py/controller.py | 108 | ||||
| -rw-r--r-- | tools/rootcanal/test/LL/DDI/SCN/BV_13_C.py | 130 | ||||
| -rw-r--r-- | tools/rootcanal/test/main.py | 6 | 
8 files changed, 4 insertions, 623 deletions
| diff --git a/tools/rootcanal/Android.bp b/tools/rootcanal/Android.bp index 4990be4a5e..07262908e2 100644 --- a/tools/rootcanal/Android.bp +++ b/tools/rootcanal/Android.bp @@ -103,84 +103,6 @@ cc_library_static {      ],  } -// This library implements Python bindings to the DualModeController -// class to enable scripted testing in Python. -cc_library_host_shared { -    name: "lib_rootcanal_python3", -    defaults: [ -        "bluetooth_py3_native_extension_defaults", -        "rootcanal_defaults", -    ], -    srcs: [ -        "model/controller/acl_connection.cc", -        "model/controller/acl_connection_handler.cc", -        "model/controller/controller_properties.cc", -        "model/controller/dual_mode_controller.cc", -        "model/controller/dual_mode_controller_python3.cc", -        "model/controller/isochronous_connection_handler.cc", -        "model/controller/le_advertiser.cc", -        "model/controller/link_layer_controller.cc", -        "model/controller/sco_connection.cc", -        "model/controller/security_manager.cc", -        "model/devices/device.cc", -        "model/setup/async_manager.cc", -        ":BluetoothPacketSources", -        ":BluetoothHciClassSources", -        ":BluetoothCryptoToolboxSources", -    ], -    export_include_dirs: [ -        "include", -        ".", -    ], -    stl: "libc++_static", -    static_libs: [ -        "liblog", -        "libjsoncpp", -    ], -    whole_static_libs: [ -        "liblmp", -    ], -    header_libs: [ -        "pybind11_headers", -    ], -    cflags: [ -        "-fexceptions", -    ], -    rtti: true, -} - -// Generate the python parser+serializer backend for -// packets/link_layer_packets.pdl. -genrule { -    name: "link_layer_packets_python3_gen", -    defaults: [ "pdl_python_generator_defaults" ], -    cmd: "$(location :pdl) $(in) |" + -        " $(location :pdl_python_generator)" + -        " --output $(out) --custom-type-location py.bluetooth", -    srcs: [ -        "packets/link_layer_packets.pdl", -    ], -    out: [ -        "link_layer_packets.py", -    ], -} - -// Generate the python parser+serializer backend for -// hci_packets.pdl. -genrule { -    name: "hci_packets_python3_gen", -    defaults: [ "pdl_python_generator_defaults" ], -    cmd: "$(location :pdl) $(in) |" + -        " $(location :pdl_python_generator)" + -        " --output $(out) --custom-type-location py.bluetooth", -    srcs: [ -        ":BluetoothHciPackets", -    ], -    out: [ -        "hci_packets.py", -    ], -} -  cc_library_static {      name: "libscriptedbeaconpayload-protos-lite",      host_supported: true, @@ -238,29 +160,6 @@ cc_test_host {      ],  } -// Implement the Bluetooth official LL test suite for root-canal. -python_test_host { -    name: "rootcanal_ll_test", -    main: "test/main.py", -    srcs: [ -        "py/controller.py", -        "py/bluetooth.py", -        ":hci_packets_python3_gen", -        ":link_layer_packets_python3_gen", -        "test/main.py", -        "test/LL/DDI/SCN/BV_13_C.py", -    ], -    data: [ -        ":lib_rootcanal_python3", -    ], -    libs: [ -        "typing_extensions", -    ], -    test_options: { -        unit_test: true, -    }, -} -  // test-vendor unit tests for host  cc_test_host {      name: "rootcanal_test_host", diff --git a/tools/rootcanal/model/controller/dual_mode_controller_python3.cc b/tools/rootcanal/model/controller/dual_mode_controller_python3.cc deleted file mode 100644 index 5e3234dc4b..0000000000 --- a/tools/rootcanal/model/controller/dual_mode_controller_python3.cc +++ /dev/null @@ -1,225 +0,0 @@ -/* - * Copyright 2022 The Android Open Source Project - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - *      http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -#include <pybind11/pybind11.h> -#include <pybind11/stl.h> - -#include "dual_mode_controller.h" - -using namespace std::literals; -namespace py = pybind11; - -namespace rootcanal { - -namespace hci { -enum Type { -  CMD, -  EVT, -  ACL, -  SCO, -  ISO, -}; -}  // namespace hci - -// Overload the class DualModeController to implement -// SendLinkLayerPacket as forwarding packets to a registered handler. -class BaseController : public DualModeController { - public: -  BaseController() : DualModeController() { -    RegisterTaskScheduler( -        [this](std::chrono::milliseconds delay, TaskCallback const& task) { -          return this->async_manager_.ExecAsync(0, delay, task); -        }); -    RegisterPeriodicTaskScheduler([this](std::chrono::milliseconds delay, -                                         std::chrono::milliseconds period, -                                         TaskCallback const& task) { -      return this->async_manager_.ExecAsyncPeriodically(0, delay, period, task); -    }); -    RegisterTaskCancel([this](AsyncTaskId task_id) { -      this->async_manager_.CancelAsyncTask(task_id); -    }); -  } -  ~BaseController() = default; - -  void RegisterLLChannel( -      std::function<void(std::shared_ptr<std::vector<uint8_t>>)> const& -          send_ll) { -    send_ll_ = send_ll; -  } - -  void Start() { -    if (timer_task_id_ == kInvalidTaskId) { -      timer_task_id_ = async_manager_.ExecAsyncPeriodically( -          0, 0ms, 5ms, [this]() { this->TimerTick(); }); -    } -  } - -  void Stop() { -    if (timer_task_id_ != kInvalidTaskId) { -      async_manager_.CancelAsyncTask(timer_task_id_); -      timer_task_id_ = kInvalidTaskId; -    } -  } - -  virtual void SendLinkLayerPacket( -      std::shared_ptr<model::packets::LinkLayerPacketBuilder> packet, -      Phy::Type phy_type_) override { -    (void)phy_type_; -    auto bytes = std::make_shared<std::vector<uint8_t>>(); -    bluetooth::packet::BitInserter inserter(*bytes); -    bytes->reserve(packet->size()); -    packet->Serialize(inserter); -    send_ll_(bytes); -  } - - private: -  std::function<void(std::shared_ptr<std::vector<uint8_t>>)> send_ll_{}; -  AsyncManager async_manager_; -  AsyncTaskId timer_task_id_; - -  BaseController(BaseController const&) = delete; -  DualModeController& operator=(BaseController const&) = delete; -}; - -PYBIND11_MODULE(lib_rootcanal_python3, m) { -  m.doc() = "RootCanal controller plugin"; - -  py::enum_<hci::Type>(m, "HciType") -      .value("Cmd", hci::Type::CMD) -      .value("Evt", hci::Type::EVT) -      .value("Acl", hci::Type::ACL) -      .value("Sco", hci::Type::SCO) -      .value("Iso", hci::Type::ISO); - -  m.def( -      "generate_rpa", -      [](py::bytes arg) { -        std::string irk_str = arg; -        irk_str.resize(LinkLayerController::kIrkSize); - -        std::array<uint8_t, LinkLayerController::kIrkSize> irk{}; -        std::copy(irk_str.begin(), irk_str.end(), irk.begin()); - -        bluetooth::hci::Address rpa = -            rootcanal::LinkLayerController::generate_rpa(irk); -        return rpa.address; -      }, -      "Bluetooth RPA generation"); - -  py::class_<rootcanal::BaseController, -             std::shared_ptr<rootcanal::BaseController>> -      basic_controller(m, "BaseController"); - -  // Implement the constructor with two callback parameters to -  // handle emitted HCI packets and LL packets. -  basic_controller.def(py::init([](py::object hci_handler, -                                   py::object ll_handler) { -    std::shared_ptr<BaseController> controller = -        std::make_shared<BaseController>(); -    controller->RegisterEventChannel( -        [=](std::shared_ptr<std::vector<uint8_t>> data) { -          pybind11::gil_scoped_acquire acquire; -          hci_handler( -              hci::Type::EVT, -              py::bytes(reinterpret_cast<char*>(data->data()), data->size())); -        }); -    controller->RegisterAclChannel( -        [=](std::shared_ptr<std::vector<uint8_t>> data) { -          pybind11::gil_scoped_acquire acquire; -          hci_handler( -              hci::Type::ACL, -              py::bytes(reinterpret_cast<char*>(data->data()), data->size())); -        }); -    controller->RegisterScoChannel( -        [=](std::shared_ptr<std::vector<uint8_t>> data) { -          pybind11::gil_scoped_acquire acquire; -          hci_handler( -              hci::Type::SCO, -              py::bytes(reinterpret_cast<char*>(data->data()), data->size())); -        }); -    controller->RegisterIsoChannel( -        [=](std::shared_ptr<std::vector<uint8_t>> data) { -          pybind11::gil_scoped_acquire acquire; -          hci_handler( -              hci::Type::ISO, -              py::bytes(reinterpret_cast<char*>(data->data()), data->size())); -        }); -    controller->RegisterLLChannel( -        [=](std::shared_ptr<std::vector<uint8_t>> data) { -          pybind11::gil_scoped_acquire acquire; -          ll_handler( -              py::bytes(reinterpret_cast<char*>(data->data()), data->size())); -        }); -    return controller; -  })); - -  // Timer interface. -  basic_controller.def("start", &BaseController::Start); -  basic_controller.def("stop", &BaseController::Stop); - -  // Implement method BaseController.receive_hci which -  // injects HCI packets into the controller as if sent from the host. -  basic_controller.def( -      "send_hci", [](std::shared_ptr<rootcanal::BaseController> controller, -                     hci::Type typ, py::bytes data) { -        std::string data_str = data; -        std::shared_ptr<std::vector<uint8_t>> bytes = -            std::make_shared<std::vector<uint8_t>>(data_str.begin(), -                                                   data_str.end()); - -        switch (typ) { -          case hci::Type::CMD: -            controller->HandleCommand(bytes); -            break; -          case hci::Type::ACL: -            controller->HandleAcl(bytes); -            break; -          case hci::Type::SCO: -            controller->HandleSco(bytes); -            break; -          case hci::Type::ISO: -            controller->HandleIso(bytes); -            break; -          default: -            std::cerr << "Dropping HCI packet with unknown type " << typ -                      << std::endl; -            break; -        } -      }); - -  // Implement method BaseController.receive_hci which -  // injects LL packets into the controller as if sent over the air. -  basic_controller.def( -      "send_ll", [](std::shared_ptr<rootcanal::BaseController> controller, -                    py::bytes data) { -        std::string data_str = data; -        std::shared_ptr<std::vector<uint8_t>> bytes = -            std::make_shared<std::vector<uint8_t>>(data_str.begin(), -                                                   data_str.end()); - -        model::packets::LinkLayerPacketView packet = -            model::packets::LinkLayerPacketView::Create( -                bluetooth::packet::PacketView<bluetooth::packet::kLittleEndian>( -                    bytes)); -        if (!packet.IsValid()) { -          std::cerr << "Dropping malformed LL packet" << std::endl; -          return; -        } -        controller->IncomingPacket(std::move(packet)); -      }); -} - -}  // namespace rootcanal diff --git a/tools/rootcanal/model/controller/link_layer_controller.cc b/tools/rootcanal/model/controller/link_layer_controller.cc index 3ab0e1064a..877bc6026c 100644 --- a/tools/rootcanal/model/controller/link_layer_controller.cc +++ b/tools/rootcanal/model/controller/link_layer_controller.cc @@ -212,6 +212,9 @@ std::optional<AddressWithType> LinkLayerController::ResolvePrivateAddress(    return {};  } +static Address generate_rpa( +    std::array<uint8_t, LinkLayerController::kIrkSize> irk); +  std::optional<AddressWithType>  LinkLayerController::GenerateResolvablePrivateAddress(AddressWithType address,                                                        IrkSelection irk) { @@ -2610,7 +2613,7 @@ void LinkLayerController::IncomingKeypressNotificationPacket(  }  #endif /* !ROOTCANAL_LMP */ -Address LinkLayerController::generate_rpa( +static Address generate_rpa(      std::array<uint8_t, LinkLayerController::kIrkSize> irk) {    // most significant bit, bit7, bit6 is 01 to be resolvable random    // Bits of the random part of prand shall not be all 1 or all 0 diff --git a/tools/rootcanal/model/controller/link_layer_controller.h b/tools/rootcanal/model/controller/link_layer_controller.h index 18213e72ac..3149dd1fce 100644 --- a/tools/rootcanal/model/controller/link_layer_controller.h +++ b/tools/rootcanal/model/controller/link_layer_controller.h @@ -62,10 +62,6 @@ class LinkLayerController {   public:    static constexpr size_t kIrkSize = 16; -  // Generate a resolvable private address using the specified IRK. -  static Address generate_rpa( -      std::array<uint8_t, LinkLayerController::kIrkSize> irk); -    LinkLayerController(const Address& address,                        const ControllerProperties& properties); diff --git a/tools/rootcanal/py/bluetooth.py b/tools/rootcanal/py/bluetooth.py deleted file mode 100644 index dba35cd53a..0000000000 --- a/tools/rootcanal/py/bluetooth.py +++ /dev/null @@ -1,48 +0,0 @@ -from dataclasses import dataclass, field -from typing import Tuple - - -@dataclass -class Address: -    address: bytes = field(default=bytes([0, 0, 0, 0, 0, 0])) - -    def __post_init__(self): -        self.address = bytes(self.address) - -    def from_str(address: str) -> 'Address': -        return Address(bytes([int(b, 16) for b in address.split(':')])) - -    def parse(span: bytes) -> Tuple['Address', bytes]: -        assert len(span) > 6 -        return (Address(bytes(reversed(span[:6]))), span[6:]) - -    def parse_all(span: bytes) -> 'Address': -        assert (len(span) == 6) -        return Address(bytes(reversed(span))) - -    def serialize(self) -> bytes: -        return bytes(reversed(self.address)) - -    def __repr__(self) -> str: -        return ':'.join([f'{b:02x}' for b in self.address]) - -    @property -    def size(self) -> int: -        return 6 - - -@dataclass -class ClassOfDevice: - -    def parse(span: bytes) -> Tuple['Address', bytes]: -        assert False - -    def parse_all(span: bytes) -> 'Address': -        assert False - -    def serialize(self) -> bytes: -        assert False - -    @property -    def size(self) -> int: -        assert False diff --git a/tools/rootcanal/py/controller.py b/tools/rootcanal/py/controller.py deleted file mode 100644 index 96bdc49bfb..0000000000 --- a/tools/rootcanal/py/controller.py +++ /dev/null @@ -1,108 +0,0 @@ -import asyncio -import collections -import hci_packets as hci -import lib_rootcanal_python3 as rootcanal -import link_layer_packets as ll -import py.bluetooth -import unittest -from typing import Optional -from hci_packets import ErrorCode - - -class Controller(rootcanal.BaseController): -    """Binder class to DualModeController. -    The methods send_cmd, send_hci, send_ll are used to inject HCI or LL -    packets into the controller, and receive_hci, receive_ll to -    catch outgoing HCI packets of LL pdus.""" - -    def __init__(self): -        super().__init__(self.receive_hci_, self.receive_ll_) -        self.evt_queue = collections.deque() -        self.acl_queue = collections.deque() -        self.ll_queue = collections.deque() -        self.evt_queue_event = asyncio.Event() -        self.acl_queue_event = asyncio.Event() -        self.ll_queue_event = asyncio.Event() - -    def receive_hci_(self, typ: rootcanal.HciType, packet: bytes): -        if typ == rootcanal.HciType.Evt: -            print(f"<-- received HCI event data={len(packet)}[..]") -            self.evt_queue.append(packet) -            self.evt_queue_event.set() -        elif typ == rootcanal.HciType.Acl: -            print(f"<-- received HCI ACL packet data={len(packet)}[..]") -            self.acl_queue.append(packet) -            self.acl_queue_event.set() -        else: -            print(f"ignoring HCI packet typ={typ}") - -    def receive_ll_(self, packet: bytes): -        print(f"<-- received LL pdu data={len(packet)}[..]") -        self.ll_queue.append(packet) -        self.ll_queue_event.set() - -    def send_cmd(self, cmd: hci.Command): -        print(f"--> sending HCI command {cmd.__class__.__name__}") -        self.send_hci(rootcanal.HciType.Cmd, cmd.serialize()) - -    def send_ll(self, pdu: ll.LinkLayerPacket, rssi: Optional[int] = None): -        print(f"--> sending LL pdu {pdu.__class__.__name__}") -        if rssi is not None: -            pdu = ll.RssiWrapper(rssi=rssi, payload=pdu.serialize()) -        super().send_ll(pdu.serialize()) - -    def stop(self): -        super().stop() -        if self.evt_queue: -            print("evt queue not empty at stop():") -            for packet in self.evt_queue: -                evt = hci.Event.parse_all(packet) -                evt.show() -            raise Exception("evt queue not empty at stop()") - -        if self.ll_queue: -            for packet in self.ll_queue: -                pdu = ll.LinkLayerPacket.parse_all(packet) -                pdu.show() -            raise Exception("ll queue not empty at stop()") - -    async def receive_evt(self): -        while not self.evt_queue: -            await self.evt_queue_event.wait() -            self.evt_queue_event.clear() -        return self.evt_queue.popleft() - -    async def expect_evt(self, expected_evt: hci.Event): -        packet = await self.receive_evt() -        evt = hci.Event.parse_all(packet) -        if evt != expected_evt: -            print("received unexpected event") -            print("expected event:") -            expected_evt.show() -            print("received event:") -            evt.show() -            raise Exception(f"unexpected evt {evt.__class__.__name__}") - - -class ControllerTest(unittest.IsolatedAsyncioTestCase): -    """Helper class for writing controller tests using the python bindings. -    The test setups the controller sending the Reset command and configuring -    the event masks to allow all events.""" - -    def setUp(self): -        self.controller = Controller() -        self.controller.start() - -    async def asyncSetUp(self): -        controller = self.controller - -        # Reset the controller and enable all events and LE events. -        controller.send_cmd(hci.Reset()) -        await controller.expect_evt(hci.ResetComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) -        controller.send_cmd(hci.SetEventMask(event_mask=0xffffffffffffffff)) -        await controller.expect_evt(hci.SetEventMaskComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) -        controller.send_cmd(hci.LeSetEventMask(le_event_mask=0xffffffffffffffff)) -        await controller.expect_evt(hci.LeSetEventMaskComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) - -    def tearDown(self): -        self.controller.stop() diff --git a/tools/rootcanal/test/LL/DDI/SCN/BV_13_C.py b/tools/rootcanal/test/LL/DDI/SCN/BV_13_C.py deleted file mode 100644 index 518b16aefd..0000000000 --- a/tools/rootcanal/test/LL/DDI/SCN/BV_13_C.py +++ /dev/null @@ -1,130 +0,0 @@ -import lib_rootcanal_python3 as rootcanal -import hci_packets as hci -import link_layer_packets as ll -import unittest -from hci_packets import ErrorCode -from py.bluetooth import Address -from py.controller import ControllerTest - - -class Test(ControllerTest): - -    # LL/DDI/SCN/BV-13-C [Network Privacy – Passive Scanning, Peer IRK] -    async def test(self): -        # Test parameters. -        LL_scanner_scanInterval_MIN = 0x2000 -        LL_scanner_scanInterval_MAX = 0x2000 -        LL_scanner_scanWindow_MIN = 0x200 -        LL_scanner_scanWindow_MAX = 0x200 -        LL_scanner_Adv_Channel_Map = 0x7 - -        controller = self.controller -        peer_irk = bytes([1] * 16) -        peer_identity_address = Address.from_str('aa:bb:cc:dd:ee:ff') -        peer_identity_address_type = hci.PeerAddressType.PUBLIC_DEVICE_OR_IDENTITY_ADDRESS -        peer_resolvable_address = Address(rootcanal.generate_rpa(peer_irk)) - -        # 1. The Upper Tester populates the IUT resolving list with the peer IRK -        # and identity address. -        controller.send_cmd( -            hci.LeAddDeviceToResolvingList(peer_irk=peer_irk, -                                           local_irk=bytes([0] * 16), -                                           peer_identity_address=peer_identity_address, -                                           peer_identity_address_type=peer_identity_address_type)) - -        await controller.expect_evt( -            hci.LeAddDeviceToResolvingListComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) - -        controller.send_cmd(hci.LeSetResolvablePrivateAddressTimeout(rpa_timeout=0x10)) - -        await controller.expect_evt( -            hci.LeSetResolvablePrivateAddressTimeoutComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) - -        controller.send_cmd(hci.LeSetAddressResolutionEnable(address_resolution_enable=hci.Enable.ENABLED)) - -        await controller.expect_evt( -            hci.LeSetAddressResolutionEnableComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) - -        # 2. The Upper Tester enables passive scanning in the IUT. -        controller.send_cmd( -            hci.LeSetScanParameters(le_scan_type=hci.LeScanType.PASSIVE, -                                    le_scan_interval=LL_scanner_scanInterval_MAX, -                                    le_scan_window=LL_scanner_scanWindow_MAX, -                                    own_address_type=hci.OwnAddressType.RESOLVABLE_OR_PUBLIC_ADDRESS, -                                    scanning_filter_policy=hci.LeScanningFilterPolicy.ACCEPT_ALL)) - -        await controller.expect_evt(hci.LeSetScanParametersComplete(status=ErrorCode.SUCCESS, -                                                                    num_hci_command_packets=1)) - -        controller.send_cmd( -            hci.LeSetScanEnable(le_scan_enable=hci.Enable.ENABLED, filter_duplicates=hci.Enable.DISABLED)) - -        await controller.expect_evt(hci.LeSetScanEnableComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) - -        # 3. Configure the Lower Tester to start advertising. The Lower Tester uses -        # a resolvable private address in the AdvA field. -        # 4. The Lower Tester sends an ADV_NONCONN_IND packet each advertising event -        # using the selected advertising channel only. Repeat for at least 20 -        # advertising intervals. -        controller.send_ll(ll.LeLegacyAdvertisingPdu(source_address=peer_resolvable_address, -                                                     advertising_address_type=ll.AddressType.RANDOM, -                                                     advertising_type=ll.LegacyAdvertisingType.ADV_NONCONN_IND, -                                                     advertising_data=[1, 2, 3]), -                           rssi=0xf0) - -        # 5. The Upper Tester receives at least one HCI_LE_Advertising_Report -        # reporting the advertising packets sent by the Lower Tester. The address in -        # the report is resolved by the IUT using the distributed IRK. -        await controller.expect_evt( -            hci.LeAdvertisingReportRaw(responses=[ -                hci.LeAdvertisingResponseRaw(event_type=hci.AdvertisingEventType.ADV_NONCONN_IND, -                                             address_type=hci.AddressType.PUBLIC_IDENTITY_ADDRESS, -                                             address=peer_identity_address, -                                             advertising_data=[1, 2, 3], -                                             rssi=0xf0) -            ])) - -        # 6. The Upper Tester sends an HCI_LE_Set_Scan_Enable to the IUT to stop the -        # scanning function and receives an HCI_Command_Complete event in response. -        controller.send_cmd(hci.LeSetScanEnable(le_scan_enable=hci.Enable.DISABLED)) - -        await controller.expect_evt(hci.LeSetScanEnableComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) - -        # 7. The Upper Tester disables address resolution. -        controller.send_cmd(hci.LeSetAddressResolutionEnable(address_resolution_enable=hci.Enable.DISABLED)) - -        await controller.expect_evt( -            hci.LeSetAddressResolutionEnableComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) - -        # 8. The Upper Tester enables passive scanning in the IUT. -        controller.send_cmd( -            hci.LeSetScanEnable(le_scan_enable=hci.Enable.ENABLED, filter_duplicates=hci.Enable.DISABLED)) - -        await controller.expect_evt(hci.LeSetScanEnableComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) - -        # 9. The Lower Tester sends an ADV_NONCONN_IND packet each advertising event -        # using the selected advertising channel only. Repeat for at least 20 -        # advertising intervals. -        controller.send_ll(ll.LeLegacyAdvertisingPdu(source_address=peer_resolvable_address, -                                                     advertising_address_type=ll.AddressType.RANDOM, -                                                     advertising_type=ll.LegacyAdvertisingType.ADV_NONCONN_IND, -                                                     advertising_data=[1, 2, 3]), -                           rssi=0xf0) - -        # 10. The IUT does not resolve the Lower Tester’s address and reports it -        # unresolved (as received in the advertising PDU) in the advertising report -        # events to the Upper Tester. -        await controller.expect_evt( -            hci.LeAdvertisingReportRaw(responses=[ -                hci.LeAdvertisingResponseRaw(event_type=hci.AdvertisingEventType.ADV_NONCONN_IND, -                                             address_type=hci.AddressType.RANDOM_DEVICE_ADDRESS, -                                             address=peer_resolvable_address, -                                             advertising_data=[1, 2, 3], -                                             rssi=0xf0) -            ])) - -        # 11. The Upper Tester sends an HCI_LE_Set_Scan_Enable to the IUT to stop the -        # scanning function and receives an HCI_Command_Complete event in response. -        controller.send_cmd(hci.LeSetScanEnable(le_scan_enable=hci.Enable.DISABLED)) - -        await controller.expect_evt(hci.LeSetScanEnableComplete(status=ErrorCode.SUCCESS, num_hci_command_packets=1)) diff --git a/tools/rootcanal/test/main.py b/tools/rootcanal/test/main.py deleted file mode 100644 index 26fe2cc06b..0000000000 --- a/tools/rootcanal/test/main.py +++ /dev/null @@ -1,6 +0,0 @@ -import unittest - -import test.LL.DDI.SCN.BV_13_C - -if __name__ == "__main__": -    unittest.TextTestRunner(verbosity=2).run(unittest.defaultTestLoader.loadTestsFromModule(test.LL.DDI.SCN.BV_13_C)) |