Compare commits
	
		
			28 Commits
		
	
	
		
			v2
			...
			8-write-te
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| f3dd9157c7 | |||
| 40076ad3c1 | |||
| 60e09751da | |||
| 1fc558a2ad | |||
| df223bd19e | |||
| 7c2d082cf4 | |||
| 1ba9934438 | |||
| d4d595ed68 | |||
| 9026dd56cc | |||
| 6bd2b3c66c | |||
| 01337279fc | |||
| d8c6b6e6bf | |||
| ecec88e230 | |||
| 9018ab4996 | |||
| ca69954315 | |||
| 4c241eeb60 | |||
| 5e55a65b3f | |||
| e551f8b98d | |||
| 55c67118b4 | |||
| 25035a3221 | |||
| 3d3539930a | |||
| 461a0dac34 | |||
| 8aff3bc57d | |||
| b932e1ad6e | |||
| 4cdefaa8a3 | |||
| 5cb441f36d | |||
| 2a35b87e5d | |||
| d3e733858e | 
							
								
								
									
										5
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1 +1,6 @@ | |||||||
|  | *.pyc | ||||||
|  |  | ||||||
|  | .pytest_cache | ||||||
|  | .coverage | ||||||
|  |  | ||||||
| venv | venv | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| stages: | stages: | ||||||
|   - linting |   - linting | ||||||
|  |   - test | ||||||
|  |  | ||||||
|  |  | ||||||
| flake8: | flake8: | ||||||
| @@ -7,7 +8,7 @@ flake8: | |||||||
|   image: python:3-alpine |   image: python:3-alpine | ||||||
|   before_script: |   before_script: | ||||||
|     - pip install flake8 --no-cache-dir |     - pip install flake8 --no-cache-dir | ||||||
|   script: flake8 main.py |   script: flake8 main.py main_test.py | ||||||
|   allow_failure: true |   allow_failure: true | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -16,5 +17,13 @@ pylint: | |||||||
|   image: python:3-alpine |   image: python:3-alpine | ||||||
|   before_script: |   before_script: | ||||||
|     - pip install pylint --no-cache-dir |     - pip install pylint --no-cache-dir | ||||||
|   script: pylint main.py |   script: pylint main.py main_test.py | ||||||
|   allow_failure: true |   allow_failure: true | ||||||
|  |  | ||||||
|  |  | ||||||
|  | test: | ||||||
|  |   stage: test | ||||||
|  |   image: python:3-alpine | ||||||
|  |   before_script: | ||||||
|  |     - pip install pytest pytest-cov --no-cache-dir | ||||||
|  |   script: pytest --showlocals --cov=main --cov=main_test --cov-report=term-missing . | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | [](https://gitlab.crans.org/ynerant/seminaire-ci/-/commits/master) | ||||||
|  | [](https://gitlab.crans.org/ynerant/seminaire-ci/-/commits/master) | ||||||
|  |  | ||||||
|  | # Séminaire intégration continue | ||||||
|  |  | ||||||
|  | Ce dépôt contient le script utilisé lors du séminaire Crans du 11 février 2021, ainsi que les slides. | ||||||
							
								
								
									
										125
									
								
								main.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										125
									
								
								main.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -1,84 +1,101 @@ | |||||||
| #!/usr/bin/env python | #!/usr/bin/env python3 | ||||||
|  |  | ||||||
|  | """ | ||||||
|  | Ce script est utilisé en guise d'appui pour le séminaire Crans d'introduction | ||||||
|  | à l'intégration continue. | ||||||
|  |  | ||||||
|  | Le dépôt est présent sur https://gitlab.crans.org/ynerant/seminaire-ci.git | ||||||
|  |  | ||||||
|  | Plus d'informations sur les séminaires : https://www.crans.org/fr/seminaire/ | ||||||
|  | """ | ||||||
|  |  | ||||||
|  |  | ||||||
| from random import choice | from random import choice | ||||||
|  | import sys | ||||||
|  |  | ||||||
|  |  | ||||||
| def main(): | def main(): | ||||||
|     print "Bienvenue dans le chatbot du séminaire de l'intégration continue !" |     """ | ||||||
|     print "Veuillez taper une commande. Tapez \"help\" pour afficher l'aide." |     Fonction principale, qui va attendre les instructions de l'utilisateur. | ||||||
|  |     """ | ||||||
|  |     print("Bienvenue dans le chatbot du séminaire de l'intégration continue !") | ||||||
|  |     print("Veuillez taper une commande. Tapez \"aide\" pour afficher l'aide.") | ||||||
|  |  | ||||||
|     while true: |     while True: | ||||||
|         command = input("> ") |         command = input("> ") | ||||||
|         args = command.split(" ") |         args = command.split(" ") | ||||||
|         print(globals()[args[0]](*args[1:])) |         print(commande(args[0], *args[1:])) | ||||||
|  |  | ||||||
|  |  | ||||||
| def help(): | def commande(name: str, *args): | ||||||
|  |     """ | ||||||
|  |     Exécute la commande `name` avec les arguments donnés. | ||||||
|  |     """ | ||||||
|  |     return globals()[name](*args) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def aide(): | ||||||
|     """ |     """ | ||||||
|     Affiche l'aide |     Affiche l'aide | ||||||
|     """ |     """ | ||||||
|     print("help\t\tAffiche l'aide") |     return "aide\t\tAffiche l'aide\n" \ | ||||||
|     print("seminaire\tLance le séminaire") |            "seminaire\tLance le séminaire\n" \ | ||||||
|     print("blague\t\tRaconte une blague") |            "blague\t\tRaconte une blague\n" \ | ||||||
|     print("calcul\t\tVérifie une opération arithmétique. Par exemple, check(1, 2, 3, '+') renvoie True") |            "calcul\t\tVérifie une opération arithmétique. " \ | ||||||
|     print("tri\t\tTrie une liste d'entiers.") |            "Par exemple, check(1, 2, 3, '+') renvoie True\n" \ | ||||||
|     print("quit\t\tQuitte le programme") |            "tri\t\tTrie une liste d'entiers.\n" \ | ||||||
|  |            "stop\t\tQuitte le programme" | ||||||
|  |  | ||||||
|  |  | ||||||
| def seminaire(): | def seminaire(): | ||||||
|     """ |     """ | ||||||
|     Affiche les slides du séminaire. |     Affiche les slides du séminaire. | ||||||
|     """ |     """ | ||||||
|     print("\x4c\x61\x69\x73\x73\x65\x20\x74\x6f\x6d\x62\x65\x72\x2c\x20\x74\x6f\x6e\x20\x74\x72\x75\x63\x20\x65\x73\x74\x20\x74\x72\x6f\x70\x20\x62\x65\x75\x67\x75\xe9\x2c\x20\x74\x75\x20\x64\x65\x76\x72\x61\x69\x73\x20\x70\x61\x73\x73\x65\x72\x20\x64\x75\x20\x74\x65\x6d\x70\x73\x20\xe0\x20\xe9\x63\x72\x69\x72\x65\x20\x64\x65\x73\x20\x74\x65\x73\x74\x73\x20\x65\x74\x20\x66\x61\x69\x72\x65\x20\x64\xe9\x66\x69\x6c\x65\x72\x20\x74\x65\x73\x20\x73\x6c\x69\x64\x65\x73") |     print("\x4c\x61\x69\x73\x73\x65\x20\x74\x6f\x6d\x62\x65" | ||||||
|  |           "\x72\x2c\x20\x74\x6f\x6e\x20\x74\x72\x75\x63\x20" | ||||||
|  |           "\x65\x73\x74\x20\x74\x72\x6f\x70\x20\x62\x65\x75" | ||||||
|  |           "\x67\x75\xe9\x2c\x20\x74\x75\x20\x64\x65\x76\x72" | ||||||
|  |           "\x61\x69\x73\x20\x70\x61\x73\x73\x65\x72\x20\x64" | ||||||
|  |           "\x75\x20\x74\x65\x6d\x70\x73\x20\xe0\x20\xe9\x63" | ||||||
|  |           "\x72\x69\x72\x65\x20\x64\x65\x73\x20\x74\x65\x73" | ||||||
|  |           "\x74\x73\x20\x65\x74\x20\x66\x61\x69\x72\x65\x20" | ||||||
|  |           "\x64\xe9\x66\x69\x6c\x65\x72\x20\x74\x65\x73\x20" | ||||||
|  |           "\x73\x6c\x69\x64\x65\x73") | ||||||
|  |  | ||||||
|  |  | ||||||
| def blague(): | def blague(): | ||||||
|     """ |     """ | ||||||
|     Renvoie une blague aléatoire. |     Renvoie une blague aléatoire. | ||||||
|     """ |     """ | ||||||
|     return choice(["Je vais vous raconter une blague sur, mais vous ne l'aurez peut-être pas.", "Connaissez-vous la différence entre la théroie et la pratique ? Il n'y en a pas, en théorie.") |     return choice( | ||||||
|  |             ["Je vais vous raconter une blague sur, mais vous " | ||||||
|  |              "ne l'aurez peut-être pas.", | ||||||
|  |              "Connaissez-vous la différence entre la théroie " | ||||||
|  |              "et la pratique ? Il n'y en left pas, en théorie."]) | ||||||
|  |  | ||||||
|  |  | ||||||
| def calcul(a b, c, operation = '+'): | def calcul(left: int, right: int, res: int, operation='+'): | ||||||
|     """ |     """ | ||||||
|     Vérifie si a operation b == c, où a, b et c sont des entiers. |     Vérifie si left operation b == c, où a, b et c sont des entiers. | ||||||
|     L'opération peut être +, -, *, /, &, |, ^, % ou l'un de ses alias anglais. |     L'opération peut être +, -, *, /, &, |, ^, % ou l'un de ses alias anglais. | ||||||
|     """ |     """ | ||||||
|     if operation = '+': |     if operation in ['+', 'add', 'sum']: | ||||||
|        result = a + b |         result = left + right | ||||||
|     if operation == 'sum': |     if operation in ['-', 'sub']: | ||||||
|        result = a + b |         result = left - right | ||||||
|     if operation == 'add': |     if operation in ['*', 'mul', 'prod']: | ||||||
|        result = a + b |         result = left * right | ||||||
|     if operation == '-': |     if operation in ['/', 'div']: | ||||||
|        result = a - b |         result = left / right | ||||||
|     if operation == 'sub': |     if operation in ['&', 'and']: | ||||||
|        result = a - b |         result = left & right | ||||||
|     if operation == '*': |     if operation in ['|', 'or']: | ||||||
|        result = a * b |         result = left | right | ||||||
|     if operation == 'mul': |     if operation in ['^', 'xor']: | ||||||
|        result = a * b |         result = left ^ right | ||||||
|     if operation == 'prod': |  | ||||||
|        result = a * b |  | ||||||
|     if operation == '/': |  | ||||||
|        result = a / b |  | ||||||
|     if operation == 'div': |  | ||||||
|        result = a / b |  | ||||||
|     if operation == '&': |  | ||||||
|        result = a & b |  | ||||||
|     if operation == 'and': |  | ||||||
|        result = a & b |  | ||||||
|     if operation == |: |  | ||||||
|        result = a | b |  | ||||||
|     if operation == 'or': |  | ||||||
|        result = a | b |  | ||||||
|     if operation == '^': |  | ||||||
|        result = a ^ b |  | ||||||
|     if operation == 'xor': |  | ||||||
|        result = a ^ b |  | ||||||
|     else: |     else: | ||||||
|        result = a % b |         result = left % right | ||||||
|     return c == result |     return res == result | ||||||
|  |  | ||||||
|  |  | ||||||
| def tri(*args): | def tri(*args): | ||||||
| @@ -88,13 +105,13 @@ def tri(*args): | |||||||
|     return sorted(args) |     return sorted(args) | ||||||
|  |  | ||||||
|  |  | ||||||
| def quit(exit_code = int: 0): | def stop(exit_code: int = 0): | ||||||
|     """ |     """ | ||||||
|     Stoppe le programme avec le code d'erreur donné. |     Stoppe le programme avec le code d'erreur donné. | ||||||
|     """ |     """ | ||||||
|     print("Fin du programme, merci !) |     print("Fin du programme, merci !") | ||||||
|     exit(exit_code) |     sys.exit(exit_code) | ||||||
|  |  | ||||||
|  |  | ||||||
| if __name__ == __main__: | if __name__ == '__main__': | ||||||
|     main() |     main() | ||||||
|   | |||||||
							
								
								
									
										89
									
								
								main_test.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										89
									
								
								main_test.py
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,89 @@ | |||||||
|  | #!/usr/bin/env python3 | ||||||
|  |  | ||||||
|  | """ | ||||||
|  | Exécution des tests du script. | ||||||
|  | """ | ||||||
|  |  | ||||||
|  | from random import randint, seed, shuffle | ||||||
|  | import unittest | ||||||
|  |  | ||||||
|  | import main | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class TestMain(unittest.TestCase): | ||||||
|  |     """ | ||||||
|  |     Cette classe permet d'executer l'ensemble des scripts | ||||||
|  |     """ | ||||||
|  |  | ||||||
|  |     def test_aide(self): | ||||||
|  |         """ | ||||||
|  |         On essaie d'afficher l'aide, | ||||||
|  |         et on vérifie si ça affiche la bonne chose. | ||||||
|  |         """ | ||||||
|  |         res = main.commande("aide") | ||||||
|  |         lines = res.split("\n") | ||||||
|  |         self.assertEqual(len(lines), 6) | ||||||
|  |         self.assertTrue(lines[0].startswith("aide")) | ||||||
|  |         self.assertTrue(lines[1].startswith("seminaire")) | ||||||
|  |         self.assertTrue(lines[2].startswith("blague")) | ||||||
|  |         self.assertTrue(lines[3].startswith("calcul")) | ||||||
|  |         self.assertTrue(lines[4].startswith("tri")) | ||||||
|  |         self.assertTrue(lines[5].startswith("stop")) | ||||||
|  |  | ||||||
|  |     def test_seminaire(self): | ||||||
|  |         """ | ||||||
|  |         Test de l'affichage du "séminaire". | ||||||
|  |         """ | ||||||
|  |         res = main.commande("seminaire") | ||||||
|  |         self.assertEqual(len(res), 114) | ||||||
|  |  | ||||||
|  |     def test_blague(self): | ||||||
|  |         """ | ||||||
|  |         On teste les blagues, et on vérifie si | ||||||
|  |         elles fonctionnent bien. | ||||||
|  |         """ | ||||||
|  |         seed(1) | ||||||
|  |         res = main.commande("blague") | ||||||
|  |         self.assertEqual(res, "Je vais vous raconter une blague sur UDP, " | ||||||
|  |                               "mais vous ne l'aurez peut-être pas.") | ||||||
|  |  | ||||||
|  |         seed(5) | ||||||
|  |         res = main.commande("blague") | ||||||
|  |         self.assertEqual(res, "Connaissez-vous la différence entre la " | ||||||
|  |                               "théorie et la pratique ? " | ||||||
|  |                               "Il n'y en a pas, en théorie.") | ||||||
|  |  | ||||||
|  |     def test_calcul(self): | ||||||
|  |         """ | ||||||
|  |         On vérifie que certains calculs basiques, puis aléatoires, | ||||||
|  |         marchent bien. | ||||||
|  |         """ | ||||||
|  |         self.assertTrue(main.commande("calcul", 1, 2, 3)) | ||||||
|  |         self.assertFalse(main.commande("calcul", 1, 2, 2, '+')) | ||||||
|  |         self.assertTrue(main.commande("calcul", 1, 2, 2, '*')) | ||||||
|  |         self.assertTrue(main.commande("calcul", 42, 3, 14, 'div')) | ||||||
|  |         self.assertTrue(main.commande("calcul", 16777215, 42, 42, 'and')) | ||||||
|  |         self.assertTrue(main.commande("calcul", 16777213, 42, 16777215, 'or')) | ||||||
|  |         self.assertFalse(main.commande("calcul", 15, 20, 35, 'xor')) | ||||||
|  |         self.assertTrue(main.commande("calcul", 15, 20, 27, '^')) | ||||||
|  |         self.assertTrue(main.commande("calcul", 100, 76, 24, 'unknown')) | ||||||
|  |  | ||||||
|  |         left, right = randint(0, 0x7FFFFFFF), randint(0, 0x7FFFFFFF) | ||||||
|  |         self.assertTrue(main.commande("calcul", left, right, | ||||||
|  |                                       left - right, "-")) | ||||||
|  |  | ||||||
|  |     def test_tri(self): | ||||||
|  |         """ | ||||||
|  |         À partir d'une liste donnée, on trie la liste | ||||||
|  |         et on vérifie qu'elle est bien triée. | ||||||
|  |         """ | ||||||
|  |         my_list = [23, 16, 234567, -4] | ||||||
|  |         shuffle(my_list) | ||||||
|  |         sorted_list = sorted(my_list) | ||||||
|  |         self.assertEqual(main.commande("tri", *my_list), sorted_list) | ||||||
|  |  | ||||||
|  |     def test_stop(self): | ||||||
|  |         """ | ||||||
|  |         On vérifie que le programme s'arrête bien. | ||||||
|  |         """ | ||||||
|  |         self.assertRaises(SystemExit, main.commande, "stop", 0) | ||||||
		Reference in New Issue
	
	Block a user