Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Tests #11

Closed
ineiti opened this issue Sep 28, 2020 · 6 comments
Closed

Tests #11

ineiti opened this issue Sep 28, 2020 · 6 comments
Assignees

Comments

@ineiti
Copy link
Collaborator

ineiti commented Sep 28, 2020

This issue tracks the various tests to be done on the modified SwissCovid app to ensure that it works as expected.

Functionalities:

  1. The application correctly advertises RPIs
  2. The application correctly scans other devices' RPIs
  3. The application can declare a positive diagnosis
  4. The application notifies the user of an exposure
  5. The crypto is correct
  6. The exposure computation is correct
  7. End-to-end with mixed phones.

Environments:

  1. The application runs on a phone with an open OS without any Google Play services installed
    →Pixel 4 installed with stock LineageOS 17.1
  2. The application runs on a phone with a commercial OS lacking Google Play services
    →Huawei?
Test Stock LineageOS Commercial OS w/o GMS
1 ✔️ (manual)
2 ✔️ (manual)
3 ✔️ (manual, calibration app)
4 ✔️ (manual, calibration app)
5 ✔️ (microG nearby-core test)
6 see microg/GmsCore#1179 (comment)
7 ✔️ (manual, calibration app, see #23)
@cgrigis cgrigis changed the title Tests to do Tests Sep 28, 2020
@cgrigis cgrigis self-assigned this Sep 29, 2020
@cgrigis
Copy link
Collaborator

cgrigis commented Sep 30, 2020

Suggestions to help investigate tests:

  • Dump the database to examine exposures manually
  • In calibration app: check whether we can force download of keys and check of matching without having to wait long durations
  • Check whether we can enable low-level traces for Bluetooth

Next steps:

  • Check for security issues — RPI rotations, MAC address rotations, contents of the encrypted data (valid for the actual application)
  • Focus on ensuring functionality now, worry about improving build process later.

@cgrigis
Copy link
Collaborator

cgrigis commented Oct 5, 2020

@cgrigis
Copy link
Collaborator

cgrigis commented Oct 5, 2020

@cgrigis
Copy link
Collaborator

cgrigis commented Oct 23, 2020

Bluetooth analysis

Tools used:

  • Logcat traces
  • HCI snoop debug traces on the phones
  • Bluetooth sniffer device (TI CC1352R1 dev kit)
  • Nordic nRF Connect app

The devices analyzed are:

  • Google Pixel4 (Bluetooth 5.0), LineageOS 17.1, SwissCovid app bundled with microG EN libraries (v0.2.13.203915)
  • Sony Z3 (Bluetooth 4.0), LineageOS 17.1, SwissCovid app bundled with microG EN libraries (v0.2.13.203915)

Advertisement: sequence of HCI commands

Every 10 minutes, aligned on a 10-minute boundary:

Pixel4

  • LE Rand
  • LE Set Extended Advertising Parameters handle 0, legacy PDUs, ADV_NONCONN_IND, interval 250-281.25 msec, channels 37,38,39, random device address
  • LE Set Advertising Set Random Address handle 0
  • LE Set Extended Advertising Data handle 0
  • LE Set Extended Scan Response Data handle 0
  • LE Set Extended Advertising Enable handle 0, on
    [10min]
  • LE Set Extended Advertising Enable handle 0, off
  • LE Remove Advertising Set handle 0

Z3

  • LE Rand
  • LE Set Advertising Parameters ADV_NONCONN_IND, interval 250-281.25 msec, channels 37,38,39, random device address
  • LE Set Random Address
  • LE Set Advertising Data
  • LE Set Scan Response Data
  • LE Set Advertise Enable on
    [10min]
  • LE Set Advertise Enable off

Scanning: sequence of HCI commands

Every 3 minutes (not aligned):

Pixel4

  • Vendor command 0x0157 (4x)
  • LE Set Extended Scan Parameters active, random device address, accept all adv (except direct not addressed here)
  • LE Set Extended Scan Enable on
  • LE Set Extended Scan Enable off
  • LE Set Extended Scan Parameters active, random device address, accept all adv (except direct not addressed here)
  • LE Set Extended Scan Parameters active, random device address, accept all adv (except direct not addressed here)
  • LE Set Extended Scan Enable on
    [20s]
  • LE Set Extended Scan Enable off

Z3

  • LE Set Scan Parameters active, random device address, accept all adv (except direct not addressed here)
  • LE Set Scan Enable on
  • LE Set Scan Enable off
  • LE Set Scan Parameters active, random device address, accept all adv (except direct not addressed here)
  • LE Set Scan Parameters active, random device address, accept all adv (except direct not addressed here)
  • LE Set Scan Enable on
    [20s]
  • LE Set Scan Enable off

Scanning events received

Pixel4

LE Meta -- LE Extended Advertising Report legacy, ADV_NONCONN_IND, random device address,

Z3

LE Meta -- LE Advertising Report ADV_NONCONN_IND, random device address,

Advertisements recorded from the sniffer, channel 37

Interval distribution over an RPI value (10 min):

Pixel4

mean: 287.21ms, median: 286,25ms

Z3

mean: 287.80ms, median: 286.26ms

Other

Every 15 minutes (not aligned):

Pixel4

  • LE Set Random Address

Z3

  • LE Set Random Address

NOTE: On the Z3, this has the effect of also changing the advertising random address in the middle of a 10-minute RPI cycle, without changing the RPI. This is probably due to it having an older Bluetooth HW and using legacy commands, which do not distinguish between setting the random address for advertising and for scanning.

RPI / BD Address overlap

  • The same BD address used with different advertised RPIs was never observed.
  • The same RPI value advertised with two different BD addresses was observed on the Z3, as indicated in the previous note.

In other words, whenever the RPI changes, the BD address changes as well, on both devices. On the Z3 however, sometimes the BD address will change while broadcasting a given RPI.

This behaviour is expected from GAEN as well.

@cgrigis
Copy link
Collaborator

cgrigis commented Oct 29, 2020

To ensure compatibility with the app using GAEN, we need an end-to-end with mixed-phones:

  • 2 phones use the "standard" calibration app
  • 2 phones use the non-GAEN calibration app
  • expose them all together
  • declare one of them positive
  • the next day, ensure all the other ones report exposure

@cgrigis
Copy link
Collaborator

cgrigis commented Dec 4, 2020

These tests have been performed as part of #23, and now pass after a fix in the backend.

@cgrigis cgrigis closed this as completed Dec 14, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants