Verificando e depurando

Para verificar e depurar a pilha Bluetooth, use as ferramentas fornecidas no AOSP e nos testes do Bluetooth Special Interest Group (SIG).

Testando e verificando

Para testar a pilha Bluetooth, o AOSP fornece uma combinação de testes de unidade, testes CTS e ferramentas para o Bluetooth Profile Tuning Suite.

Testes unitários em AOSP

AOSP inclui testes funcionais e de unidade para a pilha Bluetooth padrão. Esses testes estão localizados em /packages/modules/Bluetooth/system/test/ . Para executar os testes AOSP, faça o seguinte:

  1. Pare o tempo de execução do Android:
    adb shell stop
  2. No diretório de teste, execute o arquivo executável do shell e inclua opções se desejar executar um teste ou conjunto de testes específico:
    ./run_unit_tests.sh TEST_GROUP_NAME TEST_NAME OPTIONS
  3. Quando os testes terminarem, reative o tempo de execução do Android:
    adb shell start

A lista de nomes de testes pode ser encontrada em /packages/modules/Bluetooth/system/test/README.md .

Conjunto de testes de comunicação do Android

O Android Comms Test Suite (ACTS) realiza testes automatizados de pilhas de conectividade, como Wi-Fi, Bluetooth e serviços de celular. A ferramenta de teste requer adb e python e pode ser encontrada em tools/test/connectivity/acts .

Os testes ACTS para Bluetooth e Bluetooth Low Energy são encontrados em tools/test/connectivity/acts_tests/tests/google/bt/ e tools/test/connectivity/acts_tests/tests/google/ble/ respectivamente.

Conjunto de ajuste de perfil

O Bluetooth SIG fornece o Bluetooth Profile Tuning Suite (PTS), uma ferramenta de teste para interoperabilidade de protocolo e perfil. Para obter mais informações, consulte o site do Bluetooth Profile Tuning Suite .

AOSP fornece ferramentas adicionais para complementar o Bluetooth PTS. Essas ferramentas estão localizadas em tools/test/connectivity/acts_tests/tests/google/bt/pts/ .

Testes CTS

O Compatibility Test Suite (CTS) inclui testes para a pilha Bluetooth. Eles estão localizados em cts/apps/CtsVerifier/src/com/android/cts/verifier/bluetooth .

Opções de depuração

AOSP fornece diferentes métodos de depuração da pilha Bluetooth de um dispositivo, incluindo logs e relatórios de bugs. Esses métodos podem não funcionar para problemas que não podem ser reproduzidos ou para problemas de áudio, que podem ser afetados por diversas partes da plataforma e do dispositivo.

Depuração com relatórios de bugs

Para verificar o status do serviço Bluetooth usando dumpsys , use o seguinte comando:

adb shell dumpsys bluetooth_manager

Por padrão, todas as mensagens de log são de nível de rastreamento 2. Para saber mais sobre os níveis de log e alterar os níveis de log para diferentes perfis, consulte system/bt/conf/bt_stack.conf .

Para extrair logs de espionagem do relatório de bug, use o script btsnooz .

  1. Obtenha btsnooz.py .
  2. Extraia a versão em texto do relatório de bug.
  3. Execute btsnooz.py na versão em texto do relatório de bug:
    btsnooz.py BUG_REPORT.txt > BTSNOOP.log

Depuração com logs

No Android 4.4 e posterior, você pode coletar manualmente os logs do BTSnoop, que se assemelham ao formato snoop na RFC 1761. Esses logs capturam os pacotes Host Controller Interface (HCI). Para a maioria dos dispositivos Android, os logs são armazenados em data/misc/bluetooth/logs .

Por motivos de privacidade, o BTSnoop sempre ativo e “na memória” registra apenas informações e eventos não pessoais. Para registrar todos os dados, o usuário precisa ativar o rastreamento Bluetooth HCI fazendo o seguinte:

  1. Habilite as opções do desenvolvedor no dispositivo.
  2. No menu de opções do desenvolvedor , ative a opção Ativar log de espionagem Bluetooth HCI .
  3. Reinicie o Bluetooth para que o registro tenha efeito.