Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/google/CTAP2-test-tool
Test tool for CTAP2 authenticators
https://github.com/google/CTAP2-test-tool
cpp ctap2 fido2 security security-key
Last synced: about 2 months ago
JSON representation
Test tool for CTAP2 authenticators
- Host: GitHub
- URL: https://github.com/google/CTAP2-test-tool
- Owner: google
- License: apache-2.0
- Created: 2020-05-07T07:13:19.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2023-07-11T11:38:30.000Z (over 1 year ago)
- Last Synced: 2024-08-05T17:25:42.382Z (5 months ago)
- Topics: cpp, ctap2, fido2, security, security-key
- Language: C++
- Homepage:
- Size: 670 KB
- Stars: 57
- Watchers: 29
- Forks: 25
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-hacking-lists - google/CTAP2-test-tool - Test tool for CTAP2 authenticators (C++)
README
#
## CTAP2 test tool
The test suite intents to make it easier for developers to find bugs in their
CTAP2 implementation. It supports CTAP 2.0 only, see
[supported features](#supported-features).### Disclaimer
Those tests reflect the author's interpretation of the specification. It is not
to be confused with certification by the FIDO Alliance. Please check the
[FIDO Alliance web page](https://fidoalliance.org/) for more information.### How to install
The build system is bazel. Please make sure you have all dependencies installed.
Example command for Ubuntu:```shell
apt-get install bazel libudev-dev autotools-dev autoconf automake libtool
```On your first run, the build system will fetch all other necessary libraries
using git. The tool is tested on Linux and MacOS with GCC 9 and higher.### How to run
:warning: This tool will irreversibly delete all credentials on your device.
Running the tool without comments lists all avaiable devices. Select the device
you want to test by passing `--token_path`. For Unix, if only one CTAP2
compatible device is plugged in, you can simply run:```shell
./run.sh
```For more control, try i.e.:
```shell
bazel run //:fido2_conformance
bazel run //:fido2_conformance -- --token_path=/dev/hidraw0
```:warning: Please do not plug in other security keys with the same product ID, or
the tool might contact the wrong device during testing.While running the test tool, you will be prompted to touch or replug your
security key multiple times, to test various features.### Supported features
At the moment, we only support USB HID as a transport. We test the commands from
[CTAP 2.0](https://fidoalliance.org/specs/fido-v2.0-ps-20190130/fido-client-to-authenticator-protocol-v2.0-ps-20190130.pdf).
The security key must support resident keys and user presence. Also, security
keys with displays are untested so far.#### Fuzzing
In addition to the CTAP2 specification conformance test, we provide a proof-of-concept
fuzzing tool. Please check [fuzzing.md](docs/fuzzing.md) for a detailed guide.### Results
For more information on checking or contributing test results, please check
[results.md](docs/results.md).### Contributing
If we didn't already test your security key or you have an updated version,
please create a pull request with your result file!If you want to contribute code, please check
[contributing.md](docs/contributing.md).