2021-06-21 04:08:06 +00:00
# Development
2021-09-28 01:52:04 +00:00
This document will help to setup your development environment and run tests. If you encounter a problem, please file an issue.
2021-06-21 04:08:06 +00:00
2021-07-07 07:12:00 +00:00
Table of contents
=================
2021-09-22 09:47:53 +00:00
- [Development ](#development )
- [Table of contents ](#table-of-contents )
- [Building Milvus with Docker ](#building-milvus-with-docker )
- [Building Milvus on a local OS/shell environment ](#building-milvus-on-a-local-osshell-environment )
- [Hardware Requirements ](#hardware-requirements )
2021-09-28 01:52:04 +00:00
- [Software Requirements ](#software-requirements )
2021-09-22 09:47:53 +00:00
- [Dependencies ](#dependencies )
- [CMake ](#cmake )
- [Go ](#go )
- [Docker & Docker Compose ](#docker--docker-compose )
- [Building Milvus ](#building-milvus )
- [A Quick Start for Testing Milvus ](#a-quick-start-for-testing-milvus )
- [Presubmission Verification ](#presubmission-verification )
- [Unit Tests ](#unit-tests )
- [Code coverage ](#code-coverage )
- [E2E Tests ](#e2e-tests )
2021-10-01 04:30:45 +00:00
- [Test on local branch ](#test-on-local-branch )
- [On Linux ](#on-linux )
- [With docker ](#with-docker )
2021-09-22 09:47:53 +00:00
- [GitHub Flow ](#github-flow )
2021-07-07 07:12:00 +00:00
## Building Milvus with Docker
Official releases are built using Docker containers. To build Milvus using Docker please follow [these instructions ](https://github.com/milvus-io/milvus/blob/master/build/README.md ).
2021-06-21 04:08:06 +00:00
## Building Milvus on a local OS/shell environment
The details below outline the hardware and software requirements for building on Linux.
### Hardware Requirements
Milvus is written in Go and C++, compiling it can use a lot of resources. We recommend the following for any physical or virtual machine being used for building Milvus.
```
- 8GB of RAM
- 50GB of free disk space
```
2021-09-28 01:52:04 +00:00
### Software Requirements
2021-06-21 04:08:06 +00:00
2021-09-28 01:52:04 +00:00
In fact, all Linux distributions are available to develop Milvus. The following only contains commands on Ubuntu and CentOS, because we mainly use them. If you develop Milvus on other distributions, you are welcome to improve this document.
2021-06-21 04:08:06 +00:00
2021-06-28 08:30:17 +00:00
#### Dependencies
- Debian/Ubuntu
2021-06-21 04:08:06 +00:00
```shell
2021-09-17 02:25:50 +00:00
$ sudo apt update
$ sudo apt install -y build-essential ccache gfortran \
libssl-dev zlib1g-dev python3-dev libcurl4-openssl-dev libtbb-dev\
libboost-regex-dev libboost-program-options-dev libboost-system-dev \
libboost-filesystem-dev libboost-serialization-dev libboost-python-dev
2021-06-21 04:08:06 +00:00
```
2021-06-28 08:30:17 +00:00
- CentOS
```shell
2021-09-17 02:25:50 +00:00
$ sudo yum install -y epel-release centos-release-scl-rh & & \
$ sudo yum install -y git make automake openssl-devel zlib-devel \
libcurl-devel python3-devel \
devtoolset-7-gcc devtoolset-7-gcc-c++ devtoolset-7-gcc-gfortran \
llvm-toolset-7.0-clang llvm-toolset-7.0-clang-tools-extra \
ccache lcov
$ echo "source scl_source enable devtoolset-7" | sudo tee -a /etc/profile.d/devtoolset-7.sh
$ echo "source scl_source enable llvm-toolset-7.0" | sudo tee -a /etc/profile.d/llvm-toolset-7.sh
$ echo "export CLANG_TOOLS_PATH=/opt/rh/llvm-toolset-7.0/root/usr/bin" | sudo tee -a /etc/profile.d/llvm-toolset-7.sh
$ source "/etc/profile.d/llvm-toolset-7.sh"
2021-07-09 08:24:39 +00:00
# Install tbb
2021-09-17 02:25:50 +00:00
$ git clone https://github.com/wjakob/tbb.git & & \
cd tbb/build & & \
cmake .. & & make -j & & \
sudo make install & & \
cd ../../ & & rm -rf tbb/
2021-07-09 08:24:39 +00:00
# Install boost
2021-09-17 02:25:50 +00:00
$ wget -q https://boostorg.jfrog.io/artifactory/main/release/1.65.1/source/boost_1_65_1.tar.gz & & \
tar zxf boost_1_65_1.tar.gz & & cd boost_1_65_1 & & \
./bootstrap.sh --prefix=/usr/local --with-toolset=gcc --without-libraries=python & & \
sudo ./b2 -j2 --prefix=/usr/local --without-python toolset=gcc install & & \
cd ../ & & rm -rf ./boost_1_65_1*
2021-07-09 08:24:39 +00:00
2021-06-28 08:30:17 +00:00
```
2021-06-21 04:08:06 +00:00
Once you have finished, confirm that `gcc` and `make` are installed:
```shell
2021-09-17 02:25:50 +00:00
$ gcc --version
$ make --version
2021-06-21 04:08:06 +00:00
```
#### CMake
The algorithm library of Milvus, Knowhere is written in c++. CMake is required in the Milvus compilation. If you don't have it, please follow the instructions in the [Installing CMake ](https://cmake.org/install/ ).
Confirm that cmake is available:
```shell
2021-09-17 02:25:50 +00:00
$ cmake --version
2021-06-21 04:08:06 +00:00
```
2021-10-03 09:46:18 +00:00
Note: 3.18 or higher cmake version is required to build Milvus.
2021-06-21 04:08:06 +00:00
#### Go
Milvus is written in [Go ](http://golang.org/ ). If you don't have a Go development environment, please follow the instructions in the [Go Getting Started guide ](https://golang.org/doc/install ).
Confirm that your `GOPATH` and `GOBIN` environment variables are correctly set as detailed in [How to Write Go Code ](https://golang.org/doc/code.html ) before proceeding.
```shell
2021-09-17 02:25:50 +00:00
$ go version
2021-06-21 04:08:06 +00:00
```
2021-10-06 09:18:18 +00:00
Note: go1.15 is required to build Milvus.
2021-06-21 04:08:06 +00:00
#### Docker & Docker Compose
2021-10-26 06:31:03 +00:00
Milvus depends on etcd, Pulsar and MinIO. Using Docker Compose to manage these is an easy way in local development. To install Docker and Docker Compose in your development environment, follow the instructions from the Docker website below:
2021-06-21 04:08:06 +00:00
- Docker: https://docs.docker.com/get-docker/
- Docker Compose: https://docs.docker.com/compose/install/
### Building Milvus
To build the Milvus project, run the following command:
```shell
2021-09-17 02:25:50 +00:00
$ make all
2021-06-21 04:08:06 +00:00
```
If this command succeed, you will now have an executable at `bin/milvus` off of your Milvus project directory.
2021-10-26 06:31:03 +00:00
If you want to update proto file before `make` , we can use the following command:
2021-10-05 13:10:22 +00:00
```shell
$ make generated-proto-go
```
If you want to know more, you can read Makefile.
2021-06-21 04:08:06 +00:00
## A Quick Start for Testing Milvus
### Presubmission Verification
Presubmission verification provides a battery of checks and tests to give your pull request the best chance of being accepted. Developers need to run as many verification tests as possible locally.
To run all presubmission verification tests, use this command:
```shell
2021-09-17 02:25:50 +00:00
$ make verifiers
2021-06-21 04:08:06 +00:00
```
### Unit Tests
Pull requests need to pass all unit tests. To run every unit test, use this command:
```shell
2021-09-17 02:25:50 +00:00
$ make unittest
2021-06-21 04:08:06 +00:00
```
2021-10-05 13:10:22 +00:00
Before using `make unittest` command, we should run a milvus's deployment environment which helps us to do go test. Here we use local docker environment, use the following commands:
```shell
# Using cluster environment
$ cd deployments/docker/dev
$ docker-compose up -d
$ cd ../../../
$ make unittest
# Or using standalone environment
$ cd deployments/docker/standalone
$ docker-compose up -d
$ cd ../../../
$ make unittest
```
To run only cpp test, we can use this command:
```shell
make test-cpp
```
To run only go test, we can use this command:
```shell
make test-go
```
2021-09-13 01:44:02 +00:00
To run single test case, for instance, run TestSearchTask in /internal/proxy directory, use
```shell
2021-09-17 02:25:50 +00:00
$ go test -v ./internal/proxy/ -test.run TestSearchTask
2021-09-13 01:44:02 +00:00
```
2021-09-22 09:47:53 +00:00
### Code coverage
Before submitting your Pull Request, make sure your code change is covered by unit test. Use the following commands to check code coverage rate:
2021-10-04 01:07:56 +00:00
Install lcov(cpp code coverage tool):
2021-09-22 09:47:53 +00:00
```shell
$ sudo apt-get install lcov
```
2021-10-04 01:07:56 +00:00
Run unit test and generate code coverage report:
2021-09-22 09:47:53 +00:00
```shell
$ make codecov
```
This command will generate html report for Golang and C++ respectively.
For Golang report, open the `go_coverage.html` under milvus project path.
For C++ report, open the `cpp_coverage/index.html` under milvus project path.
You also can generate Golang coverage report by:
```shell
$ make codecov-go
```
Or C++ coverage report by:
```shell
$ make codecov-cpp
```
2021-09-13 01:44:02 +00:00
2021-06-21 04:08:06 +00:00
### E2E Tests
2021-10-26 06:31:03 +00:00
Milvus uses Python SDK to write test cases to verify the correctness of Milvus functions. Before running E2E tests, you need a running Milvus:
2021-06-21 04:08:06 +00:00
```shell
2021-10-05 13:10:22 +00:00
# Running Milvus cluster
2021-09-17 02:25:50 +00:00
$ cd deployments/docker/dev
$ docker-compose up -d
$ cd ../../../
$ ./scripts/start_cluster.sh
2021-10-05 13:10:22 +00:00
# Or running Milvus standalone
$ cd deployments/docker/standalone
$ docker-compose up -d
$ cd ../../../
$ ./scripts/start_standalone.sh
2021-06-21 04:08:06 +00:00
```
2021-10-26 06:31:03 +00:00
To run E2E tests, use these commands:
2021-06-21 04:08:06 +00:00
```shell
2021-09-17 02:25:50 +00:00
$ cd tests/python_client
$ pip install -r requirements.txt
$ pytest --tags=L0 -n auto
2021-06-21 04:08:06 +00:00
```
2021-10-01 00:55:21 +00:00
### Test on local branch
2021-10-01 04:30:45 +00:00
#### On Linux
2021-10-05 13:10:22 +00:00
After preparing deployment environment, we can start the cluster on your host machine
2021-10-01 00:55:21 +00:00
```shell
$ ./scripts/start_cluster.sh
```
#### With docker
start the cluster on your host machine
```shell
$ ./build/builder.sh make install // build milvus
$ ./build/build_image.sh // build milvus lastest docker
$ docker images // check if milvus latest image is ready
REPOSITORY TAG IMAGE ID CREATED SIZE
milvusdb/milvus latest 63c62ff7c1b7 52 minutes ago 570MB
$ install with docker compose
```
2021-06-21 04:08:06 +00:00
## GitHub Flow
2021-09-28 01:52:04 +00:00
To check out code to work on, please refer to the [GitHub Flow ](https://guides.github.com/introduction/flow/ ).