commit | 1df4e7130585be99780bb99c6095f7ddc3896392 | [log] [tgz] |
---|---|---|
author | William Kurkian <wkurkian@cisco.com> | Fri Jun 07 17:08:26 2019 -0400 |
committer | William Kurkian <wkurkian@cisco.com> | Fri Jun 07 17:08:26 2019 -0400 |
tree | ff4cc1c47c62c3bec1cb1df50b301d7156a4ed33 | |
parent | 4b0dab2699ecc30ef043b4113e6a754e5c4342e7 [diff] |
VOL-1688 Fixing subtle error where multiple dist versions can exist if the version file is updated without a make clean. This can cause the wrong version to be loaded in local builds Change-Id: I18ee71fa6875aae70ace6c9861926c4b3b43644b
Protobuf files used by VOLTHA.
Currently this is used to generate both Golang and Python protobufs and gRPC stubs.
Protobuf definition files are located in protos/voltha_protos
directory. This directory hierarchy and import scheme is required to allow the python code generated by the gRPC compiler to have the correct import paths.
NOTE: The
protos/google/api
directory has files copied from the Google APIs, and is only included for initial compilation of the VOLTHA protobuf files - these API's should be installed independently via either the python googleapis-common-protos package or the golang go-genproto repo.
Get the voltha-protos repository:
mkdir -p ~/source cd ~/source git clone https://gerrit.opencord.org/voltha-protos cd voltha-protos
After installing Go on a Mac or Linux environment, the GOPATH environment variable needs be set. These instructions assume it's ~/go
.
Create a symbolic link in the $GOPATH/src tree to the voltha-go repository:
mkdir -p $GOPATH/src/github.com/opencord ln -s ~/source/voltha-protos $GOPATH/src/github.com/opencord/voltha-protos
Checkout and go install correct version of protoc-gen-go:
cd $GOPATH/src/github.com/opencord/voltha-protos go get -d github.com/golang/protobuf/ cd $GOPATH/src/github.com/golang/protobuf git checkout v1.3.1 make install
Install libprotoc 3.7.0 manually or use the Makefile target install it. Then build the python and golang stubs:
cd $GOPATH/src/github.com/opencord/voltha-protos make install-protoc make build
use dist/*.tar.gz for local python imports use go/ for local go imports
Installation from Pypi:
pip install voltha-protos
or from a local build:
pip install ~/source/voltha-protos/dist/*.tar.gz
To use it within your code (for example)
from voltha_protos import voltha_pb2
go get github.com/opencord/voltha-protos cd $GOPATH/github.com/opencord/voltha-protos make build
Protos are importable from github.com/opencord/voltha-protos/go/<packagename>
To use the libraries, import protos with the root path github.com/opencord/voltha-protos/go/
make test
will run tests for all languages.