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