mirror of
https://github.com/status-im/status-go.git
synced 2025-01-10 06:36:32 +00:00
96 lines
3.5 KiB
Markdown
96 lines
3.5 KiB
Markdown
# Status bindings for go-ethereum
|
|
|
|
[![TravisCI Builds](https://img.shields.io/badge/TravisCI-URL-yellowgreen.svg?link=https://travis-ci.org/status-im/status-go)](https://travis-ci.org/status-im/status-go)
|
|
[![GoDoc](https://godoc.org/github.com/status-im/status-go?status.svg)](https://godoc.org/github.com/status-im/status-go) [![Master Build Status](https://img.shields.io/travis/status-im/status-go/master.svg?label=build/master)](https://github.com/status-im/status-go/tree/master) [![Develop Build Status](https://img.shields.io/travis/status-im/status-go/develop.svg?label=build/develop)](https://github.com/status-im/status-go/tree/develop)
|
|
|
|
# Docs
|
|
|
|
- [How To Build](https://wiki.status.im/Building_status-go)
|
|
- [Notes on Bindings](https://wiki.status.im/Status-go_Binding_notes)
|
|
- [How To Contribute](CONTRIBUTING.md)
|
|
|
|
# Intro
|
|
|
|
status-go is an underlying part of [Status](https://status.im/) - a browser, messenger, and gateway to a decentralized world.
|
|
|
|
It's written in Go and requires Go 1.8 or above.
|
|
|
|
It uses Makefile to do most common actions. See `make help` output for available commands.
|
|
|
|
status-go uses [go-ethereum](https://github.com/ethereum/go-ethereum) with [some patches applied](./_assets/patches/geth) in it, located under [`vendor/`](./vendor/github.com/ethereum/go-ethereum) directory. See [geth patches README](./_assets/patches/geth/README.md) for more info.
|
|
|
|
# Build
|
|
|
|
There are two main modes status-go can be built:
|
|
|
|
- standalone server
|
|
- library to link for Android or iOS
|
|
|
|
Use following Makefile commands:
|
|
|
|
- `make statusgo` (builds binary into `build/bin/statusd`)
|
|
- `make statusgo-android` (builds .aar file `build/android-16/aar`)
|
|
- `make statusgo-ios` and `make statusgo-ios-simulator` (builds iOS related artifacts in `build/os-9.3/framework`)
|
|
|
|
In order to build and use `status-go` directly from `status-react`, follow the instructions in https://wiki.status.im/Building_Status, under the '**Building Status with the checked-out version of status-go**' section.
|
|
|
|
# Debugging
|
|
|
|
In order to see the log files while debugging on an Android device, do the following:
|
|
|
|
- Ensure that the app can write to disk by granting it file permissions. For that, you can for instance set your avatar from a file on disk.
|
|
- Connect a USB cable to your phone and make sure you can use `adb`.
|
|
|
|
Run
|
|
|
|
```shell
|
|
adb shell tail -f sdcard/Download/geth.log
|
|
```
|
|
|
|
## IDE Debugging
|
|
|
|
If you're using Visual Studio Code, you can rename the `.vscode/launch.example.json` file to `launch.json` so that you can run the app with the debugger attached.
|
|
|
|
# Testing
|
|
|
|
To setup accounts passphrase you need to setup an environment variable: `export ACCOUNT_PASSWORD="secret_pass_phrase"`.
|
|
|
|
Make sure the dependencies are installed first by running:
|
|
|
|
```shell
|
|
make lint-install
|
|
make mock-install
|
|
```
|
|
|
|
To test fully statusgo, use:
|
|
|
|
```shell
|
|
make ci
|
|
```
|
|
|
|
To test statusgo using a given network by name, use:
|
|
|
|
```shell
|
|
make ci networkid=rinkeby
|
|
```
|
|
|
|
To test statusgo using a given network by number ID, use:
|
|
|
|
```shell
|
|
make ci networkid=3
|
|
```
|
|
|
|
If you have problems running tests on public network we suggest reading [e2e guide](t/e2e/README.md).
|
|
|
|
If you want to launch specific test, for instance `RPCSendTransactions`, use the following command:
|
|
|
|
```shell
|
|
go test -v ./api/ -testify.m ^RPCSendTransaction$
|
|
```
|
|
|
|
Note `-testify.m` as [testify/suite](https://godoc.org/github.com/stretchr/testify/suite) is used to group individual tests.
|
|
|
|
# Licence
|
|
|
|
[Mozilla Public License 2.0](https://github.com/status-im/status-go/blob/develop/LICENSE.md)
|