commit | 12fc0af25cd0e34555535be9949af64556569fcb | [log] [tgz] |
---|---|---|
author | William Kurkian <wkurkian@cisco.com> | Thu Apr 18 14:27:45 2019 -0400 |
committer | William Kurkian <wkurkian@cisco.com> | Fri Apr 19 12:02:03 2019 -0400 |
tree | 26b2d2ce154d4d6743efe102b954c280b234d78b | |
parent | 15249faa5bd11921186530b6419e9a780cec0dd0 [diff] |
Updating package names so that package matches go_package. This is better for consistent package references. This is needed for the afrouter tests using voltha.pb Change-Id: I4cfdf26456f92d8bce4fe5b40515ad7ac3d6747d
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.