Skip to content

Ethereum wallet application for Ledger Blue and Nano S

License

Notifications You must be signed in to change notification settings

fcipollone-ledger/app-ethereum

 
 

Repository files navigation

app-ethereum

Ethereum wallet application framework for Nano S and Nano X. Ledger Blue is not maintained anymore, but the app can still be compiled for this target using the branch blue-final-release.

This app follows the specification available in the doc/ folder.

To compile it and load it on a device, please check out our developer portal.

Plugins

This app support external plugins. More info in doc/ethapp_plugin.asc. If you wish to have a look at an existing plugin, feel free to check out the Boilerplate plugin.

Testing

Testing is done via the open-source framework zemu.

Running tests

First install yarn. Open tests/build_local_test_elfs.sh and add your BOLOS SDKs path to NANOS_SDK and NANOX_SDK. This helper script will build the applications required by the test suite and move them at the right place.

cd tests
./build_local_test_elfs.sh

Then you can install the project by simply running:

cd ..
make test

This will run make install_tests and make run_tests

To run a specific tests (here the send test):

cd tests
jest --runInBand --detectOpenHandles src/send.test.js

Make sure you're in the tests folder before running jest or yarn test.

Adding tests

Zemu

To add tests, copy one of the already existing test files in tests/src/. You then need to adapt the buffer and tx variables to adapt to the APDU you wish to send.

  • Adapt the expected screen flow. Please create a folder under tests/snapshots with the name of the test you're performing.
  • Then adapt the ORIGINAL_SNAPSHOT_PATH_PREFIX with the name of the folder you just created.
  • To create the snapshots, modify the SNAPSHOT_PATH_PREFIX and set it to be equal to ORIGINAL_SNAPSHOT_PATH_PREFIX.
  • Run the tests once, this will create all the snapshots in the folder you created.
  • Put back your SNAPSHOT_PATH_PREFIX to snapshots/tmp/.

Finally make sure you adapt the expected signature!

Update binaries

Don't forget to update the binaries in the test folder. To do so, compile with those environement variables:

make DEBUG=1 ALLOW_DATA=1

Then copy the binary to the tests/elfs folder (in this case, compiled with SDK for nanoS):

cp bin/app.elf tests/elfs/ethereum_nanos.elf

Repeat the operation for a binary compiled with nanoX SDK and change for ethereum_nanox.elf.

About

Ethereum wallet application for Ledger Blue and Nano S

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C 89.4%
  • JavaScript 6.9%
  • Makefile 3.5%
  • Shell 0.2%