forked from OpenZWave/python-openzwave
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDEVEL.txt
193 lines (119 loc) · 5.53 KB
/
DEVEL.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
Developers information
**********************
How to develop for python-openzwave
===================================
Get the sources
git clone https://github.com/OpenZWave/python-openzwave
You can install all the dependances to develop for python-openzwave
using the command :
sudo make developer-deps
You must now install python-openzwave in develop mode
make develop
Your password will be asked (by sudo) for installing eggs in your
local directory.
Develop, test, debug, test, ... :)
Update the documentation if needed. You surely found the documentation
useful, so please keep it up to date.
You can create an account on travis or docker to run the tests.
At last but not least, submit your request.
How to develop for libopenzwave (was python-openzwave-lib)
==========================================================
After updating the pyx, you need to reinstall it. Otherwise, your
changes will not be applied :
make develop
Tests
=====
First, install the dependances :
sudo make tests-deps
To launch all the tests suite (about 140 tests), use the following
command :
make tests
To launch particular tests :
nosetests --verbosity=2 tests/api/test_controller_command.py
Some tests need manual operations (ie to add a node, to remove one,
...). For example, to test the remove node, use :
export MANUALSKIP='False' && nosetests --verbosity=2 tests/api/test_controller_command.py -m test_150 && unset MANUALSKIP
test_150_command_remove_node_and_wait_for_user (tests.api.test_controller_command.TestControllerCommand) ... ok
----------------------------------------------------------------------
Ran 1 test in 16.031s
OK
You should push the inclusion button of the node before the end of the
test.
Some tests don't need a ZWave Stick to be launched, so they can be run
on the autobuilders (travis, docker, ...). Place them in the autobuild
directory.
Travis-ci, Docker Hub, nosetests and pylint are used to test quality
of code. There reports are here :
* Docker : https://registry.hub.docker.com/u/bibi21000/python-
openzwave/
* Travis : https://travis-ci.org/bibi21000/python-openzwave
* Nosetests report
* Coverage report
* Pylint report
Documentation
=============
First, install the dependances :
sudo make doc-deps
Documentation is managed with sphinx. Don't utpdate txt files (README,
INSTALL, ...), update the RST sources in docs. Use the following
commands to generate all docs files (txt, html and joomla)
You need to have installed python-openzwave (in either develop or
install mode) before generating the documentation.
make docs
Static vs dynamic (or shared)
=============================
The openzwave (c++) lib needs to run as a singleton : it means that it
MUST have only one instance of the manager running on your computer.
There is 2 ways of linking libraries with a program :
* static : includes a copy of the library in your binary program.
This means that your program has its own instance of the library.
This the way the install.sh runs. So you CAN'T have another
program (like the control-panel) running when using the python-
openzwave library
* dynamic or shared : includes a link to the library in your
binary program. This means that your program share the library
with other programs. In this case, the instance is owned directly
by the library. This the way the debian package works. So you CAN
have another program running when using the python-openzwave
library. Of course, this program MUST use the shared library too.
About sudo
==========
If you are like me and don't like root (and sudo), you can use the
following tip to install packages via pip :
Look at your python local library, it should looks like :
ls -lisa /usr/local/lib/python2.7/dist-packages/
total 2428
1445174 12 drwxrwsr-x 115 root staff 12288 avril 9 21:35 .
1445172 4 drwxrwsr-x 4 root staff 4096 mai 2 2014 ..
1457164 4 drwxr-sr-x 5 root staff 4096 nov. 26 2013 actdiag
1715480 4 drwxr-sr-x 2 root staff 4096 nov. 26 2013 actdiag-0.5.1.egg-info
1457163 4 -rw-r--r-- 1 root staff 1004 nov. 26 2013 actdiag_sphinxhelper.py
1457172 4 -rw-r--r-- 1 root staff 620 nov. 26 2013 actdiag_sphinxhelper.pyc
....
So, add your common user to the staff group :
sudo usermod -a -G staff userName
Add the write right to the group staff
sudo chmod -Rf g+w /usr/local/lib/python2.7/dist-packages/
And now, it's time log off and log on. Groups are checked when you
open the session.
You can now install your packages without sudo.
Python3 and virtualenv
======================
Python 3 is actually not supported.
A branch (python3) has been created with a special Dockerfile. It
build python-openzwave and launch some tests. This branch is
automatically merged from master at "make commit".
So please, do not directly push under python3 branch. Make your
developments under master or another branch.
It's important for me have python2/python3 compatibilty in the master
branch. cython can help for this :
http://docs.cython.org/src/tutorial/strings.html
The Makefile sill try to automatically configure your version of
python (running python --version).
If you want to install python-openzwave in a python virtual
environnement, you should use something like :
make VIRTUAL_ENV=/path/to/my/venv ...
If you use python 3 and your python executable is called python3 :
make PYTHON_EXEC=python3 ...
You can also put these variables in a CONFIG.make file instead of
passing them to the command line