Hacking Python SDK » History » Version 23
Bryan Cosca, 08/04/2015 06:54 PM
1 | 1 | Tom Clegg | h1. Hacking Python SDK |
---|---|---|---|
2 | |||
3 | {{toc}} |
||
4 | |||
5 | h2. Prerequisites |
||
6 | |||
7 | 6 | Brett Smith | The FUSE driver requires associated libraries to build: |
8 | 4 | Tom Clegg | |
9 | <pre> |
||
10 | 5 | Tom Clegg | sudo apt-get install libattr1-dev libfuse-dev pkg-config fuse |
11 | sudo adduser "$USER" fuse |
||
12 | sudo chmod g+rw /dev/fuse |
||
13 | sudo chown root:fuse /dev/fuse |
||
14 | 1 | Tom Clegg | </pre> |
15 | 5 | Tom Clegg | |
16 | 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. |
||
17 | 4 | Tom Clegg | |
18 | 1 | Tom Clegg | h2. Get the source code |
19 | |||
20 | <pre> |
||
21 | cd |
||
22 | git clone https://github.com/curoverse/arvados.git |
||
23 | </pre> |
||
24 | |||
25 | 6 | Brett Smith | h2. virtualenv |
26 | |||
27 | 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. |
||
28 | |||
29 | To build the virtualenv, run: |
||
30 | |||
31 | <pre> |
||
32 | 23 | Bryan Cosca | $ sudo apt-get install python-virtualenv |
33 | 6 | Brett Smith | $ virtualenv --setuptools VENVDIR |
34 | </pre> |
||
35 | |||
36 | (@VENVDIR@ can be a directory anywhere you like, although best practice is to keep it outside your source directory.) |
||
37 | |||
38 | To set up the shell to use the isolated virtualenv environment, run: |
||
39 | |||
40 | <pre> |
||
41 | $ source VENVDIR/bin/activate |
||
42 | </pre> |
||
43 | |||
44 | To learn more about using and configuring virtualenv, read the "virtualenv usage documentation":https://virtualenv.pypa.io/en/latest/virtualenv.html#usage. |
||
45 | |||
46 | 1 | Tom Clegg | h2. Run tests |
47 | |||
48 | Strategy: |
||
49 | 6 | Brett Smith | # Set up the environment to use a dedicated virtualenv |
50 | 1 | Tom Clegg | # Run the client library test suite |
51 | # Build a client library package and install it to the virtualenv |
||
52 | # Run the FUSE driver test suite |
||
53 | # Build a FUSE driver package and install it to the virtualenv |
||
54 | |||
55 | Note: The test suite brings up a Keep server and an API server to run tests against. For best results: |
||
56 | * Try [[Hacking Keep]] and [[Hacking API Server]] to make sure you have all the right dependencies for running the Keep and API servers. |
||
57 | * Make sure you have a blob_signing_key in services/api/config/application.yml |
||
58 | 11 | Tom Clegg | * Install the keepstore binary. |
59 | ** Make sure your GOPATH points somewhere, e.g.: @export GOPATH=~/gocode; mkdir -p $GOPATH@ |
||
60 | ** Install keepstore: @go get git.curoverse.com/arvados.git/services/keepstore@ |
||
61 | ** (if you don't do anything special, this fetches "master" from git.curoverse.com -- if you want to build a version of keepstore with local modifications, see [[Hacking Keep]]) |
||
62 | 4 | Tom Clegg | |
63 | 6 | Brett Smith | Script (make sure to edit the first line to refer to your virtualenv): |
64 | 1 | Tom Clegg | |
65 | <pre> |
||
66 | 22 | Nico César | apt-get install libcurl4-openssl-dev python-dev libssl-dev |
67 | 6 | Brett Smith | source VENVDIR/bin/activate |
68 | 1 | Tom Clegg | |
69 | cd ~/arvados/sdk/python |
||
70 | 9 | Tom Clegg | python setup.py test |
71 | 18 | Brett Smith | python setup.py install |
72 | 1 | Tom Clegg | |
73 | cd ~/arvados/services/fuse |
||
74 | 7 | Brett Smith | python setup.py test |
75 | 18 | Brett Smith | python setup.py install |
76 | 1 | Tom Clegg | </pre> |
77 | 10 | Brett Smith | |
78 | 12 | Tom Clegg | h3. Run a single test or test class |
79 | |||
80 | <pre> |
||
81 | source VENVDIR/bin/activate |
||
82 | cd ~/arvados/sdk/python |
||
83 | |||
84 | 13 | Tom Clegg | # One test module |
85 | 12 | Tom Clegg | python setup.py test --test-suite tests.test_keep_locator |
86 | 1 | Tom Clegg | |
87 | 13 | Tom Clegg | # One test class |
88 | python setup.py test --test-suite tests.test_keep_locator.ArvadosKeepLocatorTest |
||
89 | |||
90 | # One test case |
||
91 | 12 | Tom Clegg | python setup.py test --test-suite tests.test_keep_locator.ArvadosKeepLocatorTest.base_locators |
92 | 1 | Tom Clegg | </pre> |
93 | 12 | Tom Clegg | |
94 | h2. Builds and versioning |
||
95 | 15 | Brett Smith | |
96 | 18 | Brett Smith | When we build each Python package, the version number is generated from the most recent commit that affected the package. The format is @0.1.[commit's timestamp formatted as %Y%m%d%H%M%S].[commit's short hash]@. |
97 | 15 | Brett Smith | |
98 | 18 | Brett Smith | If you want to make changes in one package and refer to it somewhere else (e.g., have the FUSE package depend on a specific SDK version), you should commit your changes to the original package before anything else. Then you can consistently refer to the metadata from that dedicated commit in subsequent changes. |
99 | 15 | Brett Smith | |
100 | 10 | Brett Smith | h2. Logging |
101 | |||
102 | The Python SDK uses Python's built-in logging module to log errors, warnings, and debug messages. The arvados module sets up logging for messages under "arvados" based on local configuration (e.g., the @ARVADOS_DEBUG@ setting). Other SDK modules and command-line tools should @import arvados@ and then send messages to a logger under "arvados" to ensure consistent log handling. Typical setup looks like this: |
||
103 | |||
104 | <pre><code class="python"> |
||
105 | import arvados |
||
106 | import logging |
||
107 | |||
108 | logger = logging.getLogger('arvados.YOURTHING') |
||
109 | </code></pre> |
||
110 | |||
111 | Once you've set this up, you can send messages to the logger using methods like @logger.debug()@ and @logger.error()@. See the "Logger class documentation":https://docs.python.org/2/library/logging.html#logger-objects for full details. |
||
112 | |||
113 | Command-line scripts may reconfigure the @arvados.logger@ object based on additional configuration like command-line switches. @services/fuse/bin/arv-mount@ demonstrates adjusting the level and setting a custom log handler. |
||
114 | 14 | Peter Amstutz | |
115 | 20 | Peter Amstutz | h2. Documenting your code |
116 | 19 | Peter Amstutz | |
117 | See "PEP 257":https://www.python.org/dev/peps/pep-0257/ and "PEP 287":https://www.python.org/dev/peps/pep-0287/ |
||
118 | |||
119 | 14 | Peter Amstutz | h2. Python buffer protocol |
120 | |||
121 | Notes on managing buffers efficiently in Python, we don't use this in the python sdk as of this writing (but we might). |
||
122 | |||
123 | http://eli.thegreenplace.net/2011/11/28/less-copies-in-python-with-the-buffer-protocol-and-memoryviews/ |
||
124 | |||
125 | Example using bytearray() to allocate a buffer, memoryview() to create a writable slice, and readinto() to write directly to the buffer slice: |
||
126 | |||
127 | <pre> |
||
128 | >>> b = bytearray(20) |
||
129 | >>> c = memoryview(b) |
||
130 | >>> f = open("python.txt", "r") |
||
131 | >>> f.readinto(c[5:10]) |
||
132 | 5 |
||
133 | >>> b |
||
134 | bytearray(b"\x00\x00\x00\x00\x00I\'ve \x00\x00\x00\x00\x00\x00\x00\x00\x00\x00") |
||
135 | </pre> |