2018-01-25 14:08:43 +01:00
# Dependency Management
2018-06-12 18:50:25 +02:00
2018-01-25 14:08:43 +01:00
[`dep` ](https://github.com/golang/dep ) is a tool of choice when it comes to dependency management.
2018-06-12 18:50:25 +02:00
## How we use `dep`
2018-01-25 14:08:43 +01:00
1. Transitive dependencies of `go-ethereum` . The most important thing for us is
2018-02-14 20:44:27 +03:00
to be in-sync there. We want to reduce the regression scope.
2018-01-25 14:08:43 +01:00
Hence, we pin down all the dependencies of `go-ethereum` with SHAs in `Gopkg.toml` when
importing a new version of upstream. (This is considered a bad practice for
2018-06-12 18:50:25 +02:00
`dep` but we are willing to take the risk to keep consistency with the upstream).
1. Exclusive `status-go` dependencies. The policy there is to keep them as
2018-01-25 14:08:43 +01:00
fresh as possible. Hence, no constraints for them in the `toml` file.
## Installing `dep`
`go get -u github.com/golang/dep/cmd/dep`
## Docs (worth reading)
2018-06-12 18:50:25 +02:00
1. [README ](https://github.com/golang/dep/blob/master/README.md )
1. [F.A.Q. ](https://github.com/golang/dep/blob/master/docs/FAQ.md )
2018-01-25 14:08:43 +01:00
## Checking-out all dependencies
`dep ensure` - download all the dependencies based on `Gopkg.lock` .
2018-02-14 20:44:27 +03:00
`make dep-ensure` - ensure all patches are applied, too. ** (Recommended)**
2018-01-25 14:08:43 +01:00
`Gopkg.lock` is kept inact if it is in-sync with `Gopkg.toml` . If the `toml`
file is changed, `dep ensure` will re-generate `Gopkg.lock` as well.
## Adding a new Dependency
2018-06-12 18:50:25 +02:00
2018-01-25 14:08:43 +01:00
(see [Adding a new dependency ](https://github.com/golang/dep#adding-a-dependency ))
2018-06-12 18:50:25 +02:00
1. `$ dep ensure -add github.com/foo/bar`
1. Commit changes.
2018-01-25 14:08:43 +01:00
## Updating a dependency
2018-06-12 18:50:25 +02:00
2018-01-25 14:08:43 +01:00
(see: [Changing a Dependency ](https://github.com/golang/dep#changing-dependencies ))
2018-06-12 18:50:25 +02:00
2018-01-25 14:08:43 +01:00
1. Update constraint in the `Gopkg.toml` file if needed.
2. Run `dep ensure -update github.com/foo/bar`
3. Commit changes.
## Updating all dependencies
`dep ensure -update`
## Updating `Geth`
2018-02-20 13:04:25 -05:00
Use the `update-geth` make target. For major releases, provide the GETH_BRANCH parameter. (e.g. `make update-geth GETH_BRANCH=release/1.9` ). If there were any changes made, they will be committed while running this target.
2018-01-25 14:08:43 +01:00
2018-06-12 18:50:25 +02:00
## Committing changes
2018-01-25 14:08:43 +01:00
Make sure that you don't commit unnecessary changes to `Gopkg.toml` and
`Gopkg.lock` .
## Common issues
1. Relative imports and "Could not introduce package, as its subpackage does not contain usable Go code". See [this comment ](https://github.com/golang/dep/issues/899#issuecomment-317904001 ) for more information.