mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-01-19 05:45:21 +01:00
210 lines
5.3 KiB
Markdown
210 lines
5.3 KiB
Markdown
Makefile
|
|
========
|
|
|
|
To build, verify, and install `lnd` from source, use the following
|
|
commands:
|
|
```shell
|
|
⛰ make
|
|
⛰ make check
|
|
⛰ make install
|
|
```
|
|
|
|
The command `make check` requires `bitcoind` (almost any version should do) to
|
|
be available in the system's `$PATH` variable. Otherwise some of the tests will
|
|
fail.
|
|
|
|
Developers
|
|
==========
|
|
|
|
This document specifies all commands available from `lnd`'s `Makefile`.
|
|
The commands included handle:
|
|
- Installation of all go-related dependencies.
|
|
- Compilation and installation of `lnd` and `lncli`.
|
|
- Compilation and installation of `btcd` and `btcctl`.
|
|
- Running unit and integration suites.
|
|
- Testing, debugging, and flake hunting.
|
|
- Formatting and linting.
|
|
|
|
Commands
|
|
========
|
|
|
|
- [`all`](#scratch)
|
|
- [`btcd`](#btcd)
|
|
- [`build`](#build)
|
|
- [`check`](#check)
|
|
- [`clean`](#clean)
|
|
- [`default`](#default)
|
|
- [`dep`](#dep)
|
|
- [`flake-unit`](#flake-unit)
|
|
- [`flakehunter`](#flakehunter)
|
|
- [`fmt`](#fmt)
|
|
- [`install`](#install)
|
|
- [`itest`](#itest)
|
|
- [`lint`](#lint)
|
|
- [`list`](#list)
|
|
- [`rpc`](#rpc)
|
|
- [`scratch`](#scratch)
|
|
- [`travis`](#travis)
|
|
- [`unit`](#unit)
|
|
- [`unit-cover`](#unit-cover)
|
|
- [`unit-race`](#unit-race)
|
|
|
|
`all`
|
|
-----
|
|
Compiles, tests, and installs `lnd` and `lncli`. Equivalent to
|
|
[`scratch`](#scratch) [`check`](#check) [`install`](#install).
|
|
|
|
`btcd`
|
|
------
|
|
Ensures that the [`github.com/btcsuite/btcd`][btcd] repository is checked out
|
|
locally. Lastly, installs the version of
|
|
[`github.com/btcsuite/btcd`][btcd] specified in `Gopkg.toml`
|
|
|
|
`build`
|
|
-------
|
|
Compiles the current source and vendor trees, creating `./lnd` and
|
|
`./lncli`.
|
|
|
|
`check`
|
|
-------
|
|
Installs the version of [`github.com/btcsuite/btcd`][btcd] specified
|
|
in `Gopkg.toml`, then runs the unit tests followed by the integration
|
|
tests.
|
|
|
|
Related: [`unit`](#unit) [`itest`](#itest)
|
|
|
|
`clean`
|
|
-------
|
|
Removes compiled versions of both `./lnd` and `./lncli`, and removes the
|
|
`vendor` tree.
|
|
|
|
`default`
|
|
---------
|
|
Alias for [`scratch`](#scratch).
|
|
|
|
`flake-unit`
|
|
------------
|
|
Runs the unit test endlessly until a failure is detected.
|
|
|
|
Arguments:
|
|
- `pkg=<package>`
|
|
- `case=<testcase>`
|
|
- `timeout=<timeout>`
|
|
|
|
Related: [`unit`](#unit)
|
|
|
|
`flakehunter`
|
|
-------------
|
|
Runs the itegration test suite endlessly until a failure is detected.
|
|
|
|
Arguments:
|
|
- `icase=<itestcase>`
|
|
- `timeout=<timeout>`
|
|
|
|
Related: [`itest`](#itest)
|
|
|
|
`fmt`
|
|
-----
|
|
Runs `go fmt` on the entire project.
|
|
|
|
`install`
|
|
---------
|
|
Copies the compiled `lnd` and `lncli` binaries into `$GOPATH/bin`.
|
|
|
|
`itest`
|
|
-------
|
|
Installs the version of [`github.com/btcsuite/btcd`][btcd] specified in
|
|
`Gopkg.toml`, builds the `./lnd` and `./lncli` binaries, then runs the
|
|
integration test suite.
|
|
|
|
Arguments:
|
|
- `icase=<itestcase>` (the snake_case version of the testcase name field in the testCases slice (i.e. sweep_coins), not the test func name)
|
|
- `timeout=<timeout>`
|
|
|
|
`itest-parallel`
|
|
------
|
|
Does the same as `itest` but splits the total set of tests into
|
|
`NUM_ITEST_TRANCHES` tranches (currently set to 6 by default, can be overwritten
|
|
by setting `tranches=Y`) and runs them in parallel.
|
|
|
|
Arguments:
|
|
- `icase=<itestcase>`: The snake_case version of the testcase name field in the
|
|
testCases slice (i.e. `sweep_coins`, not the test func name) or any regular
|
|
expression describing a set of tests.
|
|
- `timeout=<timeout>`
|
|
- `tranches=<number_of_tranches>`: The number of parts/tranches to split the
|
|
total set of tests into.
|
|
- `parallel=<number_of_threads>`: The number of threads to run in parallel. Must
|
|
be greater or equal to `tranches`, otherwise undefined behavior is expected.
|
|
|
|
`flakehunter-parallel`
|
|
------
|
|
Runs the test specified by `icase` simultaneously `parallel` (default=6) times
|
|
until an error occurs. Useful for hunting flakes.
|
|
|
|
Example:
|
|
```shell
|
|
⛰ make flakehunter-parallel icase='(data_loss_protection|channel_backup)' backend=neutrino
|
|
```
|
|
|
|
`lint`
|
|
------
|
|
Ensures that [`gopkg.in/alecthomas/gometalinter.v1`][gometalinter] is
|
|
installed, then lints the project.
|
|
|
|
`list`
|
|
------
|
|
Lists all known make targets.
|
|
|
|
`rpc`
|
|
-----
|
|
Compiles the `lnrpc` proto files.
|
|
|
|
`scratch`
|
|
---------
|
|
Compiles all dependencies and builds the `./lnd` and `./lncli` binaries.
|
|
Equivalent to [`lint`](#lint) [`btcd`](#btcd)
|
|
[`unit-race`](#unit-race).
|
|
|
|
`unit`
|
|
------
|
|
Runs the unit test suite. By default, this will run all known unit tests.
|
|
|
|
Arguments:
|
|
- `pkg=<package>`
|
|
- `case=<testcase>`
|
|
- `timeout=<timeout>`
|
|
- `log="stdlog[ <log-level>]"` prints logs to stdout
|
|
- `<log-level>` can be `info` (default), `debug`, `trace`, `warn`, `error`, `critical`, or `off`
|
|
|
|
`unit-cover`
|
|
------------
|
|
Runs the unit test suite with test coverage, compiling the statisitics in
|
|
`profile.cov`.
|
|
|
|
Arguments:
|
|
- `pkg=<package>`
|
|
- `case=<testcase>`
|
|
- `timeout=<timeout>`
|
|
- `log="stdlog[ <log-level>]"` prints logs to stdout
|
|
- `<log-level>` can be `info` (default), `debug`, `trace`, `warn`, `error`, `critical`, or `off`
|
|
|
|
Related: [`unit`](#unit)
|
|
|
|
`unit-race`
|
|
-----------
|
|
Runs the unit test suite with go's race detector.
|
|
|
|
Arguments:
|
|
- `pkg=<package>`
|
|
- `case=<testcase>`
|
|
- `timeout=<timeout>`
|
|
- `log="stdlog[ <log-level>]"` prints logs to stdout
|
|
- `<log-level>` can be `info` (default), `debug`, `trace`, `warn`, `error`, `critical`, or `off`
|
|
|
|
Related: [`unit`](#unit)
|
|
|
|
[btcd]: https://github.com/btcsuite/btcd (github.com/btcsuite/btcd")
|
|
[gometalinter]: https://gopkg.in/alecthomas/gometalinter.v1 (gopkg.in/alecthomas/gometalinter.v1)
|
|
[goveralls]: https://github.com/mattn/goveralls (github.com/mattn/goveralls)
|