Hacking Python SDK » History » Revision 6
Revision 5 (Tom Clegg, 07/04/2014 01:12 PM) → Revision 6/26 (Brett Smith, 07/18/2014 09:41 AM)
h1. Hacking Python SDK
{{toc}}
h2. Prerequisites
The <pre>
sudo apt-get install python python-pip python-dev python-virtualenv libyaml-dev
</pre>
Additional prerequisites for FUSE driver requires associated libraries to build: driver:
<pre>
sudo apt-get install libattr1-dev libfuse-dev pkg-config fuse
sudo adduser "$USER" fuse
sudo chmod g+rw /dev/fuse
sudo chown root:fuse /dev/fuse
</pre>
After installing @fuse@ and adding yourself to the @fuse@ group, you need to start a new login session. Make sure the @groups@ command reports that you're in the @fuse@ group.
h2. Get the source code
<pre>
cd
git clone https://github.com/curoverse/arvados.git
</pre>
h2. virtualenv
virtualenv helps you isolate the dependencies for a specific package or environment, much like Bundler does for our Rails applications. The recommended way to deploy is to build a virtualenv for Arvados development.
To build the virtualenv, run:
<pre>
$ virtualenv --setuptools VENVDIR
</pre>
(@VENVDIR@ can be a directory anywhere you like, although best practice is to keep it outside your source directory.)
To set up the shell to use the isolated virtualenv environment, run:
<pre>
$ source VENVDIR/bin/activate
</pre>
To learn more about using and configuring virtualenv, read the "virtualenv usage documentation":https://virtualenv.pypa.io/en/latest/virtualenv.html#usage.
h2. Run tests
Strategy:
# Set up the environment Install your local (possibly modified) client library to use a dedicated virtualenv
# Run the client library test suite
# Build a client library package and install it to the virtualenv
# Install your local (possibly modified) FUSE driver to the same virtualenv
# Run the FUSE driver test suite
# Build a FUSE driver package and install it to the virtualenv
Note: The test suite brings up a Keep server and an API server to run tests against. For best results:
* Try [[Hacking Keep]] and [[Hacking API Server]] to make sure you have all the right dependencies for running the Keep and API servers.
* Make sure you have a blob_signing_key in services/api/config/application.yml
Script (make sure to edit the first line to refer to your virtualenv): Script:
<pre>
source VENVDIR/bin/activate VENVDIR=$(mktemp -d)
virtualenv --setuptools --system-site-packages "$VENVDIR"
cd ~/arvados/sdk/python
"$VENVDIR/bin/pip" install -r requirements.txt
"$VENVDIR/bin/pip" install -e .
GOPATH="$HOME/gocode" python "$VENVDIR/bin/python" -m unittest discover tests
"$VENVDIR/bin/python" setup.py test
python setup.py egg_info -b ".$(git log --format=format:%ct.%h -n1 .)" sdist rotate --keep=1
pip "$VENVDIR/bin/pip" install dist/arvados-python-client-0.1.*.tar.gz
cd ~/arvados/services/fuse
"$VENVDIR/bin/pip" install -r requirements.txt
"$VENVDIR/bin/pip" install -e .
GOPATH="$HOME/gocode" python "$VENVDIR/bin/python" -m unittest discover tests
"$VENVDIR/bin/python" setup.py test
python setup.py egg_info -b ".$(git log --format=format:%ct.%h -n1 .)" sdist rotate --keep=1
pip "$VENVDIR/bin/pip" install dist/arvados_fuse-0.1.*.tar.gz
</pre>