Blame view

pyros.py 34.4 KB
5c5b079e   Etienne Pallier   Requirements harm...
1
#!/usr/bin/env python3
20ed1e7a   Etienne Pallier   bugfixed time sav...
2

4816e86b   Jeremy   removed *.sh *.ba...
3
4
5
6
7
8
9
import sys
import os
import subprocess
import platform
import fileinput
import argparse
import time
bca9a283   Jeremy   Reworked the sche...
10
import signal
4816e86b   Jeremy   removed *.sh *.ba...
11

cd0149f5   Etienne Pallier   progress made for...
12

d1e6236c   Etienne Pallier   Refactorized pyro...
13
DEBUG = True
a64f430a   Unknown   Adding argument t...
14
SIMULATOR_CONFIG_FILE = "conf.json" #default config file
4816e86b   Jeremy   removed *.sh *.ba...
15

257abe9b   Jeremy   Added comments
16
17
18
19
20
'''
    Pyros Manager, able to launch processes and handle all project commands
'''


4816e86b   Jeremy   removed *.sh *.ba...
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
class Utils:
    system = platform.system()
    columns = 100
    row = 1000
    disp = True

    def __init__(self):
        if (platform.system() != 'Windows'):
            try:
                rows, columns = os.popen('stty size', 'r').read().split()
                self.columns = int(columns)
            except:
                self.columns = 100
                if DEBUG:
                    print("Could not get terminal size")

    def printFullTerm(self, color, string):
        value = int(self.columns / 2 - len(string) / 2)
        self.printColor(color, "-" * value, eol='')
        self.printColor(color, string, eol='')
        value += len(string)
        self.printColor(color, "-" * (self.columns - value))
        return 0

    def changeDirectory(self, path):
        if DEBUG:
            print("Moving to : " + path)
        os.chdir(path)
        if DEBUG:
            print("Current directory : " + str(os.getcwd()))
        return 0

0716eccb   Etienne Pallier   Bye Bye Celery (1...
53
    def replacePatternInFile(self, pattern, replacement, file_path):
737529b0   Etienne Pallier   bugfixes and impr...
54
55
56
        #try:
        with fileinput.FileInput(file_path, inplace=True, backup='.bak') as file:
            for line in file:
0716eccb   Etienne Pallier   Bye Bye Celery (1...
57
                print(line.replace(pattern, replacement), end='')
737529b0   Etienne Pallier   bugfixes and impr...
58
        '''
4816e86b   Jeremy   removed *.sh *.ba...
59
60
61
        except:
            return 1
        return 0
737529b0   Etienne Pallier   bugfixes and impr...
62
63
        '''
        # Now, check that replacement has been done or else ERROR !!!
737529b0   Etienne Pallier   bugfixes and impr...
64
65
66
67
        FOUND=False
        #with fileinput.FileInput(file_path) as file:
        with open(file_path) as file:
            for line in file:
0716eccb   Etienne Pallier   Bye Bye Celery (1...
68
69
                #if replacement in line:
                if line.startswith(replacement):
737529b0   Etienne Pallier   bugfixes and impr...
70
71
72
                    FOUND = True
                    break
        #if FOUND: print("pattern "+pattern+" found in file "+file_path)
0716eccb   Etienne Pallier   Bye Bye Celery (1...
73
        if not FOUND: raise(Exception("pattern "+replacement+" not found in file "+file_path))
737529b0   Etienne Pallier   bugfixes and impr...
74

4816e86b   Jeremy   removed *.sh *.ba...
75
76
77
78
79
80
81
82
83
84
85
86
87
88

    def printColor(self, color, message, file=sys.stdout, eol=os.linesep, forced=False):
        if (self.disp == False and forced == False):
            return 0
        if (self.system == 'Windows'):
            print(message, file=file, end=eol)
        else:
            print(color + message + Colors.ENDC, file=file, end=eol)
        return 0

    def askQuestion(self, message, default = ""):
        self.printColor(Colors.BLUE, message, forced=True)
        self.printColor(Colors.BOLD, "Answer (default="+default+"): ", eol='', forced=True)
        sys.stdout.flush()
27e81f38   jeremy   Update windows
89
        ret = sys.stdin.readline().replace('\n', '').replace('\r', '')
4816e86b   Jeremy   removed *.sh *.ba...
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
        if ret == "":
            return default
        return ret

    def sleep(self, t):
        time.sleep(t)
        return 0

'''
    Manager class : manager of your project
'''


class AManager(Utils):
    path = os.path.realpath(__file__)
    path_dir = os.getcwd()
    path_dir_file = os.path.dirname(os.path.realpath(__file__))
    python_path = sys.executable
    python_version = sys.version_info

    bin_dir = ""
4816e86b   Jeremy   removed *.sh *.ba...
111
112
113
114
115
116
117
118
119
120
    venv_pip = "pip"
    venv_bin = "python"
    wait = True
    current_command = ""
    config = None
    commandMatcher = {}
    commandDescription = {}
    commands = []
    errors = {}
    executed = {}
bca9a283   Jeremy   Reworked the sche...
121
    subproc = []
4816e86b   Jeremy   removed *.sh *.ba...
122
123
124
125
126
127
128
129

    def __init__(self, param):
        super(AManager, self).__init__()
        self.wait = param.getWait()
        self.commands = param.getCommandList()
        self.disp = param.getPrint()
        config = param.getConfig()
        self.config = config
bca9a283   Jeremy   Reworked the sche...
130
        signal.signal(signal.SIGINT, self.signal_handler)
4816e86b   Jeremy   removed *.sh *.ba...
131
132
133
134
135
136
137

        self.changeDirectory(self.path_dir_file)

        if self.system == 'Windows':
            self.bin_dir = "Scripts"
            self.bin_name = "python.exe"
            self.pip_name = "pip.exe"
4816e86b   Jeremy   removed *.sh *.ba...
138
139
140
141
        else:
            self.bin_dir = "bin"
            self.bin_name = "python"
            self.pip_name = "pip"
4816e86b   Jeremy   removed *.sh *.ba...
142
143
        self.venv_pip = self.path_dir_file + os.sep + config["path"] + os.sep + config["env"] + os.sep + self.bin_dir + os.sep + self.pip_name
        self.venv_bin = self.path_dir_file + os.sep + config["path"] + os.sep + config["env"] + os.sep + self.bin_dir + os.sep + self.bin_name
4816e86b   Jeremy   removed *.sh *.ba...
144
145
146
147
148

    def help(self):
        print("This function must be implemented")
        raise(NotImplementedError("Function not implemented"))

54467c54   Etienne Pallier   refactorisation
149

0716eccb   Etienne Pallier   Bye Bye Celery (1...
150
    def set_simulator_mode_to(self, set_it:bool):
54467c54   Etienne Pallier   refactorisation
151
152
        file_path = "pyros/settings.py"
        '''
54467c54   Etienne Pallier   refactorisation
153
154
        if simulator: self.replacePatternInFile("SIMULATOR = False", "SIMULATOR = True", file_path)
        '''
0716eccb   Etienne Pallier   Bye Bye Celery (1...
155
        self.replacePatternInFile("SIMULATOR = "+str(not set_it), "SIMULATOR = "+str(set_it), file_path)
54467c54   Etienne Pallier   refactorisation
156
157


bca9a283   Jeremy   Reworked the sche...
158
159
    def signal_handler(self, signal, frame):
        self.printFullTerm(Colors.WARNING, "Ctrl-c catched")
0716eccb   Etienne Pallier   Bye Bye Celery (1...
160
        self.set_simulator_mode_to(False)
bca9a283   Jeremy   Reworked the sche...
161
162
163
164
165
166
167
        for p in self.subproc:
            proc, name = p
            self.printColor(Colors.BLUE, "Killing process " + str(name))
            proc.kill()
        self.printFullTerm(Colors.WARNING, "Exiting")
        sys.exit(0)

4816e86b   Jeremy   removed *.sh *.ba...
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
    def addExecuted(self, src, message):
        if (src in self.executed):
            self.executed[src].append(str(message))
        else:
            self.executed[src] = [str(message)]
        return 0

    def addError(self, src, message):
        if (src in self.errors):
            self.errors[src].append(str(message))
        else:
            self.errors[src] = [str(message)]
        return 0

    def execProcess(self, command):
        self.printFullTerm(Colors.BLUE, "Executing command [" + command + "]")
        process = subprocess.Popen(command, shell=True)
        process.wait()
        if process.returncode == 0:
            self.printFullTerm(Colors.GREEN, "Process executed successfully")
            self.addExecuted(self.current_command, command)
        else:
            self.printFullTerm(Colors.WARNING, "Process execution failed")
            self.addError(self.current_command, command)
        return process.returncode

bca9a283   Jeremy   Reworked the sche...
194
195
196
197
198
    def execProcessSilent(self, command):
        process = subprocess.Popen(command, shell=True)
        process.wait()
        return process.returncode

4816e86b   Jeremy   removed *.sh *.ba...
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
    def execProcessFromVenv(self, command):
        args = command.split()
        self.printFullTerm(Colors.BLUE, "Executing command from venv [" + str(' '.join(args[1:])) + "]")
        process = subprocess.Popen(args)
        process.wait()
        if process.returncode == 0:
            self.printFullTerm(Colors.GREEN, "Process executed successfully")
            self.addExecuted(self.current_command, str(' '.join(args[1:])))
        else:
            self.printFullTerm(Colors.WARNING, "Process execution failed")
            self.addError(self.current_command, str(' '.join(args[1:])))
        return process.returncode

    def execProcessAsync(self, command):
        self.printFullTerm(Colors.BLUE, "Executing command [" + command + "]")
bca9a283   Jeremy   Reworked the sche...
214
215
        p = subprocess.Popen(command, shell=True)
        self.subproc.append((p, command))
4816e86b   Jeremy   removed *.sh *.ba...
216
217
        self.printFullTerm(Colors.GREEN, "Process launched successfully")
        self.addExecuted(self.current_command, command)
bca9a283   Jeremy   Reworked the sche...
218
        return p
4816e86b   Jeremy   removed *.sh *.ba...
219

bca9a283   Jeremy   Reworked the sche...
220
    def execProcessFromVenvAsync(self, command: str):
4816e86b   Jeremy   removed *.sh *.ba...
221
222
        args = command.split()
        self.printFullTerm(Colors.BLUE, "Executing command from venv [" + str(' '.join(args[1:])) + "]")
bca9a283   Jeremy   Reworked the sche...
223
224
        p = subprocess.Popen(args)
        self.subproc.append((p, ' '.join(args[1:])))
4816e86b   Jeremy   removed *.sh *.ba...
225
226
        self.printFullTerm(Colors.GREEN, "Process launched successfully")
        self.addExecuted(self.current_command, str(' '.join(args[1:])))
bca9a283   Jeremy   Reworked the sche...
227
228
229
230
231
232
233
        return p

    def waitProcesses(self):
        if (self.wait):
            for p in self.subproc:
                proc, name = p
                proc.wait()
4816e86b   Jeremy   removed *.sh *.ba...
234
235
236
237
        return 0

    def end(self):
        count = 0
bca9a283   Jeremy   Reworked the sche...
238
        self.waitProcesses()
4816e86b   Jeremy   removed *.sh *.ba...
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
        self.printFullTerm(Colors.WARNING, "Summary")
        self.printColor(Colors.GREEN, "Success : ")
        for command, valid in self.executed.items():
            if not valid:
                self.printColor(Colors.BLUE, "\t- Command : " + command + " success !")
            else:
                self.printColor(Colors.WARNING, "\t- In commmand : " + command)
                for exe in valid:
                    self.printColor(Colors.GREEN, "\t\t - Command : " + exe + " success !")
        self.printColor(Colors.FAIL, "Errors : ")
        if not self.errors:
            self.printColor(Colors.GREEN, "\tNone")
        for command, items in self.errors.items():
            count += 1
            if (not items):
                self.printColor(Colors.FAIL, "Command : " + command + " failed !")
            else:
                self.printColor(Colors.WARNING, "\t- In commmand : " + command)
                for exe in items:
                    self.printColor(Colors.FAIL, "\t\t - Command : " + exe)
        return count

    def exec(self):
        if (not self.commands):
            self.commandMatcher["help"]()
            return 0
        for command in self.commands:
            self.current_command = command
            if command in self.commandMatcher:
                self.commandMatcher[command]()
            else:
                self.addError(str(command), "invalid command")
        return self.end()

    def logError(self, message):
        self.printColor(Colors.FAIL, "Pyros : An error occurred [" + message + "]", file=sys.stderr)
        return 0

257abe9b   Jeremy   Added comments
277
278
279
280
'''
    Config file representation (able to parse and give informations)
'''

4816e86b   Jeremy   removed *.sh *.ba...
281
282

class Config:
7db4ab5f   Unknown   small change in h...
283
    __parser = argparse.ArgumentParser("Project Pyros")
4816e86b   Jeremy   removed *.sh *.ba...
284
285
286
287
288
289
290
291
292
293
    __content = {
        "path": "private",
        "env": "venv_py3_pyros"
    }
    __wait = True
    __print = True
    usage = ""
    __command_list = []

    def __init__(self):
a64f430a   Unknown   Adding argument t...
294
        self.__parser.add_argument("command", nargs='*', default="help", help="The command you want to execute (default=help)")
4816e86b   Jeremy   removed *.sh *.ba...
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
        self.__parser.add_argument("--env", help="Your environment directory name default=venv")
        self.__parser.add_argument("--path", help="Path to the virtual env (from the source file directory) (default=private)")
        self.__parser.add_argument("--nowait", action='store_true', help="Don't wait the end of a program")
        self.__parser.add_argument("--noprint", action='store_true', help="Won't print")
        self.usage = self.__parser.format_usage()

    def parse(self):
        try:
            res = self.__parser.parse_args(), self.__parser.format_usage()
            return (res)
        except SystemExit as e:
            # print(e, file=sys.stderr)
            sys.exit(1)

    def parseConf(self):
        res, usage = self.parse()
        try:
            if (res.env):
                self.__content["env"] = res.env
            if (res.path):
                self.__content["path"] = res.path
            if (res.nowait):
                self.__wait = False
            if (res.noprint):
                self.__print = False
a64f430a   Unknown   Adding argument t...
320
            self.__command_list.append(res.command[0])
b4e8963c   Etienne Pallier   Each agent (envmo...
321
322
            #return 
            return True
4816e86b   Jeremy   removed *.sh *.ba...
323
324
        except Exception as e:
            print(e, file=sys.stderr)
b4e8963c   Etienne Pallier   Each agent (envmo...
325
326
            #return 1
            return False
4816e86b   Jeremy   removed *.sh *.ba...
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400

    def getPath(self):
        return self.__content["path"]

    def getEnv(self):
        return self.__content["env"]

    def getWait(self):
        return self.__wait

    def getPrint(self):
        return self.__print

    def setPrint(self, value):
        self.__print = value
        return 0

    def setWait(self, value):
        self.__wait = value
        return 0

    def getCommandList(self):
        return self.__command_list

    def printUsage(self):
        print(self.usage, file=sys.stderr)

    def addConf(self, key, value):
        if isinstance(key, str) and isinstance(value, str):
            self.__content[key] = value
            return 0
        return 1

    def setPath(self, path):
        if (os.path.isdir(path)):
            if (path == ""):
                path = "."
            self.__content["path"] = path
            return 0
        return 1

    def setEnvName(self, name):
        self.__content["env"] = name
        return 0

    def getConfig(self):
        return self.__content


'''
    Color class
'''


class Colors:
    HEADER = '\033[95m'
    BLUE = '\033[94m'
    GREEN = '\033[92m'
    WARNING = '\033[93m'
    FAIL = '\033[91m'
    ENDC = '\033[0m'
    BOLD = '\033[1m'
    UNDERLINE = '\033[4m'


'''
    Pyros class
'''


class Pyros(AManager):
    help_message = "python neo.py"
    init_fixture = "initial_fixture.json"

ff448d43   Jeremy   Update
401
402
403
404
405
406
407
408
409
410
411
412
    def signal_handler(self, signal, frame):
        self.printFullTerm(Colors.WARNING, "Ctrl-c catched")
        for p in self.subproc:
            proc, name = p
            self.printColor(Colors.BLUE, "Killing process " + str(name))
            proc.kill()
        if self.current_command == "simulator" or self.current_command == "simulator_development":
            self.changeDirectory(self.path_dir_file)
            self.kill_simulation()
        self.printFullTerm(Colors.WARNING, "Exiting")
        sys.exit(0)

4816e86b   Jeremy   removed *.sh *.ba...
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
    def install(self):
        if (self.system == "Windows"):
            self.execProcess("python install/install.py install")
        else:
            self.execProcess("python3 install/install.py install")
        return 0

    def update(self):
        if (self.system == "Windows"):
            self.execProcess("python install/install.py update")
        else:
            self.execProcess("python3 install/install.py update")
        return 0

    def server(self):
        self.changeDirectory("src")
        self.execProcessFromVenvAsync(self.venv_bin + " manage.py runserver")
        self.changeDirectory("..")
        return 0

    def clean(self):
        return self.clean_logs()

    def clean_logs(self):
        return self.execProcess("rm logs/*.log")

    def test(self):
4816e86b   Jeremy   removed *.sh *.ba...
440
        self.changeDirectory("src")
e573c1f1   Etienne Pallier   All unit tests no...
441
        ##self.execProcessFromVenv(self.venv_bin + " manage.py test")
4816e86b   Jeremy   removed *.sh *.ba...
442
443
        self.execProcessFromVenvAsync(self.venv_bin + " manage.py test")
        self.changeDirectory("..")
4816e86b   Jeremy   removed *.sh *.ba...
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
        return 0

    def migrate(self):
        self.changeDirectory("src")
        self.execProcessFromVenv(self.venv_bin + " manage.py migrate")
        self.changeDirectory("..")
        return 0

    def makemigrations(self):
        self.changeDirectory("src")
        self.execProcessFromVenv(self.venv_bin + " manage.py makemigrations")
        self.changeDirectory("..")
        return 0

    def help(self):
3b0ef1c7   Jeremy   Beautify help mes...
459
460
        count = 0
        self.printFullTerm(Colors.WARNING, "Help Message")
4816e86b   Jeremy   removed *.sh *.ba...
461
        for command, message in self.commandDescription.items():
3b0ef1c7   Jeremy   Beautify help mes...
462
463
464
465
466
            count += 1
            if (self.columns > 100):
                self.printColor(Colors.BLUE, "\t"+str(count)+(' ' if count < 10 else '')+": " + command + ": ", eol='')
            else:
                self.printColor(Colors.BLUE, "-> " + command + ": ", eol='')
4816e86b   Jeremy   removed *.sh *.ba...
467
468
469
470
            self.printColor(Colors.GREEN, message)
        return 0

    def updatedb(self):
4816e86b   Jeremy   removed *.sh *.ba...
471
        self.makemigrations()
3b0ef1c7   Jeremy   Beautify help mes...
472
        self.migrate()
4816e86b   Jeremy   removed *.sh *.ba...
473
474
        return 0

c53a13e0   Jeremy   Updating a lot of...
475
476
    def reset_config(self):
        self.changeDirectory("src")
0716eccb   Etienne Pallier   Bye Bye Celery (1...
477
        self.set_simulator_mode_to(False)
c53a13e0   Jeremy   Updating a lot of...
478
479
480
481
        self.addExecuted(self.current_command, "reset configuration")
        self.changeDirectory("..")
        return 0

f4dd5b4a   Unknown   merging pyros.py
482
483
484
485
486
487
488
489
    def unittest(self):
        #self.changeDirectory("src")
        apps = ['common', 'scheduler', 'routine_manager', 'user_manager', 'alert_manager.tests.TestStrategyChange']
        for app in apps:
            self.loaddata()
            self.changeDirectory("src")
            self.execProcessFromVenv(self.venv_bin + ' manage.py test ' + app)
            self.changeDirectory("..")
4816e86b   Jeremy   removed *.sh *.ba...
490
491
492
493
        return 0

    def test_all(self):
        self.unittest()
4816e86b   Jeremy   removed *.sh *.ba...
494
495
        return 0

d1e6236c   Etienne Pallier   Refactorized pyro...
496
    #TODO: mettre la fixture en date naive (sans time zone)
4816e86b   Jeremy   removed *.sh *.ba...
497
498
    def loaddata(self):
        self.changeDirectory("src")
3185a08a   Unknown   updating init_dat...
499
        self.execProcessFromVenv(self.venv_bin + " manage.py loaddata misc" + os.sep + "fixtures" + os.sep + self.init_fixture)
4816e86b   Jeremy   removed *.sh *.ba...
500
501
502
        self.changeDirectory("..")
        return 0

d1e6236c   Etienne Pallier   Refactorized pyro...
503

3b0ef1c7   Jeremy   Beautify help mes...
504
505
506
507
    def init_database(self):
        self.makemigrations()
        self.migrate()
        self.loaddata()
675fb3d5   Jeremy   Update scheduler ...
508
509
        return 0

3b0ef1c7   Jeremy   Beautify help mes...
510

b4e8963c   Etienne Pallier   Each agent (envmo...
511
512
513
514
515
516
517
518
519
520
521
522
    # Start the PyROS software

    # Start only the (django) Web server (pyros website)
    def start_web(self):
        self.start("web")
        #self.start(3)

    # Start only the agents (all of them)
    def start_agents(self):
        self.start("agents")

    # Start only 1 agent
40227fbd   Etienne Pallier   changed monitorin...
523
    def start_agent_monitoring(self):
b4e8963c   Etienne Pallier   Each agent (envmo...
524
525
526
527
528
529
530
531
532
        self.start("monitoring")
    def start_agent_majordome(self):
        self.start("majordome")
    def start_agent_alertmanager(self):
        self.start("alert_manager")
        
    # Start the PyROS software
    # By default (what=None), start everything : all the agents and also the web server (website, web viewing, for global monitoring)
    def start(self, what:str = None):
b70385ab   Etienne Pallier   bugfixing pyros s...
533
534
        #agents = ("alert_manager", "majordome", "monitoring")
        agents = ("majordome", "monitoring")
b4e8963c   Etienne Pallier   Each agent (envmo...
535
536
537
538
539
540
541
        '''
        what="monitoring"
        what="majordome"
        what="alert_manager"
        what="all"
        '''

b4e8963c   Etienne Pallier   Each agent (envmo...
542
543
544
545
546
547
548
549
        # Go into src/
        self.changeDirectory("src")
        #print("Current directory : " + str(os.getcwd()))

        # Start (Django) Web server (pyros website)
        if what=='web' or what is None:
            self.execProcessFromVenvAsync(self.venv_bin + " manage.py runserver")
            #self.changeDirectory("..")
40227fbd   Etienne Pallier   changed monitorin...
550

b4e8963c   Etienne Pallier   Each agent (envmo...
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
        # DJANGO setup
        ''' (optional)
        import sys
        sys.path.append('/PROJECTS/GFT/SOFT/PYROS_SOFT/PYROS201802/src')
        '''
        '''
        os.environ.setdefault("DJANGO_SETTINGS_MODULE", "src.pyros.settings")
        #os.environ['SECRET_KEY'] = 'abc'
        #os.environ['ENVIRONMENT'] = 'production'
        import django
        django.setup()
        '''

        # Start Agents
        '''            
        if agent=="majordome" or agent=="all":
            from majordome.tasks import Majordome
            Majordome().run()
        if agent=="alert_manager" or agent=="all":
            from alert_manager.tasks import AlertListener
            AlertListener().run()
        '''
        for agent in agents:
            if what==agent or what=="agents" or what is None:
                #os.chdir('src')
                '''
                from monitoring.tasks import Monitoring
                Monitoring().run()
                '''
                #self.changeDirectory("src/monitoring")
                #self.changeDirectory("src")
                self.changeDirectory(agent)
                self.execProcessFromVenvAsync(self.venv_bin + ' start_agent_'+agent+'.py')
737529b0   Etienne Pallier   bugfixes and impr...
584
585
586
587
588
                # Go back to src/
                self.changeDirectory('..')
                #os.chdir('..')
        # Go back to root folder (/)
        self.changeDirectory('..')
b4e8963c   Etienne Pallier   Each agent (envmo...
589
590
591


            
fd782a47   Etienne Pallier   refactorisations ...
592
    # Reset the database content
c72eb17a   Jeremy   Update celery task
593
594
    def reset_database_sim(self):
        self.changeDirectory("src")
0716eccb   Etienne Pallier   Bye Bye Celery (1...
595
        self.set_simulator_mode_to(True, False)
cd0149f5   Etienne Pallier   progress made for...
596
597
598
599
600
601
        '''
        Supprime toutes les données de la base de données 
        et réexécute tout gestionnaire de post-synchronisation. 
        La table contenant les informations d’application des migrations n’est pas effacée
        '''
        #TODO: remplacer par manage.py --noinput flush pour eviter le "echo yes"...
f79c72e7   Unknown   quickfix --noinpu...
602
        self.execProcess( self.venv_bin + " manage.py flush  --noinput")
0716eccb   Etienne Pallier   Bye Bye Celery (1...
603
        self.set_simulator_mode_to(True, False)
c72eb17a   Jeremy   Update celery task
604
605
        self.changeDirectory("..")

d1e6236c   Etienne Pallier   Refactorized pyro...
606

0716eccb   Etienne Pallier   Bye Bye Celery (1...
607
    # Simulation for the scheduler ONLY
fd782a47   Etienne Pallier   refactorisations ...
608
609
    def simulator_development(self):
        self.simulator(False)
d1e6236c   Etienne Pallier   Refactorized pyro...
610

05bdcc44   Etienne Pallier   BIG DEMO tests (s...
611
612
613
614
615
616
617
618
619
    '''
    (EP) utile pour le debug avec phpmyadmin pour remettre à zéro la bd pyros_test
    delete from plan;
    delete from album;
    delete from schedule_has_sequences;
    delete from schedule;
    delete from sequence;
    delete from request;
    '''
d1e6236c   Etienne Pallier   Refactorized pyro...
620

0716eccb   Etienne Pallier   Bye Bye Celery (1...
621
    # Simulation (by default, with ALL simulators)
fd782a47   Etienne Pallier   refactorisations ...
622
    def simulator(self, TOTAL=True):
4816e86b   Jeremy   removed *.sh *.ba...
623
        self.changeDirectory("src")
cd0149f5   Etienne Pallier   progress made for...
624

0716eccb   Etienne Pallier   Bye Bye Celery (1...
625
        # Set SIMULATOR mode ON
ff448d43   Jeremy   Update
626
        self.replacePatternInFile("SIMULATOR = False", "SIMULATOR = True", "pyros/settings.py")
cd0149f5   Etienne Pallier   progress made for...
627

075082e1   Etienne Pallier   added start of ag...
628
        # 0) Reset the database (Empty the database from any data)
cd0149f5   Etienne Pallier   progress made for...
629
        #TODO: je crois qu'on n'utilise plus sqlite... donc ce code est inutile ?
2ce20c50   Quentin Durand   applying workshop...
630
631
        if self.system == "Windows" : self.execProcess("del /f testdb.sqlite3")
        else : self.execProcess("rm -f testdb.sqlite3")
4816e86b   Jeremy   removed *.sh *.ba...
632
        self.changeDirectory("..")
fd782a47   Etienne Pallier   refactorisations ...
633
        if TOTAL: self.reset_database_sim()
05bdcc44   Etienne Pallier   BIG DEMO tests (s...
634
635
        # EP added:
        if not TOTAL: self.reset_database_sim()
cd0149f5   Etienne Pallier   progress made for...
636
        # Actualise l’état de la DB en accord avec l’ensemble des modèles et des migrations actuels
03814884   Etienne Pallier   launch majordome ...
637
        self.makemigrations()
4816e86b   Jeremy   removed *.sh *.ba...
638
        self.migrate()
cd0149f5   Etienne Pallier   progress made for...
639
        # Load fixture initial_fixture.json
4816e86b   Jeremy   removed *.sh *.ba...
640
        self.loaddata()
d1e6236c   Etienne Pallier   Refactorized pyro...
641
642

        #
0716eccb   Etienne Pallier   Bye Bye Celery (1...
643
        # 1) Launch web server
d1e6236c   Etienne Pallier   Refactorized pyro...
644
        #
4816e86b   Jeremy   removed *.sh *.ba...
645
646
        self.server()
        self.sleep(2)
075082e1   Etienne Pallier   added start of ag...
647

4816e86b   Jeremy   removed *.sh *.ba...
648
649
        self.printFullTerm(Colors.WARNING, "SUMMARY")
        self.printColor(Colors.GREEN, "The simulator has been successfully initialised")
cd0149f5   Etienne Pallier   progress made for...
650
651
        #TODO: (EP) verifier mais je pense que cette info est obsolete, c'est MySQL qui est utilisé, pas sqlite
        #self.printColor(Colors.GREEN, "The simulator runs on a temp database : src/testdb.sqlite3")
4816e86b   Jeremy   removed *.sh *.ba...
652
653
        self.printColor(Colors.GREEN, "The simulation will be ended by the task 'simulator herself'")
        self.printColor(Colors.GREEN, "If you want to shutdown the simulation, please run :")
ed1bf194   Etienne Pallier   bugfix task major...
654
        self.printColor(Colors.GREEN, "CTRL-C or pyros.py kill_simulation")
4816e86b   Jeremy   removed *.sh *.ba...
655
        self.printColor(Colors.GREEN, "If the simulation isn't correctly killed, please switch the variable")
0716eccb   Etienne Pallier   Bye Bye Celery (1...
656
        self.printColor(Colors.GREEN, "SIMULATOR in src/pyros/settings.py to False")
4816e86b   Jeremy   removed *.sh *.ba...
657
        self.printFullTerm(Colors.WARNING, "SUMMARY")
d1e6236c   Etienne Pallier   Refactorized pyro...
658
659

        #
0716eccb   Etienne Pallier   Bye Bye Celery (1...
660
        # 2) Start simulator(s) :
d1e6236c   Etienne Pallier   Refactorized pyro...
661
662
663
664
        #
        self.sims_launch(TOTAL)

        '''
fd782a47   Etienne Pallier   refactorisations ...
665
        # (DEFAULT NORMAL) TOTAL RUN
d1e6236c   Etienne Pallier   Refactorized pyro...
666
        # - Launch ALL simulators
fd782a47   Etienne Pallier   refactorisations ...
667
        if TOTAL:
fd782a47   Etienne Pallier   refactorisations ...
668
            # Launch ALL simulators and WAIT until finished:
d1e6236c   Etienne Pallier   Refactorized pyro...
669
670
671
            #self.sims_launch(conf)
            self.sims_launch(TOTAL)

fd782a47   Etienne Pallier   refactorisations ...
672
        # (DEV) PARTIAL RUN
d1e6236c   Etienne Pallier   Refactorized pyro...
673
        # - Launch only USER simulator
fd782a47   Etienne Pallier   refactorisations ...
674
        else:
d1e6236c   Etienne Pallier   Refactorized pyro...
675
676
677
678
679
680
681
682
683
684
            # EP: bugfix: inutile si TOTAL, car refait dans sims_launch !!!
            self.changeDirectory("simulators/config")
            self.printColor(Colors.BOLD, "Existing simulations : ", eol='')
            sys.stdout.flush()
            if (self.system == "Windows") : self.execProcessSilent("dir /B conf*.json")
            else: self.execProcessSilent("ls conf*.json")
            self.changeDirectory("..")
            conf = self.askQuestion("Which simulation do you want to use", default="conf.json")
            self.changeDirectory("..")

fd782a47   Etienne Pallier   refactorisations ...
685
686
687
688
689
690
691
692
693
            procs = []
            self.changeDirectory("simulators")
            self.changeDirectory("user")
            # Launch only 1 simulator : UserSimulator
            procs.append(self.execProcessFromVenvAsync(self.venv_bin + " userSimulator.py " + conf))
            self.changeDirectory("..")
            for p in procs:
                p.wait()
            self.changeDirectory("..")
d1e6236c   Etienne Pallier   Refactorized pyro...
694
695
        '''

fd782a47   Etienne Pallier   refactorisations ...
696
        # When simulators are finished:
d1e6236c   Etienne Pallier   Refactorized pyro...
697
        #self.kill_simulation()
4816e86b   Jeremy   removed *.sh *.ba...
698
        return 0
fd782a47   Etienne Pallier   refactorisations ...
699
    
4816e86b   Jeremy   removed *.sh *.ba...
700

03814884   Etienne Pallier   launch majordome ...
701
702
703
704
705
706


    # Test of the Majordome agent
    def test_majordome(self):
        self.changeDirectory("src")

0716eccb   Etienne Pallier   Bye Bye Celery (1...
707
708
        # Set SIMULATOR mode ON
        self.set_simulator_mode_to(True)
03814884   Etienne Pallier   launch majordome ...
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731

        # 0) Reset the database (Empty the database from any data)
        self.changeDirectory("..")
        self.reset_database_sim()
        # Actualise l’état de la DB en accord avec l’ensemble des modèles et des migrations actuels
        self.migrate()
        # Load fixture initial_fixture.json
        self.loaddata()
        return

        #
        # 1) Launch Django web server
        #
        '''
        self.server()
        self.sleep(2)
        '''

        self.printFullTerm(Colors.WARNING, "SUMMARY")
        self.printColor(Colors.GREEN, "The simulation will be ended by the task 'simulator herself'")
        self.printColor(Colors.GREEN, "If you want to shutdown the simulation, please run :")
        self.printColor(Colors.GREEN, "CTRL-C or pyros.py kill_simulation")
        self.printColor(Colors.GREEN, "If the simulation isn't correctly killed, please switch the variable")
0716eccb   Etienne Pallier   Bye Bye Celery (1...
732
        self.printColor(Colors.GREEN, "SIMULATOR in src/pyros/settings.py to False")
03814884   Etienne Pallier   launch majordome ...
733
734
        self.printFullTerm(Colors.WARNING, "SUMMARY")

03814884   Etienne Pallier   launch majordome ...
735
        #
0716eccb   Etienne Pallier   Bye Bye Celery (1...
736
        # 2) Start simulator(s) :
03814884   Etienne Pallier   launch majordome ...
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
        #
        #self.sims_launch(True)
        agent='majordome'
        self.changeDirectory(agent)
        p = self.execProcessFromVenvAsync(self.venv_bin + ' start_agent_'+agent+'.py')
        os.chdir('..')
        time.sleep(5)


        # Wait for end of simulators :
        #p.wait()

        # When simulators are finished:
        #self.kill_simulation()
        #self.changeDirectory("src")
0716eccb   Etienne Pallier   Bye Bye Celery (1...
752
        self.set_simulator_mode_to(False)
03814884   Etienne Pallier   launch majordome ...
753
754
755
756
757
758
759
760
761
762
763
        self.changeDirectory("..")
        self.execProcessAsync("ps aux | grep \"start_agent_majordome.py\" | awk '{ print $2 }' | xargs kill")

        return 0







3b0ef1c7   Jeremy   Beautify help mes...
764
765
766
767
    def kill_server(self):
        self.execProcessAsync("fuser -k 8000/tcp")
        return 0

4816e86b   Jeremy   removed *.sh *.ba...
768
    def kill_simulation(self):
9f3db1a3   Quentin Durand   plc_mode in progr...
769
        self.changeDirectory("src")
0716eccb   Etienne Pallier   Bye Bye Celery (1...
770
        self.set_simulator_mode_to(False)
9f3db1a3   Quentin Durand   plc_mode in progr...
771
        self.changeDirectory("..")
27e81f38   jeremy   Update windows
772
773
        if (self.system == "Windows"):
            self.execProcessAsync("taskkill /f /im python.exe")
58f35996   Unknown   Fixing process bu...
774
775
            #self.execProcessAsync("del /f testdb.sqlite3") obsolete
            #self.changeDirectory("..") POURQUOI ?
27e81f38   jeremy   Update windows
776
            return 0
58f35996   Unknown   Fixing process bu...
777
        #else: self.execProcessAsync("rm -f testdb.sqlite3")
075082e1   Etienne Pallier   added start of ag...
778

fd782a47   Etienne Pallier   refactorisations ...
779
780
        # Kill web server (processes using TCP port 8000) :
        #self.execProcessAsync("fuser -k 8000/tcp")
9f3db1a3   Quentin Durand   plc_mode in progr...
781

fd782a47   Etienne Pallier   refactorisations ...
782
        self.kill_server()
075082e1   Etienne Pallier   added start of ag...
783

0716eccb   Etienne Pallier   Bye Bye Celery (1...
784
785
786
787
        # Kill all agents :
        self.execProcessAsync("ps aux | grep \"start_agent_alert_manager.py\" | awk '{ print $2 }' | xargs kill")
        self.execProcessAsync("ps aux | grep \"start_agent_monitoring.py\" | awk '{ print $2 }' | xargs kill")
        self.execProcessAsync("ps aux | grep \"start_agent_majordome.py\" | awk '{ print $2 }' | xargs kill")
58f35996   Unknown   Fixing process bu...
788
        #self.execProcessAsync("ps aux | grep \"start_agent_majordome.py\" | awk '{ print $2 }' | xargs kill")
0716eccb   Etienne Pallier   Bye Bye Celery (1...
789

fd782a47   Etienne Pallier   refactorisations ...
790
        # Kill all simulators :
cfc9d09c   Jeremy   Added dome simula...
791
        self.execProcessAsync("ps aux | grep \" domeSimulator.py\" | awk '{ print $2 }' | xargs kill")
4816e86b   Jeremy   removed *.sh *.ba...
792
793
794
795
796
797
798
        self.execProcessAsync("ps aux | grep \" userSimulator.py\" | awk '{ print $2 }' | xargs kill")
        self.execProcessAsync("ps aux | grep \" alertSimulator.py\" | awk '{ print $2 }' | xargs kill")
        self.execProcessAsync("ps aux | grep \" plcSimulator.py\" | awk '{ print $2 }' | xargs kill")
        self.execProcessAsync("ps aux | grep \" telescopeSimulator.py\" | awk '{ print $2 }' | xargs kill")
        self.execProcessAsync("ps aux | grep \" cameraNIRSimulator.py\" | awk '{ print $2 }' | xargs kill")
        self.execProcessAsync("ps aux | grep \" cameraVISSimulator.py\" | awk '{ print $2 }' | xargs kill")
        self.changeDirectory("..")
58f35996   Unknown   Fixing process bu...
799

4816e86b   Jeremy   removed *.sh *.ba...
800
801
802
        self.printFullTerm(Colors.GREEN, "simulation ended")
        return 0

d1e6236c   Etienne Pallier   Refactorized pyro...
803

f3534c59   Etienne Pallier   Simulators web pa...
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846

    # EP 25/7/18
    # Start one, some, or all agents and simulators
    
    def start_agents_and_simulators_for_majordome(self):
        self.start_agents_and_simulators("majordome")
        
    def start_agents_and_simulators(self, agent:str=None):
        
        simulators = ('user', 'plc', 'dome', 'alert', 'cameraVIS', 'cameraNIR', 'telescope')
        #simulators = ('plc', 'user')
        #simulators = ()

        agents = ("alert_manager", "majordome", "monitoring")

        if agent=="majordome": 
            simulators = ("plc",)
            agents = (agent, "monitoring")

        # Start simulators
        p_sims = []
        self.changeDirectory("simulators/")
        for simulator in simulators:
            print()
            print("Start simulator", ' '+simulator+"Simulator.py ")
            self.changeDirectory(simulator)
            #p_sims.append( self.execProcessFromVenvAsync(self.venv_bin + ' '+simulator+"Simulator.py " + conf) )
            p_sims.append( self.execProcessFromVenvAsync(self.venv_bin + ' '+simulator+"Simulator.py ") )
            self.changeDirectory("../")

        # Start agents
        #self.start_agents()
        p_agents = []
        self.changeDirectory("../src/")
        for agent in agents:
            print()
            print("Start agent", 'start_agent_'+agent+'.py')
            self.changeDirectory(agent)
            p_agents.append( self.execProcessFromVenvAsync(self.venv_bin + ' start_agent_'+agent+'.py') )
            self.changeDirectory('..')



fd782a47   Etienne Pallier   refactorisations ...
847
    # Simulators only
a64f430a   Unknown   Adding argument t...
848
849
    def sims_launch(self, TOTAL=True):
        conf = SIMULATOR_CONFIG_FILE
d1e6236c   Etienne Pallier   Refactorized pyro...
850
        # Read simulators scenario file
4816e86b   Jeremy   removed *.sh *.ba...
851
        self.changeDirectory("simulators/config")
a64f430a   Unknown   Adding argument t...
852
853
854
855
856
857
858
859
        # if (conf == ""):
        #     self.printColor(Colors.BOLD, "Existing simulations : ", eol='')
        #     sys.stdout.flush()
        #     if (self.system == "Windows"):
        #         self.execProcessSilent("dir /B conf*.json")
        #     else:
        #         self.execProcessSilent("ls conf*.json")
        #     conf = self.askQuestion("Which simulation do you want to use ?", default="conf.json")
4816e86b   Jeremy   removed *.sh *.ba...
860
861
862
        if not os.path.isfile(conf):
            self.printColor(Colors.FAIL, "The simulation file " + conf + " does not exist")
            return 1
075082e1   Etienne Pallier   added start of ag...
863
864
        # Go back to simulators/
        self.changeDirectory("..")
d1e6236c   Etienne Pallier   Refactorized pyro...
865
866
867
868

        procs = []

        # Launch the User simulator:
4816e86b   Jeremy   removed *.sh *.ba...
869
        self.changeDirectory("user")
bca9a283   Jeremy   Reworked the sche...
870
        procs.append(self.execProcessFromVenvAsync(self.venv_bin + " userSimulator.py " + conf))
075082e1   Etienne Pallier   added start of ag...
871
        self.changeDirectory("..")
d1e6236c   Etienne Pallier   Refactorized pyro...
872
873
874
875

        # (if TOTAL) Launch all other simulators
        if TOTAL:

d1e6236c   Etienne Pallier   Refactorized pyro...
876
877
            self.changeDirectory("dome")
            procs.append(self.execProcessFromVenvAsync(self.venv_bin + " domeSimulator.py " + conf))
d1e6236c   Etienne Pallier   Refactorized pyro...
878
            self.changeDirectory("..")
075082e1   Etienne Pallier   added start of ag...
879

d1e6236c   Etienne Pallier   Refactorized pyro...
880
881
            self.changeDirectory("alert")
            procs.append(self.execProcessFromVenvAsync(self.venv_bin + " alertSimulator.py " + conf))
d1e6236c   Etienne Pallier   Refactorized pyro...
882
            self.changeDirectory("..")
075082e1   Etienne Pallier   added start of ag...
883

d1e6236c   Etienne Pallier   Refactorized pyro...
884
885
            self.changeDirectory("plc")
            procs.append(self.execProcessFromVenvAsync(self.venv_bin + " plcSimulator.py " + conf))
d1e6236c   Etienne Pallier   Refactorized pyro...
886
            self.changeDirectory("..")
075082e1   Etienne Pallier   added start of ag...
887

d1e6236c   Etienne Pallier   Refactorized pyro...
888
889
890
            self.changeDirectory("camera")
            procs.append(self.execProcessFromVenvAsync(self.venv_bin + " cameraVISSimulator.py " + conf))
            procs.append(self.execProcessFromVenvAsync(self.venv_bin + " cameraNIRSimulator.py " + conf))
d1e6236c   Etienne Pallier   Refactorized pyro...
891
            self.changeDirectory("..")
075082e1   Etienne Pallier   added start of ag...
892

d1e6236c   Etienne Pallier   Refactorized pyro...
893
894
            self.changeDirectory("telescope")
            procs.append(self.execProcessFromVenvAsync(self.venv_bin + " telescopeSimulator.py " + conf))
075082e1   Etienne Pallier   added start of ag...
895
            self.changeDirectory("..")
d1e6236c   Etienne Pallier   Refactorized pyro...
896

075082e1   Etienne Pallier   added start of ag...
897
        # Get back to project root folder
4816e86b   Jeremy   removed *.sh *.ba...
898
        self.changeDirectory("..")
075082e1   Etienne Pallier   added start of ag...
899

0716eccb   Etienne Pallier   Bye Bye Celery (1...
900
901
        # Launch agents (env monitor, major, alert mgr)
        self.start_agents()
075082e1   Etienne Pallier   added start of ag...
902
903

        # Wait for end of simulators :
f3534c59   Etienne Pallier   Simulators web pa...
904
        for p in procs: p.wait()
075082e1   Etienne Pallier   added start of ag...
905
906

        # Kill all processes
d1e6236c   Etienne Pallier   Refactorized pyro...
907
        self.kill_simulation()
4816e86b   Jeremy   removed *.sh *.ba...
908
909
        return 0

d1e6236c   Etienne Pallier   Refactorized pyro...
910

c53a13e0   Jeremy   Updating a lot of...
911
912
913
914
915
916
917
918
919
920
921
922
923
924
    def mysql_on(self):
        self.changeDirectory("src")
        self.replacePatternInFile("MYSQL = False", "MYSQL = True", "pyros/settings.py")
        self.addExecuted(self.current_command, "Switch to mysql")
        self.changeDirectory("..")
        return 0

    def mysql_off(self):
        self.changeDirectory("src")
        self.replacePatternInFile("MYSQL = True", "MYSQL = False", "pyros/settings.py")
        self.addExecuted(self.current_command, "Switch to sqlite")
        self.changeDirectory("..")
        return 0

4816e86b   Jeremy   removed *.sh *.ba...
925
926
927
928
929
930
931
    def __init__(self, argv):
        super(Pyros, self).__init__(argv)
        self.commandMatcher = {
            "install": self.install,
            "update": self.update,
            "server": self.server,
            "clean": self.clean,
ff448d43   Jeremy   Update
932
            "simulator_development": self.simulator_development,
4816e86b   Jeremy   removed *.sh *.ba...
933
934
935
            "clean_logs": self.clean_logs,
            "test": self.test,
            "migrate": self.migrate,
c53a13e0   Jeremy   Updating a lot of...
936
937
            "mysql_on": self.mysql_on,
            "mysql_off": self.mysql_off,
4816e86b   Jeremy   removed *.sh *.ba...
938
939
940
            "makemigrations": self.makemigrations,
            "updatedb": self.updatedb,
            "unittest": self.unittest,
c53a13e0   Jeremy   Updating a lot of...
941
            "reset_config": self.reset_config,
4816e86b   Jeremy   removed *.sh *.ba...
942
            "test_all": self.test_all,
c72eb17a   Jeremy   Update celery task
943
            "reset_database_sim": self.reset_database_sim,
3b0ef1c7   Jeremy   Beautify help mes...
944
945
            "init_database": self.init_database,
            "kill_server": self.kill_server,
4816e86b   Jeremy   removed *.sh *.ba...
946
            "loaddata": self.loaddata,
b4e8963c   Etienne Pallier   Each agent (envmo...
947
948
949
            "start": self.start,
            "start_web": self.start_web,
            "start_agents": self.start_agents,
f3534c59   Etienne Pallier   Simulators web pa...
950
951
            "start_agents_and_simulators": self.start_agents_and_simulators,
            "start_agents_and_simulators_for_majordome": self.start_agents_and_simulators_for_majordome,
40227fbd   Etienne Pallier   changed monitorin...
952
            "start_agent_monitoring": self.start_agent_monitoring,
b4e8963c   Etienne Pallier   Each agent (envmo...
953
954
            "start_agent_majordome": self.start_agent_majordome,
            "start_agent_alertmanager": self.start_agent_alertmanager,
03814884   Etienne Pallier   launch majordome ...
955
            "test_majordome": self.test_majordome,
b4e8963c   Etienne Pallier   Each agent (envmo...
956
            
4816e86b   Jeremy   removed *.sh *.ba...
957
958
959
960
961
962
963
964
965
966
967
968
969
970
            "simulator": self.simulator,
            "kill_simulation": self.kill_simulation,
            "sims_launch": self.sims_launch,
            "help": self.help,
        }
        self.commandDescription = {
            "install": "Launch the server installation",
            "update": "Update the server",
            "server": "Launch the web server",
            "loaddata": "Load the initial fixture in database",
            "clean": "clean the repository",
            "clean_logs": "clean the log directory",
            "test": "launch the server tests",
            "migrate": "execute migrations",
c53a13e0   Jeremy   Updating a lot of...
971
972
            "mysql_on": "switch the database to be used to MYSQL",
            "mysql_off": "switch the database to be used usage to SQLITE",
4816e86b   Jeremy   removed *.sh *.ba...
973
            "makemigrations": "create new migrations",
c53a13e0   Jeremy   Updating a lot of...
974
            "reset_config": "Reset the configuration in settings.py",
c72eb17a   Jeremy   Update celery task
975
            "reset_database_sim": "Reset the database content",
4816e86b   Jeremy   removed *.sh *.ba...
976
977
            "help": "Help message",
            "updatedb": "Update the database",
3b0ef1c7   Jeremy   Beautify help mes...
978
979
            "kill_server": "Kill the web server on port 8000",
            "init_database": "Create a standard context for pyros in db",
0716eccb   Etienne Pallier   Bye Bye Celery (1...
980
            "unittest": "Runs the unit tests",
4816e86b   Jeremy   removed *.sh *.ba...
981
            "test_all": "Run all the existing tests (this command needs to be updated when tests are added in the project",
4816e86b   Jeremy   removed *.sh *.ba...
982
            "simulator": "Launch a simulation",
ff448d43   Jeremy   Update
983
            "simulator_development": "Simulation for the scheduler only",
0716eccb   Etienne Pallier   Bye Bye Celery (1...
984
            "kill_simulation": "kill the simulators & web server",
4816e86b   Jeremy   removed *.sh *.ba...
985
986
987
988
            "sims_launch": "Launch only the simulators",
        }

if __name__ == "__main__":
a64f430a   Unknown   Adding argument t...
989
990
    if len(sys.argv) == 3 and sys.argv[1].startswith("simulator"):
        SIMULATOR_CONFIG_FILE = sys.argv[2]
4816e86b   Jeremy   removed *.sh *.ba...
991
    conf = Config()
b4e8963c   Etienne Pallier   Each agent (envmo...
992
    if not conf.parseConf(): sys.exit(1)
4816e86b   Jeremy   removed *.sh *.ba...
993
    pyros = Pyros(conf)
2ce20c50   Quentin Durand   applying workshop...
994
    sys.exit(pyros.exec())