## Introduction In addition to low-level subsystems, the suite tests the overall operation of MMGen Wallet’s commands by running them interactively as a user would. Thus the test suite is useful not only for ensuring the MMGen Wallet system is correctly installed and working on your platform but also for demonstrating how it works. BTC-only testing requires installation of Bitcoin Core and pycoin only, while altcoin testing requires additional helper programs and libraries, installation instructions for which are provided below. Non-standard RPC ports and data directories are always used, so there’s no need to stop any running nodes. On Linux/x86\_64 with a reasonably fast processor, the full suite should run in under 30 minutes when invoked with the `-F` option. Execution times on other platforms may be much slower. ## Quick start ### LXC container setup (if applicable) The test suite requires the `/dev/loopX` devices to exist and be enabled. If you’re running in an LXC container, note that only privileged containers allow loop devices. You may enable them in the config file as follows: ```text lxc.cgroup2.devices.allow = b 7:0 rwm # /dev/loop0 lxc.cgroup2.devices.allow = b 7:1 rwm # /dev/loop1 lxc.cgroup2.devices.allow = b 7:2 rwm # /dev/loop2 ``` Every time the container is started, you may need to create the files afresh: ```text # mknod /dev/loop0 b 7 0 # mknod /dev/loop1 b 7 1 # mknod /dev/loop2 b 7 2 ``` ### BTC-only testing Install the Bitcoin Core daemon [(source)][sd] [(binaries)][bd]. Install Pycoin: ```text # online install: $ python3 -m pip install pycoin # offline install: $ python3 -m pip download pycoin # online $ python3 -m pip install --no-build-isolation pycoin-*.tar.gz # offline ``` CD to the MMGen Wallet repository root and build the secp256k1 extension module in place: ```text $ cd path/to/mmgen/repo $ python3 setup.py build_ext --inplace ``` Run the following if upgrading from a previous version of MMGen: ```text $ test/cmdtest.py clean ``` Run the test suite in fast mode, skipping altcoin tests (fast mode skips non-essential tests and uses fewer rounds for repeated tests): ```text $ test/test-release.sh -FA ``` ### Complete testing (BTC plus all supported altcoins) Complete the BTC-only installation steps above, without running the test. Make sure the [Bitcoin Cash Node][cnd], [Litecoin][ld] and [Monero][md] daemons are installed on your system. Install [Reth, Geth, Parity and the ETH Python requirements][rg], optionally the [Solidity compiler][sc], and [the XMR Python requirements][xr] as described on the Altcoin-and-Forkcoin-Support page. For Ethereum testing in fast mode, Reth may be omitted. In addition, you must install the following helper programs and libraries (MSYS2 users can omit Zcash-Mini and leave out `sudo` in commands): #### SSH daemon setup (MSYS2 only) The XMR test sets up a local SOCKS proxy to test transaction relaying. This requires the SSH daemon to be set up and running. On MSYS2 systems, SSHD is not configured by default, but it may be easily set up with the following steps: Open PowerShell as administrator, and at the DOS prompt, execute: ```text system32> net user administrator /active:yes system32> C:\\msys64\usr\bin\bash.exe --login ``` Now, at the MSYS2 prompt, cd to the MMGen Wallet repository root and run the setup script: ```text $ scripts/msys2-sshd-setup.sh ``` The daemon should now start automatically every time the system is booted. It may also be started and stopped manually at the DOS or MSYS2 prompt as follows (PowerShell must be running with admin privileges): ```text # net start msys2_sshd # net stop msys2_sshd ``` #### Install Monero-Python ```text $ python3 -m pip install ipaddress varint $ python3 -m pip install --no-deps monero ``` #### Install Eth-Keys (non-MSYS2 systems) This pulls in a lot of dependencies. If you prefer, you may install the openethereum ‘ethkey’ utility instead, if it’s available on your platform. ```text $ python3 -m pip install eth-keys ``` #### Install OpenEthereum Ethkey (alternative to eth-keys) Install this on MSYS2 or if ‘eth-keys’ is unavailable on your platform. Do not confuse this with the Reth ‘ethkey’ utility, which is entirely different. On Arch Linux and ArchLinuxArm systems, ‘ethkey’ is installed as follows: ```text $ pacman -S openethereum ``` For 64-bit Windows (MSYS2), Linux and macOS systems, ‘ethkey’ can be found in the zip archives distributed with [this release][oz]. #### Install Vanitygen PlusPlus (a fork of Vanitygen Plus) ```text $ git clone https://github.com/10gic/vanitygen-plusplus $ cd vanitygen-plusplus $ git checkout -b vanitygen-plus e7858035d092 # rewind to fork commit ``` Edit the Makefile, changing `-lpcre` to `-lpcre2-posix` on the second line. ```text $ make keyconv # ‘mingw32-make.exe keyconv’ for MSYS2 $ sudo install --strip keyconv /usr/local/bin # Linux, macOS $ install --strip keyconv.exe /usr/local/bin # MSYS2 $ cd .. ``` #### Install Zcash-Mini ```text $ sudo apt-get install golang # skip this if Go is already installed $ git clone https://github.com/FiloSottile/zcash-mini $ cd zcash-mini $ sed -e "s@github.com/FiloSottile/@@" -i main.go $ sed -e "s@github.com/FiloSottile/@@" -i zcash/address.go $ sed -e "s@github.com/btcsuite@zcash-mini@" -i zcash/address.go $ sed -e "s@golang.org/x@zcash-mini@" -i zcash/address.go $ mv vendor/github.com/btcsuite/btcutil . $ mv vendor/golang.org/x/crypto . $ go mod init zcash-mini $ go build -mod=mod $ sudo install --strip ./zcash-mini /usr/local/bin $ cd .. ``` #### Monero note The Monero test (`test/test-release.sh xmr`) creates a private network and mines coins, so is therefore non-deterministic and prone to random failures. If you experience such a failure, just restart the test. ### Run the tests Now you may run the test suite in fast mode for all coins: ```text $ test/test-release.sh -F ``` ## Overview of the individual tests `test/test-release.sh` is just a simple shell script that invokes the test scripts with various options and arguments to ensure complete coverage of MMGen Wallet’s functionality. Launch the script with the `-t` option to view the invocations without running them. The test scripts themselves are all located in the `test/` directory and bear the `.py` extension. They may be run individually if desired. Options and arguments required by the tests are described in detail on their help screens. High-level testing of the MMGen Wallet system is performed by `test/cmdtest.py`, which uses the `pexpect` library to simulate interactive operation of MMGen Wallet’s user commands. Running `test/cmdtest.py` with the `-e` option will display the commands’ output on the screen as they’re being run. | Test | What it tests | |:----------------------|:-----------------------------------------------------| | `test/colortest.py` | terminfo parsing; terminal colors | | `test/gentest.py` | key/address generation - profiling and data validity | | `test/hashfunc.py` | native SHA2 and Keccak implementations | | `test/objtest.py` | MMGen data objects - creation and error handling | | `test/objattrtest.py` | MMGen data objects - immutable attributes | | `test/scrambletest.py`| HMAC scramble strings used in key/password derivation| | `test/cmdtest.py` | overall operation of MMGen Wallet commands | | `test/tooltest.py` | the `mmgen-tool` utility - overall operation | | `test/tooltest2.py` | the `mmgen-tool` utility - data validity | | `test/modtest.py` | low-level subsystems (unit tests) | | `test/daemontest.py` | low-level subsystems requiring daemons | [sd]: Install-Bitcoind-from-Source-on-Linux.md [bd]: Install-Bitcoind.md [md]: https://getmonero.org/downloads/#linux [ad]: https://download.bitcoinabc.org/ [cnd]: https://bitcoincashnode.org/ [ld]: https://download.litecoin.org/litecoin-0.17.1/ [rg]: Altcoin-and-Forkcoin-Support.md#a_geth [sc]: Altcoin-and-Forkcoin-Support.md#a_dt [xr]: Altcoin-and-Forkcoin-Support.md#a_xmr_req [oz]: https://github.com/openethereum/openethereum/releases/tag/v3.1.0