From f309a6d304257c5650c6d589fa1b79fafade6835 Mon Sep 17 00:00:00 2001 From: Jernej Kos Date: Fri, 12 Jun 2020 10:21:15 +0200 Subject: [PATCH] docs: Refactor setup instructions, add single validator node setup --- .changelog/3006.doc.md | 1 + README.md | 367 +------------------- docs/index.md | 14 + docs/setup/building.md | 66 ++++ docs/setup/oasis-net-runner.md | 76 ++++ docs/setup/prerequisites.md | 208 +++++++++++ docs/setup/running-tests.md | 51 +++ docs/setup/single-validator-node-network.md | 139 ++++++++ 8 files changed, 561 insertions(+), 361 deletions(-) create mode 100644 .changelog/3006.doc.md create mode 100644 docs/setup/building.md create mode 100644 docs/setup/oasis-net-runner.md create mode 100644 docs/setup/prerequisites.md create mode 100644 docs/setup/running-tests.md create mode 100644 docs/setup/single-validator-node-network.md diff --git a/.changelog/3006.doc.md b/.changelog/3006.doc.md new file mode 100644 index 00000000000..a3d64687def --- /dev/null +++ b/.changelog/3006.doc.md @@ -0,0 +1 @@ +docs: Refactor setup instructions, add single validator node setup diff --git a/README.md b/README.md index 0258c30a5bc..fd75c9af092 100644 --- a/README.md +++ b/README.md @@ -51,372 +51,17 @@ Read our [Security](SECURITY.md) document. See our [developer documentation index](docs/index.md). -## Developing and building the system +## Developing and Building the System -Prerequisites: - -* Linux (if you are not on Linux, you will need to either set up a VM with the - proper environment or, if Docker is available for your platform, use the - provided Docker image which does this for you, - [see below](#using-the-development-docker-image)). - -* System packages: - * [Bubblewrap] (at least version 0.3.3). - * [GCC] (including C++ subpackage). - * [Protobuf] compiler. - * [GNU Make]. - * [CMake]. - * [OpenSSL] development package. - * [libseccomp] development package. - - On Fedora 29+, you can install all the above with: - - - ``` - sudo dnf install bubblewrap gcc gcc-c++ protobuf-compiler make cmake openssl-devel libseccomp-devel - ``` - - - On Ubuntu 18.10+ (18.04 LTS provides overly-old `bubblewrap`), you can install - all the above with: - - ``` - sudo apt install bubblewrap gcc g++ protobuf-compiler make cmake libssl-dev libseccomp-dev - ``` - -* [Go] (at least version 1.14.3). - - If your distribution provides a new-enough version of Go, just use that. - - Otherwise: - * install the Go version provided by your distribution, - * [ensure `$GOPATH/bin` is in your `PATH`]( - https://tip.golang.org/doc/code.html#GOPATH), - * [install the desired version of Go]( - https://golang.org/doc/install#extra_versions), e.g. 1.14.3, with: - - ``` - go get golang.org/dl/go1.14.3 - go1.14.3 download - ``` - - * instruct the build system to use this particular version of Go by setting - the `OASIS_GO` environment variable in your `~/.bashrc`: - - ``` - export OASIS_GO=go1.14.3 - ``` - -* [Rust]. - - We follow [Rust upstream's recommendation][rust-upstream-rustup] on using - [rustup] to install and manage Rust versions. - - _NOTE: rustup cannot be installed alongside a distribution packaged Rust - version. You will need to remove it (if it's present) before you can start - using rustup._ - - Install it by running: - - ``` - curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh - ``` - - _NOTE: If you want to avoid directly executing a shell script fetched the - internet, you can also [download `rustup-init` executable for your platform] - and run it manually._ - - This will run `rustup-init` which will download and install the latest stable - version of Rust on your system. - -* [Fortanix Rust EDP] utilities. - - Make sure a _nightly_ version of the Rust toolchain is installed: - - ``` - rustup install nightly - ``` - - Then install the Fortanix Rust EDP utilities by running: - - ``` - cargo +nightly install --version 0.4.0 fortanix-sgx-tools - cargo +nightly install --version 0.8.2 sgxs-tools - ``` - - _NOTE: These utilities must be compiled with a nightly version of the Rust - toolchain since they use the `#![feature]` macro._ - -* Oasis Core's Rust toolchain version with Fortanix SGX target. - - The version of the Rust toolchain we use in Oasis Core is specified in the - [rust-toolchain] file. - - The rustup-installed versions of `cargo`, `rustc` and other tools will - [automatically detect this file and use the appropriate version of the Rust - toolchain][rust-toolchain-precedence] when invoked from the Oasis core git - checkout directory. - - To install the appropriate version of the Rust toolchain, make sure you are - in an Oasis Core git checkout directory and run: - - ``` - rustup show - ``` - - This will automatically install the appropriate Rust toolchain (if not - present) and output something similar to: - - ``` - ... - - active toolchain - ---------------- - - nightly-2020-06-09-x86_64-unknown-linux-gnu (overridden by '/oasis-core/rust-toolchain') - rustc 1.46.0-nightly (fd4b177aa 2020-06-08) - ``` - - Then add the Fortanix SGX Rust target to this version of the Rust toolchain by - running: - - ``` - rustup target add x86_64-fortanix-unknown-sgx - ``` - -* (**OPTIONAL**) [protoc-gen-go]. - - Download and install it with: - - ``` - GO111MODULE=on ${OASIS_GO:-go} get google.golang.org/protobuf/cmd/protoc-gen-go@v1.21.0 - ``` - - _NOTE: If you didn't/can't add `$GOPATH/bin` to your `PATH`, you can install - `protoc-gen-go` to `/usr/local/bin` (which is in `$PATH`) with:_ - - - ``` - sudo GOBIN=/usr/local/bin GO111MODULE=on ${OASIS_GO:-go} install google.golang.org/protobuf/cmd/protoc-gen-go@v1.21.0 - ``` - - - _NOTE: The repository has the most up-to-date files generated by protoc-gen-go - committed for convenience. Installing protoc-gen-go is only required if you - are a developer making changes to protobuf definitions used by Go._ - -In the following instructions, the top-level directory is the directory -where the code has been checked out. - -[Bubblewrap]: https://github.com/projectatomic/bubblewrap -[GCC]: http://gcc.gnu.org/ -[Protobuf]: https://github.com/protocolbuffers/protobuf -[GNU Make]: https://www.gnu.org/software/make/ -[CMake]: https://cmake.org/ -[OpenSSL]: https://www.openssl.org/ -[libseccomp]: https://github.com/seccomp/libseccomp -[Go]: https://golang.org -[rustup]: https://rustup.rs/ -[rust-upstream-rustup]: https://www.rust-lang.org/tools/install -[download `rustup-init` executable for your platform]: - https://github.com/rust-lang/rustup#other-installation-methods -[Rust]: https://www.rust-lang.org/ -[rust-toolchain]: rust-toolchain -[rust-toolchain-precedence]: - https://github.com/rust-lang/rustup/blob/master/README.md#override-precedence -[Fortanix Rust EDP]: https://edp.fortanix.com -[protoc-gen-go]: https://github.com/golang/protobuf - -### Using the development Docker image - -If for some reason you don't want or can't install the specified prerequisites -on the host system, you can use our development Docker image. This requires that -you have a [recent version of Docker installed]( -https://docs.docker.com/install/). - -Oasis development environment with all the dependencies preinstalled is -available in the `oasisprotocol/oasis-core-dev:master` image. -To run a container, do the following in the top-level directory: - -```bash -make docker-shell -``` - -If you are curious, this target will internally run the following command: - -``` -docker run -t -i \ - --name oasis-core \ - --security-opt apparmor:unconfined \ - --security-opt seccomp=unconfined \ - -v $(pwd):/code \ - -w /code \ - oasisprotocol/oasis-core-dev:master \ - bash -``` - -All the following commands can then be used from inside the container. See the -Docker documentation for detailed instructions on working with Docker -containers. - -## Unsafe non-SGX environment: Building and Running an Oasis node - -To build everything required for running an Oasis node locally, simply execute -in the top-level directory: - -``` -export OASIS_UNSAFE_SKIP_AVR_VERIFY="1" -export OASIS_UNSAFE_SKIP_KM_POLICY="1" -make -``` - -This will build all the required parts (build tools, Oasis node, runtime -libraries, runtime loader, key manager and test runtimes). The AVR and KM flags -are supported on production SGX systems only and these features must be disabled -in our environment. - -Next we specify how to run a simple network for development purposes. To start a -simple Oasis network as defined by [the default network fixture]( -go/oasis-net-runner/fixtures/default.go) running the `simple-keyvalue` test -runtime, do: - -``` -./go/oasis-net-runner/oasis-net-runner \ - --fixture.default.node.binary go/oasis-node/oasis-node \ - --fixture.default.runtime.binary target/default/debug/simple-keyvalue \ - --fixture.default.runtime.loader target/default/debug/oasis-core-runtime-loader \ - --fixture.default.keymanager.binary target/default/debug/simple-keymanager -``` - -Wait for the network to start, there should be messages about nodes being -started and at the end the following message should appear: - - -``` -level=info module=oasis/net-runner caller=oasis.go:319 ts=2019-10-03T10:47:30.776566482Z msg="network started" -level=info module=net-runner caller=root.go:145 ts=2019-10-03T10:47:30.77662061Z msg="client node socket available" path=/tmp/oasis-net-runner530668299/net-runner/network/client-0/internal.sock -``` - - -The `simple-keyvalue` runtime implements a key-value hash map in the enclave -and supports reading, writing, and fetching string values associated with the -given key. To learn how to create your own runtime, see the sources of the -example [here](tests/runtimes/simple-keyvalue). - -Finally, to test Oasis node, we will run a test client written specifically -for the `simple-keyvalue` runtime. The client sends a few keys with associated -values and fetches them back over RPC defined in the runtime's API. Execute the -client as follows (substituting the socket path from your log output) in a -different terminal: - -``` -./target/default/debug/simple-keyvalue-client \ - --runtime-id 8000000000000000000000000000000000000000000000000000000000000000 \ - --node-address unix:/tmp/oasis-net-runner530668299/net-runner/network/client-0/internal.sock -``` - -By default, Oasis node is configured with a 30-second epoch, so you may -initially need to wait for the first epoch to pass before the test client will -make any progress. For more information on writing your own client, see the -`simple-keyvalue` client sources [here](tests/clients/simple-keyvalue). - -## SGX environment: Building and Running an Oasis node - -Compilation procedure under SGX environment is similar to the non-SGX with -slightly different environmental variables set: - -``` -export OASIS_UNSAFE_SKIP_AVR_VERIFY="1" -export OASIS_UNSAFE_KM_POLICY_KEYS="1" -export OASIS_UNSAFE_ALLOW_DEBUG_ENCLAVES="1" -make -``` - -The AVR flag is there because we are running a node in a local development -environment and we will not do any attestation with Intel's remote servers. The -KM policy keys flag allows testing keys to be used while verifying the security -policy of the node. TEE hardware flag denotes the trusted execution environment -engine for running the Oasis node and the tests below. - -To run an Oasis node under SGX make sure: - -* Your hardware has SGX support. -* You either explicitly enabled SGX in BIOS or made a - `sgx_cap_enable_device()` system call, if SGX is in software controlled state. -* You installed Intel's SGX driver (check that `/dev/isgx` exists). -* You have the AESM daemon running. The easiest way is to just run it in a - Docker container by doing (this will keep the container running and it will - be automatically started on boot): - - ``` - docker run \ - --detach \ - --restart always \ - --device /dev/isgx \ - --volume /var/run/aesmd:/var/run/aesmd \ - --name aesmd \ - fortanix/aesmd - ``` - -Run `sgx-detect` (part of fortanix rust tools) to verify that everything is -configured correctly. - -Finally, to run an Oasis node under SGX follow the same steps as for non-SGX, -except the `oasis-net-runner` invocation: +See [a list of prerequisites] followed by [build instructions] and an example +of [setting up a local test network with a simple runtime]. -``` -./go/oasis-net-runner/oasis-net-runner \ - --fixture.default.tee_hardware intel-sgx \ - --fixture.default.node.binary go/oasis-node/oasis-node \ - --fixture.default.runtime.binary target/sgx/x86_64-fortanix-unknown-sgx/debug/simple-keyvalue.sgxs \ - --fixture.default.runtime.loader target/default/debug/oasis-core-runtime-loader \ - --fixture.default.keymanager.binary target/sgx/x86_64-fortanix-unknown-sgx/debug/simple-keymanager.sgxs -``` +[a list of prerequisites]: docs/setup/prerequisites.md +[build instructions]: docs/setup/building.md +[setting up a local test network with a simple runtime]: docs/setup/oasis-net-runner.md -## Running tests and benchmarks - -After you built everything, you can use the following commands to run tests. - -To run all unit tests: - -``` -make test-unit -``` - -To run end-to-end tests locally: - -``` -make test-e2e -``` - -To run all tests: - -``` -make test -``` - -To execute tests using SGX set the following environmental variable before -running the tests: - -``` -export OASIS_TEE_HARDWARE=intel-sgx -``` - -### Troubleshooting - -Check the console output for mentions of a path of the form -`/tmp/oasis-test-runnerXXXXXXXXX` (where each `X` is a digit). -That's the log directory. Start with coarsest-level debug output in -`console.log` files: - -``` -cat $(find /tmp/oasis-test-runnerXXXXXXXXX -name console.log) | less -``` - -For even more output, check the other `*.log` files. - ## Directories * `client`: Client library for talking with the runtimes. diff --git a/docs/index.md b/docs/index.md index a22a7874f80..686ccf27069 100644 --- a/docs/index.md +++ b/docs/index.md @@ -2,6 +2,20 @@ ![Architecture](images/oasis-core-high-level.svg) +## Development Setup + +Here are instructions on how to set up the local build environment, run the +tests and some examples on how to prepare test networks for local development of +Oasis Core components. + +* Build Environment Setup and Building + * [Prerequisites](setup/prerequisites.md) + * [Building](setup/building.md) +* Running Tests and Development Networks + * [Running Tests](setup/running-tests.md) + * [Local Network Runner With a Simple Runtime](setup/oasis-net-runner.md) + * [Single Validator Node Network](setup/single-validator-node-network.md) + ## High-Level Components At the highest level, Oasis Core is divided into two major layers: the diff --git a/docs/setup/building.md b/docs/setup/building.md new file mode 100644 index 00000000000..a8948635510 --- /dev/null +++ b/docs/setup/building.md @@ -0,0 +1,66 @@ +# Building + +This section contains a description of steps required to build Oasis Core. +Before proceeding, make sure to look at the [prerequisites] required for running +an Oasis Core environment. + +[prerequisites]: prerequisites.md + +## Unsafe Non-SGX Environment + +To build everything required for running an Oasis node locally, simply execute +the following in the top-level directory: + +``` +export OASIS_UNSAFE_SKIP_AVR_VERIFY="1" +export OASIS_UNSAFE_SKIP_KM_POLICY="1" +make +``` + +This will build all the required parts (build tools, Oasis node, runtime +libraries, runtime loader, key manager and test runtimes). The AVR and KM flags +are supported on production SGX systems only and these features must be disabled +in our environment. + +## SGX Environment + +Compilation procedure under SGX environment is similar to the non-SGX with +slightly different environmental variables set: + +``` +export OASIS_UNSAFE_SKIP_AVR_VERIFY="1" +export OASIS_UNSAFE_KM_POLICY_KEYS="1" +export OASIS_UNSAFE_ALLOW_DEBUG_ENCLAVES="1" +make +``` + +The AVR flag is there because we are running a node in a local development +environment and we will not do any attestation with Intel's remote servers. The +KM policy keys flag allows testing keys to be used while verifying the security +policy of the node. TEE hardware flag denotes the trusted execution environment +engine for running the Oasis node and the tests below. + +To run an Oasis node under SGX make sure: + +* Your hardware has SGX support. +* You either explicitly enabled SGX in BIOS or made a + `sgx_cap_enable_device()` system call, if SGX is in software controlled state. +* You installed [Intel's SGX driver] (check that `/dev/isgx` exists). +* You have the AESM daemon running. The easiest way is to just run it in a + Docker container by doing (this will keep the container running and it will + be automatically started on boot): + + ``` + docker run \ + --detach \ + --restart always \ + --device /dev/isgx \ + --volume /var/run/aesmd:/var/run/aesmd \ + --name aesmd \ + fortanix/aesmd + ``` + +Run `sgx-detect` (part of fortanix rust tools) to verify that everything is +configured correctly. + +[Intel's SGX driver]: https://github.com/intel/linux-sgx-driver diff --git a/docs/setup/oasis-net-runner.md b/docs/setup/oasis-net-runner.md new file mode 100644 index 00000000000..6a577cbad1c --- /dev/null +++ b/docs/setup/oasis-net-runner.md @@ -0,0 +1,76 @@ +# Local Network Runner + +In order to make development easier (and also to facilitate automated E2E +tests), the Oasis Core repository provides a utility called `oasis-net-runner` +that enables developers to quickly set up local networks. + +Before proceeding, make sure to look at the [prerequisites] required for running +an Oasis Core environment followed by [build instructions] for the respective +environment (non-SGX or SGX). The following sections assume that you have +successfully completed the required build steps. + +[prerequisites]: prerequisites.md +[build instructions]: building.md + +## Unsafe Non-SGX Environment + +To start a simple Oasis network as defined by [the default network fixture] +running the `simple-keyvalue` test runtime, do: + +``` +./go/oasis-net-runner/oasis-net-runner \ + --fixture.default.node.binary go/oasis-node/oasis-node \ + --fixture.default.runtime.binary target/default/debug/simple-keyvalue \ + --fixture.default.runtime.loader target/default/debug/oasis-core-runtime-loader \ + --fixture.default.keymanager.binary target/default/debug/simple-keymanager +``` + +Wait for the network to start, there should be messages about nodes being +started and at the end the following message should appear: + + +``` +level=info module=oasis/net-runner caller=oasis.go:319 ts=2019-10-03T10:47:30.776566482Z msg="network started" +level=info module=net-runner caller=root.go:145 ts=2019-10-03T10:47:30.77662061Z msg="client node socket available" path=/tmp/oasis-net-runner530668299/net-runner/network/client-0/internal.sock +``` + + +The `simple-keyvalue` runtime implements a key-value hash map in the enclave +and supports reading, writing, and fetching string values associated with the +given key. To learn how to create your own runtime, see the sources of the +example [here](tests/runtimes/simple-keyvalue). + +Finally, to test Oasis node, we will run a test client written specifically +for the `simple-keyvalue` runtime. The client sends a few keys with associated +values and fetches them back over RPC defined in the runtime's API. Execute the +client as follows (substituting the socket path from your log output) in a +different terminal: + +``` +./target/default/debug/simple-keyvalue-client \ + --runtime-id 8000000000000000000000000000000000000000000000000000000000000000 \ + --node-address unix:/tmp/oasis-net-runner530668299/net-runner/network/client-0/internal.sock +``` + +By default, Oasis node is configured with a 30-second epoch, so you may +initially need to wait for the first epoch to pass before the test client will +make any progress. For more information on writing your own client, see the +`simple-keyvalue` client sources [here](tests/clients/simple-keyvalue). + +[the default network fixture]: ../../go/oasis-net-runner/fixtures/default.go + +## SGX Environment + +To run an Oasis node under SGX follow the same steps as for non-SGX, except the +`oasis-net-runner` invocation: + + +``` +./go/oasis-net-runner/oasis-net-runner \ + --fixture.default.tee_hardware intel-sgx \ + --fixture.default.node.binary go/oasis-node/oasis-node \ + --fixture.default.runtime.binary target/sgx/x86_64-fortanix-unknown-sgx/debug/simple-keyvalue.sgxs \ + --fixture.default.runtime.loader target/default/debug/oasis-core-runtime-loader \ + --fixture.default.keymanager.binary target/sgx/x86_64-fortanix-unknown-sgx/debug/simple-keymanager.sgxs +``` + diff --git a/docs/setup/prerequisites.md b/docs/setup/prerequisites.md new file mode 100644 index 00000000000..1b2eb0a6440 --- /dev/null +++ b/docs/setup/prerequisites.md @@ -0,0 +1,208 @@ +# Prerequisites + +The following is a list of prerequisites required to start developing on Oasis +Core: + +* Linux (if you are not on Linux, you will need to either set up a VM with the + proper environment or, if Docker is available for your platform, use the + provided Docker image which does this for you, + [see below](#using-the-development-docker-image)). + +* System packages: + * [Bubblewrap] (at least version 0.3.3). + * [GCC] (including C++ subpackage). + * [Protobuf] compiler. + * [GNU Make]. + * [CMake]. + * [OpenSSL] development package. + * [libseccomp] development package. + + On Fedora 29+, you can install all the above with: + + + ``` + sudo dnf install bubblewrap gcc gcc-c++ protobuf-compiler make cmake openssl-devel libseccomp-devel + ``` + + + On Ubuntu 18.10+ (18.04 LTS provides overly-old `bubblewrap`), you can install + all the above with: + + ``` + sudo apt install bubblewrap gcc g++ protobuf-compiler make cmake libssl-dev libseccomp-dev + ``` + +* [Go] (at least version 1.14.3). + + If your distribution provides a new-enough version of Go, just use that. + + Otherwise: + * install the Go version provided by your distribution, + * [ensure `$GOPATH/bin` is in your `PATH`]( + https://tip.golang.org/doc/code.html#GOPATH), + * [install the desired version of Go]( + https://golang.org/doc/install#extra_versions), e.g. 1.14.3, with: + + ``` + go get golang.org/dl/go1.14.3 + go1.14.3 download + ``` + + * instruct the build system to use this particular version of Go by setting + the `OASIS_GO` environment variable in your `~/.bashrc`: + + ``` + export OASIS_GO=go1.14.3 + ``` + +* [Rust]. + + We follow [Rust upstream's recommendation][rust-upstream-rustup] on using + [rustup] to install and manage Rust versions. + + _NOTE: rustup cannot be installed alongside a distribution packaged Rust + version. You will need to remove it (if it's present) before you can start + using rustup._ + + Install it by running: + + ``` + curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh + ``` + + _NOTE: If you want to avoid directly executing a shell script fetched the + internet, you can also [download `rustup-init` executable for your platform] + and run it manually._ + + This will run `rustup-init` which will download and install the latest stable + version of Rust on your system. + +* [Fortanix Rust EDP] utilities. + + Make sure a _nightly_ version of the Rust toolchain is installed: + + ``` + rustup install nightly + ``` + + Then install the Fortanix Rust EDP utilities by running: + + ``` + cargo +nightly install --version 0.4.0 fortanix-sgx-tools + cargo +nightly install --version 0.8.2 sgxs-tools + ``` + + _NOTE: These utilities must be compiled with a nightly version of the Rust + toolchain since they use the `#![feature]` macro._ + +* Oasis Core's Rust toolchain version with Fortanix SGX target. + + The version of the Rust toolchain we use in Oasis Core is specified in the + [rust-toolchain] file. + + The rustup-installed versions of `cargo`, `rustc` and other tools will + [automatically detect this file and use the appropriate version of the Rust + toolchain][rust-toolchain-precedence] when invoked from the Oasis core git + checkout directory. + + To install the appropriate version of the Rust toolchain, make sure you are + in an Oasis Core git checkout directory and run: + + ``` + rustup show + ``` + + This will automatically install the appropriate Rust toolchain (if not + present) and output something similar to: + + ``` + ... + + active toolchain + ---------------- + + nightly-2020-06-09-x86_64-unknown-linux-gnu (overridden by '/oasis-core/rust-toolchain') + rustc 1.46.0-nightly (fd4b177aa 2020-06-08) + ``` + + Then add the Fortanix SGX Rust target to this version of the Rust toolchain by + running: + + ``` + rustup target add x86_64-fortanix-unknown-sgx + ``` + +* (**OPTIONAL**) [protoc-gen-go]. + + Download and install it with: + + ``` + GO111MODULE=on ${OASIS_GO:-go} get google.golang.org/protobuf/cmd/protoc-gen-go@v1.21.0 + ``` + + _NOTE: If you didn't/can't add `$GOPATH/bin` to your `PATH`, you can install + `protoc-gen-go` to `/usr/local/bin` (which is in `$PATH`) with:_ + + + ``` + sudo GOBIN=/usr/local/bin GO111MODULE=on ${OASIS_GO:-go} install google.golang.org/protobuf/cmd/protoc-gen-go@v1.21.0 + ``` + + + _NOTE: The repository has the most up-to-date files generated by protoc-gen-go + committed for convenience. Installing protoc-gen-go is only required if you + are a developer making changes to protobuf definitions used by Go._ + +In the following instructions, the top-level directory is the directory +where the code has been checked out. + +[Bubblewrap]: https://github.com/projectatomic/bubblewrap +[GCC]: http://gcc.gnu.org/ +[Protobuf]: https://github.com/protocolbuffers/protobuf +[GNU Make]: https://www.gnu.org/software/make/ +[CMake]: https://cmake.org/ +[OpenSSL]: https://www.openssl.org/ +[libseccomp]: https://github.com/seccomp/libseccomp +[Go]: https://golang.org +[rustup]: https://rustup.rs/ +[rust-upstream-rustup]: https://www.rust-lang.org/tools/install +[download `rustup-init` executable for your platform]: + https://github.com/rust-lang/rustup#other-installation-methods +[Rust]: https://www.rust-lang.org/ +[rust-toolchain]: rust-toolchain +[rust-toolchain-precedence]: + https://github.com/rust-lang/rustup/blob/master/README.md#override-precedence +[Fortanix Rust EDP]: https://edp.fortanix.com +[protoc-gen-go]: https://github.com/golang/protobuf + +## Using the development Docker image + +If for some reason you don't want or can't install the specified prerequisites +on the host system, you can use our development Docker image. This requires that +you have a [recent version of Docker installed]( +https://docs.docker.com/install/). + +Oasis development environment with all the dependencies preinstalled is +available in the `oasisprotocol/oasis-core-dev:master` image. +To run a container, do the following in the top-level directory: + +```bash +make docker-shell +``` + +If you are curious, this target will internally run the following command: + +``` +docker run -t -i \ + --name oasis-core \ + --security-opt apparmor:unconfined \ + --security-opt seccomp=unconfined \ + -v $(pwd):/code \ + -w /code \ + oasisprotocol/oasis-core-dev:master \ + bash +``` + +All the following commands can then be used from inside the container. See the +Docker documentation for detailed instructions on working with Docker +containers. diff --git a/docs/setup/running-tests.md b/docs/setup/running-tests.md new file mode 100644 index 00000000000..efc435aa3d5 --- /dev/null +++ b/docs/setup/running-tests.md @@ -0,0 +1,51 @@ +# Running Tests + +Before proceeding, make sure to look at the [prerequisites] required for running +an Oasis Core environment followed by [build instructions] for the respective +environment (non-SGX or SGX). The following sections assume that you have +successfully completed the required build steps. + +[prerequisites]: prerequisites.md +[build instructions]: building.md + +## Tests + +After you've built everything, you can use the following commands to run tests. + +To run all unit tests: + +``` +make test-unit +``` + +To run end-to-end tests locally: + +``` +make test-e2e +``` + +To run all tests: + +``` +make test +``` + +To execute tests using SGX set the following environmental variable before +running the tests: + +``` +export OASIS_TEE_HARDWARE=intel-sgx +``` + +## Troubleshooting + +Check the console output for mentions of a path of the form +`/tmp/oasis-test-runnerXXXXXXXXX` (where each `X` is a digit). +That's the log directory. Start with coarsest-level debug output in +`console.log` files: + +``` +cat $(find /tmp/oasis-test-runnerXXXXXXXXX -name console.log) | less +``` + +For even more output, check the other `*.log` files. diff --git a/docs/setup/single-validator-node-network.md b/docs/setup/single-validator-node-network.md new file mode 100644 index 00000000000..b4228ff470c --- /dev/null +++ b/docs/setup/single-validator-node-network.md @@ -0,0 +1,139 @@ +# Single Validator Node Network + +It is possible to provision a local "network" consisting of a single validator +node. This may be useful for specific development use cases. + +Before proceeding, make sure to look at the [prerequisites] required for running +an Oasis Core environment followed by [build instructions] for the respective +environment (non-SGX or SGX). The following sections assume that you have +successfully completed the required build steps. + +**NOTE: These instructions are for a development-only instance, do not use them +for setting up any kind of production instances as they are unsafe and will +result in insecure configurations leading to node compromise.** + +[prerequisites]: prerequisites.md +[build instructions]: building.md + +## Provisioning an Entity + +To provision an [entity] we first prepare an empty directory under +`/path/to/entity` and then initialize the entity: + +``` +mkdir -p /path/to/entity +cd /path/to/entity +oasis-node registry entity init --signer.backend file --signer.dir . +``` + +[entity]: ../consensus/registry.md#entities-and-nodes + +## Provisioning a Node + +To provision a [node] we first prepare an empty directory under `/path/to/node` +and the initialize the node. The node is provisioned as a validator. + +``` +mkdir -p /path/to/node +cd /path/to/node +oasis-node registry node init \ + --signer.backend file \ + --signer.dir /path/to/entity \ + --node.consensus_address 127.0.0.1:26656 \ + --node.is_self_signed \ + --node.role validator +``` + +After the node is provisioned we proceed with updating the [entity whitelist] +so that the node will be able to register itself: + +``` +oasis-node registry entity update \ + --signer.backend file \ + --signer.dir /path/to/entity \ + --entity.node.descriptor /path/to/node/node_genesis.json +``` + +[node]: ../consensus/registry.md#entities-and-nodes +[entity whitelist]: ../consensus/registry.md#register-node + +## Creating a Test Genesis Document + +To create a test genesis document for your development "network" use the +following commands: + +``` +mkdir -p /path/to/genesis +cd /path/to/genesis +oasis-node genesis init \ + --chain.id test \ + --entity /path/to/entity/entity_genesis.json \ + --node /path/to/node/node_genesis.json \ + --debug.dont_blame_oasis \ + --debug.test_entity \ + --debug.allow_test_keys \ + --registry.debug.allow_unroutable_addresses +``` + +**NOTE: This enables unsafe debug-only flags which must never be used in a +production setting as they may result in node compromise.** + +## Running the Node + +To run the single validator node, use the following command: + +``` +oasis-node \ + --datadir /path/to/node \ + --genesis.file /path/to/genesis/genesis.json \ + --worker.registration.entity /path/to/entity/entity.json \ + --consensus.validator \ + --debug.dont_blame_oasis \ + --debug.allow_test_keys \ + --log.level debug +``` + +**NOTE: This enables unsafe debug-only flags which must never be used in a +production setting as they may result in node compromise.** + +## Using the Node CLI + +The `oasis-node` exposes [an RPC interface] via a UNIX socket located in its +data directory (e.g., under `/path/to/node/internal.sock`). To simplify the +following instructions set up an `ADDR` environment variable pointing to it: + +``` +export ADDR=unix:/path/to/node/internal.sock +``` + +This can then be used to execute CLI commands against the running node (in a +separate terminal). For example to show all registered entities: + +``` +oasis-node registry entity list -a $ADDR -v +``` + +Giving output similar to: + + +``` +{"v":1,"id":"UcxpyD0kSo/5keRqv8pLypM/Mg5S5iULRbt7Uf73vKQ=","nodes":["jo+quvaFYAP4Chyf1PRqCZZObqpDeJCxfBzTyghiXxs="]} +{"v":1,"id":"TqUyj5Q+9vZtqu10yw6Zw7HEX3Ywe0JQA9vHyzY47TU=","allow_entity_signed_nodes":true} +``` + + +Or getting a list of all staking accounts: + +``` +oasis-node stake list -a $ADDR +``` + +Giving output similar to: + +``` +oasis1qzzd6khm3acqskpxlk9vd5044cmmcce78y5l6000 +oasis1qz3xllj0kktskjzlk0qacadgwpfe8v7sy5kztvly +oasis1qrh4wqfknrlvv7whjm7mjsjlvka2h35ply289pp2 +``` + +[an RPC interface]: ../oasis-node/rpc.md