Project Installation

Version 47 (Etienne Pallier, 03/30/2016 06:53 pm)

1 1 Etienne Pallier
h1. Project Installation
2 1 Etienne Pallier
3 6 Etienne Pallier
4 11 Etienne Pallier
Project Development page : [[Project Development]]
5 11 Etienne Pallier
6 6 Etienne Pallier
HOWTO Format Redmine Wiki : http://www.redmine.org/projects/redmine/wiki/FrRedmineWikiFormatting
7 6 Etienne Pallier
8 6 Etienne Pallier
{{>toc}}
9 6 Etienne Pallier
10 6 Etienne Pallier
11 3 Etienne Pallier
---
12 3 Etienne Pallier
13 4 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}I - DATABASE SCHEMA (v0.2.1)%
14 4 Etienne Pallier
15 4 Etienne Pallier
16 4 Etienne Pallier
{{thumbnail(PYROS_PDM_v021.png, size=300, title=Pyros data model)}}
17 4 Etienne Pallier
18 4 Etienne Pallier
19 4 Etienne Pallier
---
20 5 Etienne Pallier
21 5 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}II - Get the project (from gitlab)%
22 5 Etienne Pallier
23 1 Etienne Pallier
24 12 Etienne Pallier
h3. Browse the code from gitlab
25 5 Etienne Pallier
26 12 Etienne Pallier
https://gitlab.irap.omp.eu/epallier/pyros/tree/master
27 5 Etienne Pallier
28 5 Etienne Pallier
h3. Project structure
29 5 Etienne Pallier
30 5 Etienne Pallier
Once you have fetched the project, you should obtain this structure:
31 5 Etienne Pallier
32 5 Etienne Pallier
<pre>
33 5 Etienne Pallier
34 5 Etienne Pallier
PYROS/
35 5 Etienne Pallier
├── install/
36 5 Etienne Pallier
│   └── REQUIREMENTS.txt
37 5 Etienne Pallier
│   └── INSTALLATION.txt
38 5 Etienne Pallier
├── public/
39 5 Etienne Pallier
│   └── static/
40 5 Etienne Pallier
├── src/
41 5 Etienne Pallier
│   ├── manage.py
42 5 Etienne Pallier
│   ├── pyros/
43 5 Etienne Pallier
│   │   ├── __init__.py
44 5 Etienne Pallier
│   │   ├── __pycache__
45 5 Etienne Pallier
│   │   ├── settings.py
46 5 Etienne Pallier
│   │   ├── urls.py
47 5 Etienne Pallier
│   │   └── wsgi.py
48 5 Etienne Pallier
│   └── pyrosapp/
49 5 Etienne Pallier
│       ├── __init__.py
50 5 Etienne Pallier
│       ├── admin.py
51 5 Etienne Pallier
│       ├── apps.py
52 5 Etienne Pallier
│       ├── migrations
53 5 Etienne Pallier
│       ├── models.py
54 5 Etienne Pallier
│       ├── tests.py
55 5 Etienne Pallier
│       └── views.py
56 5 Etienne Pallier
57 5 Etienne Pallier
58 5 Etienne Pallier
</pre>
59 5 Etienne Pallier
60 37 Etienne Pallier
h3. From Eclipse
61 37 Etienne Pallier
62 37 Etienne Pallier
See below, section "NOTES FOR ECLIPSE USERS"
63 37 Etienne Pallier
64 37 Etienne Pallier
65 5 Etienne Pallier
h3. From the terminal
66 5 Etienne Pallier
67 5 Etienne Pallier
<pre>
68 5 Etienne Pallier
git clone https://gitlab.irap.omp.eu/epallier/pyros.git PYROS
69 5 Etienne Pallier
(or also : git clone git@gitlab.irap.omp.eu:epallier/pyros.git PYROS)
70 5 Etienne Pallier
</pre>
71 5 Etienne Pallier
72 5 Etienne Pallier
This creates a PYROS/ folder containing the project (with a .git/ subfolder for synchronization with the git repository)
73 5 Etienne Pallier
74 5 Etienne Pallier
_If you just wanted a static copy of the project (without synchronization), just remove the .git/ folder:_
75 5 Etienne Pallier
<pre>
76 5 Etienne Pallier
$ rm -r .git/
77 5 Etienne Pallier
</pre>
78 5 Etienne Pallier
79 38 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}III - INSTALLATION OF NEEDED DEPENDANCES%
80 9 Etienne Pallier
81 9 Etienne Pallier
82 9 Etienne Pallier
---
83 1 Etienne Pallier
84 38 Etienne Pallier
h3. Install a database server (only if necessary)
85 38 Etienne Pallier
86 44 Etienne Pallier
By default, Pyros uses Mysql, but this means that you will need to install the Mysql database server...
87 1 Etienne Pallier
88 40 Etienne Pallier
Thus, to make things easier, avoid Mysql installation by using Sqlite instead as the database server (which will need no installation at all) :
89 40 Etienne Pallier
90 44 Etienne Pallier
=> For this, just edit the file PYROS/src/pyros/settings.py and set MYSQL variable to False, and that's it. You can go to next section.
91 40 Etienne Pallier
92 44 Etienne Pallier
Now, if you really want to use Mysql (which is the default), you will need to install it (only if not already installed), so keep reading.
93 40 Etienne Pallier
94 44 Etienne Pallier
_(Skip this if you are using Sqlite instead of MySql)_
95 9 Etienne Pallier
96 9 Etienne Pallier
 * Linux Ubuntu
97 9 Etienne Pallier
<pre>
98 9 Etienne Pallier
99 9 Etienne Pallier
$ sudo apt-get install mysql-server
100 9 Etienne Pallier
$ sudo apt-get install mysql-client
101 9 Etienne Pallier
102 9 Etienne Pallier
</pre>
103 9 Etienne Pallier
104 9 Etienne Pallier
 * Linux CentOS
105 9 Etienne Pallier
<pre>
106 9 Etienne Pallier
TODO:
107 9 Etienne Pallier
$ sudo yum install mysql
108 9 Etienne Pallier
...
109 9 Etienne Pallier
</pre>
110 9 Etienne Pallier
111 9 Etienne Pallier
 * Mac OS X
112 9 Etienne Pallier
Install XAMPP
113 9 Etienne Pallier
(but you could also use the pre-installed Mac OS MySql)
114 9 Etienne Pallier
<pre>
115 9 Etienne Pallier
TODO:
116 9 Etienne Pallier
</pre>
117 9 Etienne Pallier
118 9 Etienne Pallier
 * Windows
119 9 Etienne Pallier
120 9 Etienne Pallier
<pre>
121 9 Etienne Pallier
Download and install the newest version on https://dev.mysql.com/downloads/installer/
122 9 Etienne Pallier
123 9 Etienne Pallier
Once installed, launch MySQL Installer. Clic on 'Add...' on the right.
124 9 Etienne Pallier
In MySQLServers section, choose the newest, then clic on next.
125 9 Etienne Pallier
Install and configure the server (just follow the installation guide).
126 9 Etienne Pallier
127 9 Etienne Pallier
Then launch mysql (via the Windows menu).
128 9 Etienne Pallier
</pre>
129 9 Etienne Pallier
130 9 Etienne Pallier
131 9 Etienne Pallier
---
132 9 Etienne Pallier
133 9 Etienne Pallier
h3. Install Python3.5 (only if necessary)
134 9 Etienne Pallier
135 9 Etienne Pallier
136 9 Etienne Pallier
 * Mac OS X :
137 9 Etienne Pallier
<pre>
138 9 Etienne Pallier
139 9 Etienne Pallier
1) Installer MacPort
140 9 Etienne Pallier
(TODO: doc)
141 9 Etienne Pallier
142 9 Etienne Pallier
2) Installer le "port" python35
143 9 Etienne Pallier
$ sudo port install python35
144 9 Etienne Pallier
145 9 Etienne Pallier
</pre>
146 9 Etienne Pallier
147 9 Etienne Pallier
 * Linux (Ubuntu) :
148 9 Etienne Pallier
<pre>
149 9 Etienne Pallier
$ sudo add-apt-repository ppa:fkrull/deadsnakes
150 9 Etienne Pallier
$ sudo apt-get update
151 9 Etienne Pallier
$ sudo apt-get install python3.5
152 9 Etienne Pallier
153 9 Etienne Pallier
$ sudo pip install virtualenv
154 9 Etienne Pallier
</pre>
155 9 Etienne Pallier
156 9 Etienne Pallier
157 9 Etienne Pallier
 * Windows 7 :
158 9 Etienne Pallier
<pre>
159 9 Etienne Pallier
Go to https://www.python.org/downloads/windows/ , choose the wanted version
160 9 Etienne Pallier
On the wanted version’s page, download Windows x86 executable installer
161 9 Etienne Pallier
162 9 Etienne Pallier
Run the executable
163 9 Etienne Pallier
    * On the first page, check "Add python3.5 to PATH"
164 9 Etienne Pallier
    * Choose "Install now" option
165 9 Etienne Pallier
166 9 Etienne Pallier
Open cmd (windows + R, cmd) :
167 9 Etienne Pallier
 $ python -m pip install --upgrade pip
168 9 Etienne Pallier
 $ pip install virtualenv
169 9 Etienne Pallier
</pre>
170 9 Etienne Pallier
171 9 Etienne Pallier
 * Windows 10 :
172 9 Etienne Pallier
<pre>
173 9 Etienne Pallier
TODO:
174 9 Etienne Pallier
</pre>
175 9 Etienne Pallier
176 9 Etienne Pallier
---
177 9 Etienne Pallier
178 9 Etienne Pallier
h3. Create a Python3 virtual environment dedicated to the project (inside the project folder)
179 9 Etienne Pallier
180 9 Etienne Pallier
<pre>
181 9 Etienne Pallier
182 9 Etienne Pallier
$ mkdir private/
183 9 Etienne Pallier
184 9 Etienne Pallier
$ cd private/
185 9 Etienne Pallier
186 9 Etienne Pallier
$ which python3.5 ("where python" for windows)
187 9 Etienne Pallier
/opt/local/bin/python3.5
188 9 Etienne Pallier
189 45 Etienne Pallier
$ virtualenv venv_py35_pyros -p /opt/local/bin/python3.5
190 9 Etienne Pallier
=> creates a venv_py35_pyros/ folder inside PYROS/private/
191 9 Etienne Pallier
192 9 Etienne Pallier
</pre>
193 9 Etienne Pallier
194 9 Etienne Pallier
---
195 9 Etienne Pallier
196 9 Etienne Pallier
h3. Activate the python virtual environment (from inside the project)
197 9 Etienne Pallier
198 9 Etienne Pallier
<pre>
199 9 Etienne Pallier
200 9 Etienne Pallier
$ pwd
201 9 Etienne Pallier
.../PYROS/private
202 9 Etienne Pallier
203 9 Etienne Pallier
$ source ./venv_py35_pyros/bin/activate (venv_py35_pyros/Scripts/activate on Windows)
204 9 Etienne Pallier
205 9 Etienne Pallier
206 9 Etienne Pallier
$ python -V
207 9 Etienne Pallier
Python 3.5.1
208 9 Etienne Pallier
209 9 Etienne Pallier
$ which pip
210 9 Etienne Pallier
.../PYROS/venv_py35_pyros/bin/pip
211 9 Etienne Pallier
212 9 Etienne Pallier
Upgrade pip to last version available:
213 9 Etienne Pallier
$ pip install --upgrade pip
214 9 Etienne Pallier
Collecting pip
215 9 Etienne Pallier
  Downloading pip-8.1.1-py2.py3-none-any.whl (1.2MB)
216 9 Etienne Pallier
Installing collected packages: pip
217 9 Etienne Pallier
  Found existing installation: pip 7.1.2
218 9 Etienne Pallier
    Uninstalling pip-7.1.2:
219 9 Etienne Pallier
      Successfully uninstalled pip-7.1.2
220 9 Etienne Pallier
Successfully installed pip-8.1.1
221 9 Etienne Pallier
222 9 Etienne Pallier
Upgrade wheel to last version available:
223 9 Etienne Pallier
$ pip install --upgrade wheel
224 9 Etienne Pallier
Collecting wheel
225 9 Etienne Pallier
  Downloading wheel-0.29.0-py2.py3-none-any.whl (66kB)
226 9 Etienne Pallier
Installing collected packages: wheel
227 9 Etienne Pallier
  Found existing installation: wheel 0.24.0
228 9 Etienne Pallier
    Uninstalling wheel-0.24.0:
229 9 Etienne Pallier
      Successfully uninstalled wheel-0.24.0
230 9 Etienne Pallier
Successfully installed wheel-0.29.0
231 9 Etienne Pallier
232 9 Etienne Pallier
233 9 Etienne Pallier
</pre>
234 9 Etienne Pallier
235 9 Etienne Pallier
---
236 9 Etienne Pallier
237 9 Etienne Pallier
h3. Install the needed Python packages (from within the virtual environment)
238 9 Etienne Pallier
239 9 Etienne Pallier
First, be sure that the virtual environment is activated:
240 9 Etienne Pallier
<pre>
241 9 Etienne Pallier
$ python -V
242 9 Etienne Pallier
Python 3.5.1
243 9 Etienne Pallier
</pre>
244 9 Etienne Pallier
245 46 Etienne Pallier
Go into the install/ folder:
246 46 Etienne Pallier
<pre>
247 46 Etienne Pallier
$ cd .../PYROS/install/
248 46 Etienne Pallier
</pre>
249 1 Etienne Pallier
250 47 Etienne Pallier
Install the needed python packages:
251 9 Etienne Pallier
<pre>
252 9 Etienne Pallier
$ pip install -r REQUIREMENTS.txt
253 1 Etienne Pallier
</pre>
254 9 Etienne Pallier
255 47 Etienne Pallier
If things go wrong, then install the needed packages one by one :
256 9 Etienne Pallier
257 9 Etienne Pallier
  * *Install Django* :
258 9 Etienne Pallier
<pre>
259 9 Etienne Pallier
$ pip install django
260 9 Etienne Pallier
Collecting django
261 9 Etienne Pallier
  Downloading Django-1.9.4-py2.py3-none-any.whl (6.6MB)
262 9 Etienne Pallier
Installing collected packages: django
263 9 Etienne Pallier
Successfully installed django-1.9.4
264 9 Etienne Pallier
265 9 Etienne Pallier
$ pip install django-admin-tools
266 9 Etienne Pallier
Collecting django-admin-tools
267 9 Etienne Pallier
  Downloading django_admin_tools-0.7.2-py2.py3-none-any.whl (289kB)
268 9 Etienne Pallier
Installing collected packages: django-admin-tools
269 9 Etienne Pallier
Successfully installed django-admin-tools-0.7.2
270 9 Etienne Pallier
271 9 Etienne Pallier
$ pip install django-debug-toolbar
272 9 Etienne Pallier
Collecting django-debug-toolbar
273 9 Etienne Pallier
  Downloading django_debug_toolbar-1.4-py2.py3-none-any.whl (212kB)
274 9 Etienne Pallier
Requirement already satisfied (use --upgrade to upgrade): Django>=1.7 in ./venv_py35_pyros/lib/python3.5/site-packages (from django-debug-toolbar)
275 9 Etienne Pallier
Collecting sqlparse (from django-debug-toolbar)
276 9 Etienne Pallier
  Downloading sqlparse-0.1.19.tar.gz (58kB)
277 9 Etienne Pallier
Building wheels for collected packages: sqlparse
278 9 Etienne Pallier
  Running setup.py bdist_wheel for sqlparse ... done
279 9 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/7b/d4/72/6011bb100dd5fc213164e4bbee13d4e03261dd54ce6a5de6b8
280 9 Etienne Pallier
Successfully built sqlparse
281 9 Etienne Pallier
Installing collected packages: sqlparse, django-debug-toolbar
282 9 Etienne Pallier
Successfully installed django-debug-toolbar-1.4 sqlparse-0.1.19
283 9 Etienne Pallier
284 9 Etienne Pallier
$ pip install django-extensions
285 9 Etienne Pallier
Collecting django-extensions
286 9 Etienne Pallier
  Downloading django_extensions-1.6.1-py2.py3-none-any.whl (202kB)
287 9 Etienne Pallier
Collecting six>=1.2 (from django-extensions)
288 9 Etienne Pallier
  Downloading six-1.10.0-py2.py3-none-any.whl
289 9 Etienne Pallier
Installing collected packages: six, django-extensions
290 9 Etienne Pallier
Successfully installed django-extensions-1.6.1 six-1.10.0
291 9 Etienne Pallier
292 9 Etienne Pallier
$ pip install django-suit
293 9 Etienne Pallier
Collecting django-suit
294 9 Etienne Pallier
  Downloading django-suit-0.2.18.tar.gz (587kB)
295 9 Etienne Pallier
Building wheels for collected packages: django-suit
296 9 Etienne Pallier
  Running setup.py bdist_wheel for django-suit ... done
297 9 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/12/8b/9a/e02ab0ad9229881638aa040d47d77c8f562999533811927d41
298 9 Etienne Pallier
Successfully built django-suit
299 9 Etienne Pallier
Installing collected packages: django-suit
300 9 Etienne Pallier
Successfully installed django-suit-0.2.18
301 9 Etienne Pallier
302 9 Etienne Pallier
</pre>
303 9 Etienne Pallier
304 30 Paul Carensac
  * *Install the django boostrap css package* :
305 30 Paul Carensac
<pre>
306 30 Paul Carensac
$ pip install django-bootstrap3
307 30 Paul Carensac
</pre>
308 30 Paul Carensac
==> You need to add 'bootstrap3' in settings.py -> INSTALLED_APPS
309 30 Paul Carensac
310 9 Etienne Pallier
  * *Install the web application server gunicorn (will be used in production instead of the dev django web server)* :
311 9 Etienne Pallier
<pre>
312 9 Etienne Pallier
$ pip install gunicorn
313 9 Etienne Pallier
Collecting gunicorn
314 9 Etienne Pallier
  Downloading gunicorn-19.4.5-py2.py3-none-any.whl (112kB)
315 9 Etienne Pallier
Installing collected packages: gunicorn
316 9 Etienne Pallier
Successfully installed gunicorn-19.4.5
317 9 Etienne Pallier
</pre>
318 1 Etienne Pallier
319 30 Paul Carensac
  * *Install the python mysql client* (not needed if you want to use sqlite):
320 9 Etienne Pallier
<pre>
321 9 Etienne Pallier
$ pip install mysqlclient
322 9 Etienne Pallier
...
323 9 Etienne Pallier
</pre>
324 9 Etienne Pallier
325 9 Etienne Pallier
   * => Issue under Mac OS X:
326 9 Etienne Pallier
<pre>
327 9 Etienne Pallier
$ pip install mysqlclient
328 9 Etienne Pallier
Collecting mysqlclient
329 9 Etienne Pallier
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
330 9 Etienne Pallier
Building wheels for collected packages: mysqlclient
331 9 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... error
332 9 Etienne Pallier
333 9 Etienne Pallier
  ----------------------------------------
334 9 Etienne Pallier
  Failed building wheel for mysqlclient
335 9 Etienne Pallier
  Running setup.py clean for mysqlclient
336 9 Etienne Pallier
Failed to build mysqlclient
337 9 Etienne Pallier
Installing collected packages: mysqlclient
338 9 Etienne Pallier
  Running setup.py install for mysqlclient ... done
339 9 Etienne Pallier
Successfully installed mysqlclient-1.3.7
340 9 Etienne Pallier
341 9 Etienne Pallier
BOUH !!!
342 9 Etienne Pallier
343 9 Etienne Pallier
$ pip install --upgrade wheel
344 9 Etienne Pallier
Collecting wheel
345 9 Etienne Pallier
  Downloading wheel-0.29.0-py2.py3-none-any.whl (66kB)
346 9 Etienne Pallier
Installing collected packages: wheel
347 9 Etienne Pallier
  Found existing installation: wheel 0.24.0
348 9 Etienne Pallier
    Uninstalling wheel-0.24.0:
349 9 Etienne Pallier
      Successfully uninstalled wheel-0.24.0
350 9 Etienne Pallier
Successfully installed wheel-0.29.0
351 9 Etienne Pallier
352 9 Etienne Pallier
$ pip uninstall mysqlclient
353 9 Etienne Pallier
354 9 Etienne Pallier
$ pip install mysqlclient
355 9 Etienne Pallier
Collecting mysqlclient
356 9 Etienne Pallier
  Using cached mysqlclient-1.3.7.tar.gz
357 9 Etienne Pallier
Building wheels for collected packages: mysqlclient
358 9 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... done
359 9 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/9b/06/50/d11418c26cf8f2156b13d4363b5afde8e7e75ebb8540d0228d
360 9 Etienne Pallier
Successfully built mysqlclient
361 9 Etienne Pallier
Installing collected packages: mysqlclient
362 9 Etienne Pallier
Successfully installed mysqlclient-1.3.7
363 9 Etienne Pallier
364 9 Etienne Pallier
YES !!!
365 9 Etienne Pallier
366 9 Etienne Pallier
</pre>
367 9 Etienne Pallier
368 9 Etienne Pallier
   * => Issues under Ubuntu:
369 9 Etienne Pallier
<pre>
370 9 Etienne Pallier
$ pip install mysqlclient
371 9 Etienne Pallier
Collecting mysqlclient
372 9 Etienne Pallier
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
373 9 Etienne Pallier
    Complete output from command python setup.py egg_info:
374 9 Etienne Pallier
    /bin/sh: 1: mysql_config: not found
375 9 Etienne Pallier
    Traceback (most recent call last):
376 9 Etienne Pallier
      File "<string>", line 1, in <module>
377 9 Etienne Pallier
    [...]
378 9 Etienne Pallier
    ----------------------------------------
379 9 Etienne Pallier
Command "python setup.py egg_info" failed with error code 1 in /tmp/pip-build-q6j4inuz/mysqlclient/
380 9 Etienne Pallier
381 9 Etienne Pallier
BOUH !!!
382 9 Etienne Pallier
383 9 Etienne Pallier
$ sudo apt-get install libmysqlclient-dev
384 9 Etienne Pallier
385 9 Etienne Pallier
$ pip install mysqlclient
386 9 Etienne Pallier
Collecting mysqlclient
387 9 Etienne Pallier
  Using cached mysqlclient-1.3.7.tar.gz
388 9 Etienne Pallier
Building wheels for collected packages: mysqlclient
389 9 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... error
390 9 Etienne Pallier
391 9 Etienne Pallier
    _mysql.c:40:20: fatal error: Python.h: No such file or directory
392 9 Etienne Pallier
     #include "Python.h"
393 9 Etienne Pallier
                        ^
394 9 Etienne Pallier
    compilation terminated.
395 9 Etienne Pallier
    error: command 'x86_64-linux-gnu-gcc' failed with exit status 1
396 9 Etienne Pallier
    
397 9 Etienne Pallier
    ----------------------------------------
398 9 Etienne Pallier
Command "/home/carens_p/pyros/venv_py35_pyros/bin/python3.5 -u -c "import setuptools, tokenize;__file__='/tmp/pip-build-k3klv92j/mysqlclient/setup.py';exec(compile(getattr(tokenize, 'open', open)(__file__).read().replace('\r\n', '\n'), __file__, 'exec'))" install --record /tmp/pip-gz242xxs-record/install-record.txt --single-version-externally-managed --compile --install-headers /home/carens_p/pyros/venv_py35_pyros/include/site/python3.5/mysqlclient" failed with error code 1 in /tmp/pip-build-k3klv92j/mysqlclient/
399 9 Etienne Pallier
400 9 Etienne Pallier
BOUH !!!
401 9 Etienne Pallier
402 9 Etienne Pallier
$ sudo apt-get install python3.5-dev
403 9 Etienne Pallier
404 9 Etienne Pallier
$ pip install mysqlclient
405 9 Etienne Pallier
406 9 Etienne Pallier
YES !!!
407 9 Etienne Pallier
408 1 Etienne Pallier
</pre>
409 9 Etienne Pallier
410 30 Paul Carensac
   * => Issue under Windows
411 9 Etienne Pallier
<pre>
412 9 Etienne Pallier
Same message as the issue for Mac.
413 9 Etienne Pallier
414 9 Etienne Pallier
Go to http://www.lfd.uci.edu/~gohlke/pythonlibs/#mysqlclient to download the newest mysqlclient wheel
415 9 Etienne Pallier
416 9 Etienne Pallier
$ pip install path\to\mysqlclient\wheel
417 9 Etienne Pallier
418 9 Etienne Pallier
No need to redo "pip install mysqlclient"
419 9 Etienne Pallier
</pre>
420 9 Etienne Pallier
421 9 Etienne Pallier
---
422 9 Etienne Pallier
423 9 Etienne Pallier
h3. (Eclipse only) Set the Python3 virtual environment as the project interpreter
424 9 Etienne Pallier
425 9 Etienne Pallier
clic droit sur projet / Properties / PyDev - Interpreter/Grammar :
426 9 Etienne Pallier
Grammar version : 3
427 9 Etienne Pallier
428 9 Etienne Pallier
Interpreter : click on « click here to configure an interpreter not listed »
429 9 Etienne Pallier
430 32 Etienne Pallier
click on « New... » :
431 9 Etienne Pallier
- Interpreter name : venv_py35_pyros
432 9 Etienne Pallier
- Interpreter executable : click on « Browse »
433 32 Etienne Pallier
	Select your virtualenv python35 executable (private/venv_py35_pyros/bin/python3.5)
434 1 Etienne Pallier
	click OK
435 1 Etienne Pallier
436 32 Etienne Pallier
*Now, a last thing to do so that Pydev finds Django:*
437 32 Etienne Pallier
438 32 Etienne Pallier
In the Python interpreters list, select your virtual env (venv_py35_pyros)
439 32 Etienne Pallier
440 32 Etienne Pallier
Click on the tab "Libraries"
441 32 Etienne Pallier
442 32 Etienne Pallier
clic on 'New folder', then select your virtualenv's lib/python3.5/site-packages folder
443 32 Etienne Pallier
444 32 Etienne Pallier
OK
445 32 Etienne Pallier
446 9 Etienne Pallier
Interpreter: select now venv_py35_pyros from the list
447 32 Etienne Pallier
448 32 Etienne Pallier
OK
449 9 Etienne Pallier
450 9 Etienne Pallier
---
451 9 Etienne Pallier
452 9 Etienne Pallier
h3. Run the project
453 9 Etienne Pallier
454 9 Etienne Pallier
TODO: more details... (notamment sur localhost:8000/admin)
455 9 Etienne Pallier
456 9 Etienne Pallier
h4. From the terminal
457 9 Etienne Pallier
458 9 Etienne Pallier
<pre>
459 9 Etienne Pallier
460 9 Etienne Pallier
$ cd src/
461 9 Etienne Pallier
462 9 Etienne Pallier
$ ./manage.py runserver
463 9 Etienne Pallier
(or gunicorn pyros.wsgi)
464 9 Etienne Pallier
==> http://localhost:8000
465 9 Etienne Pallier
...
466 9 Etienne Pallier
...
467 9 Etienne Pallier
Ctrl-c
468 9 Etienne Pallier
469 9 Etienne Pallier
</pre>
470 9 Etienne Pallier
471 9 Etienne Pallier
h4. From Eclipse
472 9 Etienne Pallier
473 9 Etienne Pallier
Right clic on project -> Django/Custom command/runserver
474 9 Etienne Pallier
475 9 Etienne Pallier
Error on Ubuntu :
476 9 Etienne Pallier
477 9 Etienne Pallier
<pre>
478 9 Etienne Pallier
479 9 Etienne Pallier
Traceback (most recent call last):
480 9 Etienne Pallier
  File "/home/carens_p/git/pyros/src/manage.py", line 8, in <module>
481 9 Etienne Pallier
    from django.core.management import execute_from_command_line
482 9 Etienne Pallier
ImportError: No module named 'django'
483 9 Etienne Pallier
484 9 Etienne Pallier
</pre>
485 9 Etienne Pallier
486 9 Etienne Pallier
Project -> Properties -> Pydev interpreter -> Clic here to configure an interpreter not listed
487 9 Etienne Pallier
488 9 Etienne Pallier
select venv_py35_pyros
489 9 Etienne Pallier
490 9 Etienne Pallier
In Libraries, clic on 'New folder', then select your virtualenv's lib/python3.5/site-packages folder.
491 9 Etienne Pallier
492 9 Etienne Pallier
OK -> re-select venv_py35_pyros in 'Interpreter' dropdown menu
493 9 Etienne Pallier
494 9 Etienne Pallier
Then right clic on project -> Django/Custom command/runserver
495 9 Etienne Pallier
496 9 Etienne Pallier
check http://localhost:8000/
497 9 Etienne Pallier
498 9 Etienne Pallier
499 9 Etienne Pallier
---
500 17 Etienne Pallier
501 17 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}IV - TEST%
502 17 Etienne Pallier
503 25 Paul Carensac
Tests are classes declared in all apps' test.py file. The test classes inherit from django.test.TestCase
504 17 Etienne Pallier
505 17 Etienne Pallier
You can run the tests suite, just to be sure that the software is well installed.
506 17 Etienne Pallier
507 19 Etienne Pallier
h3. From Terminal
508 19 Etienne Pallier
509 19 Etienne Pallier
510 1 Etienne Pallier
<pre>
511 20 Etienne Pallier
$ cd src/
512 20 Etienne Pallier
513 20 Etienne Pallier
$ ./manage.py test
514 21 Etienne Pallier
515 21 Etienne Pallier
Ran 5 tests in 0.093s
516 21 Etienne Pallier
517 21 Etienne Pallier
OK
518 17 Etienne Pallier
</pre>
519 19 Etienne Pallier
520 19 Etienne Pallier
h3. From Eclipse:
521 1 Etienne Pallier
522 25 Paul Carensac
* Right-clic on the project / Django / Run Django tests
523 25 Paul Carensac
524 25 Paul Carensac
* Right-clic on the project / Django / Custom command / ...
525 25 Paul Carensac
526 27 Paul Carensac
h3. Custom commands :
527 27 Paul Carensac
528 25 Paul Carensac
$ [./manage.py] test app.tests                           # Run tests for the application 'app'
529 25 Paul Carensac
$ [./manage.py] test app.tests.ModelTests                # Run test methods declared in the class app.tests.ModelTests
530 25 Paul Carensac
$ [./manage.py] test app.tests.ModelTests.test_method    # Only run the method test_method declared in app.tests.ModelTests
531 33 Etienne Pallier
532 33 Etienne Pallier
533 33 Etienne Pallier
---
534 33 Etienne Pallier
535 33 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}NOTES FOR ECLIPSE USERS%
536 35 Etienne Pallier
537 35 Etienne Pallier
0) Install Eclipse (if necessary)
538 35 Etienne Pallier
539 35 Etienne Pallier
Get the Eclipse version for Php
540 35 Etienne Pallier
541 35 Etienne Pallier
Install the plug-in pydev (via install new software, add http://pydev.org/updates)
542 35 Etienne Pallier
543 35 Etienne Pallier
Install the django template editor (via install new software, add http://eclipse.kacprzak.org/updates)
544 35 Etienne Pallier
545 35 Etienne Pallier
1) Deactivate CA certificate verification
546 35 Etienne Pallier
547 35 Etienne Pallier
Window -> Preferences -> Team -> git -> configuration -> Add entry
548 35 Etienne Pallier
549 35 Etienne Pallier
Key = http.sslVerify
550 35 Etienne Pallier
Value = false
551 35 Etienne Pallier
552 35 Etienne Pallier
2) Fetch the project
553 35 Etienne Pallier
554 35 Etienne Pallier
File/Import project from git
555 35 Etienne Pallier
556 35 Etienne Pallier
Select repository source: Clone URI: https://gitlab.irap.omp.eu/epallier/pyros.git
557 35 Etienne Pallier
558 35 Etienne Pallier
Directory: 
559 35 Etienne Pallier
par défaut, il propose : /Users/epallier/git/pyros
560 35 Etienne Pallier
mais on peut le mettre ailleurs (c'est ce que j'ai fait)
561 35 Etienne Pallier
562 35 Etienne Pallier
initial branch: master
563 35 Etienne Pallier
remote name: origin
564 35 Etienne Pallier
565 35 Etienne Pallier
Import as general project
566 35 Etienne Pallier
567 35 Etienne Pallier
Project name: PYROS
568 35 Etienne Pallier
569 35 Etienne Pallier
570 35 Etienne Pallier
3) Configure the project
571 35 Etienne Pallier
572 35 Etienne Pallier
The project is created. Now, you have to set it as a «PyDev » and a « Django » project.
573 35 Etienne Pallier
574 35 Etienne Pallier
clic droit sur le projet / PyDev / set as a PyDev project
575 35 Etienne Pallier
576 35 Etienne Pallier
clic droit sur le projet / PyDev / set as a Django project
577 35 Etienne Pallier
578 35 Etienne Pallier
clic droit sur le projet : on doit maintenant avoir un sous-menu Django
579 35 Etienne Pallier
580 35 Etienne Pallier
clic droit sur le dossier src / PyDev / set as source folder (add to PYTHONPATH)
581 35 Etienne Pallier
582 35 Etienne Pallier
clic droit sur projet / Properties / Pydev-Django :
583 35 Etienne Pallier
  - Django manage.py : src/manage.py
584 35 Etienne Pallier
  - Django settings module : pyros.settings
585 35 Etienne Pallier
586 35 Etienne Pallier
587 35 Etienne Pallier
4) Set Code style
588 35 Etienne Pallier
589 35 Etienne Pallier
Window/Preferences : Pydev / Editor
590 35 Etienne Pallier
- Auto Imports : uncheck « Do auto import »
591 35 Etienne Pallier
- Code style:
592 35 Etienne Pallier
	- Locals … : camelCase
593 35 Etienne Pallier
	- Methods : camelCase() with first lower
594 35 Etienne Pallier
- Code style / Code Formatter: activer « use autopep8.py for code formatting »
595 35 Etienne Pallier
- Tabs : Tab length : 4
596 35 Etienne Pallier
597 35 Etienne Pallier
(
598 35 Etienne Pallier
il faudra aussi faire un peu plus loin : 
599 35 Etienne Pallier
https://projects.irap.omp.eu/projects/pyros/wiki/Project_Installation#Eclipse-only-Set-the-Python3-virtual-environment-as-the-project-interpreter
600 35 Etienne Pallier
)