gwift-reborn/introduction.asc

122 lines
9.0 KiB
Plaintext
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

[preface]
== Introduction
"The only way to go fast, is to go well."
-- Robert C. Martin
Il existe énormément de tutoriaux très bien réalisés qui expliquent _”Comment réaliser une application Django”_ et autres _”Déployer votre code en 2 minutes”_.
Nous nous disions cependant que ces tutoriaux restaient relativement haut-niveaux et se limitaient à un contexte donné, sans réellement préparer à la maintenance et au suivi d'une application.
Les quelques idées ci-dessous de jeter les bases dun bon développement, en
* Survolant lensemble des lignes directrices reconnues
* Maintenant une bonne qualité de code
* Parcourant les différentes étapes du développement qui mèneront jusquau déploiement
* Maintenant correctement la base de données
* Permettant à quiconque de reprendre ce qui aura déjà été écrit.
Ces idées ne sappliquent pas uniquement à Django et à son cadre de travail, ni même au langage Python en particulier.
Dans un http://blog.codinghorror.com/why-ruby/[article de blog], Jeff Atwood, développeur .Net expérimenté, a décrit sa décision de développer Discourse en utilisant le language Ruby cite:[roads_and_bridges(27)] :
"Getting up and running with a Microsoft stack is just plain too hard for a developer in, say, Argentina, or Nepal, or Bulgaria. Open source operating, languages, and tool chaines are the great equializer, the basis for the next great generation of programmers all over the world who are goind to help us change the world."
-- Jeff Atwood
La même réflexion sapplique sans effort à Python et Django : lorganisation https://djangogirls.org/fr/[Django Girls] a par exemple formé plus de 2000 femmes dans le monde, réparties dans plus de 49 pays.
Django na pas été développé par cette organisation elle-même, mais étant _open source_, ce framework peut être téléchargé, utilisé et étudié gratuitement cite:[roads_and_bridges(28)].
Si ces morceaux logiciels nétaient pas libres et accessibles, ils ne pourraient pas être déconstruits, analysés, étudiés et publiés, ni aider certaines personnes à exercer leur propre métier.
Louverture de ces langages et frameworks en fait également des modèles bien définis de documentation et de flexibilité.
Django se présente comme un Framework Web pour perfectionnistes ayant des deadlines cite:[django] et suit ces quelques principes cite:[django_design_philosophies] :
* *Faible couplage et forte cohésion*, pour que chaque composant dispose de son indépendance, en nayant aucune connaissance des autres couches applicatives. Ainsi, le moteur de rendu ne connait absolument rien à lexistence du moteur de base de données, tout comme le système de vues ne sait pas quel moteur de renduest utilisé.
* *Plus de fonctionnalités avec moins de code* : chaque application Django doit utiliser le moins de code possible
* *Dont repeat yourself*, chaque concept ou morceau de code ne doit être présent quà un et un seul endroit de vos dépôts.
* *Rapidité du développement*, en masquant les aspects fastidieux du développement web actuel.
Mis côte à côte, le suivi de ces principes permet une bonne stabilité du projet à moyen et long terme.
Sans être parfait, Django offre une énorme flexibilité qui permet de conserver un maximum doptions ouvertes et de facilement expérimenter différentes pistes, jusquau moment de prendre une vraie décision.
Pour la (grande) majorité des problèmes rencontrés lors du développement dune application Web, Django proposera une solution pragmatique, compréhensible et facile à mettre en place : pour tout problème communément connu, vous disposerez dune solution logique.
*Dans la première partie*, nous verrons comment partir dun environnement sain, comment le configurer correctement, comment installer Django de manière isolée et comment démarrer un nouveau projet.
Nous verrons rapidement comment gérer les dépendances, les versions et comment appliquer et suivre un score de qualité de notre code.
Ces quelques points pourront être appliqués pour nimporte quel langage ou cadre de travail.
Nous verrons aussi que la configuration proposée par défaut par le framework nest pas idéale dans la majorité des cas.
Pour cela, nous présenterons différents outils, la rédaction de tests unitaires et dintégration pour limiter les régressions, les règles de nomenclature et de contrôle du contenu, comment partir dun squelette plus complet, ainsi que les bonnes étapes à suivre pour arriver à un déploiement rapide et fonctionnel avec peu defforts.
A la fin de cette partie, vous disposerez dun code propre et dun projet fonctionnel, bien quencore peu utile.
*Dans la deuxième partie*, nous aborderons les grands principes de modélisation, en suivant les lignes de conduites du cadre de travail.
Nous aborderons les concepts clés qui permettent à une application de rester maintenable, les formulaires, leurs validations, comment gérer les données en entrée, les migrations de données et ladministration.
*Dans la troisième partie*, nous détaillerons précisément les étapes de déploiement, avec la description et la configuration de linfrastructure, des exemples concrets de mise à disposition se basant sur une distribution GNU/Linux connue et utilisée en entreprise, sur une _Plateform as a Service_, ainsi que sur des containeurs.
Nous aborderons également la supervision et la mise à jour dune application existante, en respectant les bonnes pratiques dadministration système.
*Dans la quatrième partie*, nous aborderons les architectures typées entreprise, les services et les différentes manières de structurer notre application pour faciliter sa gestion et sa maintenance, tout en décrivant différents types de scénarii, en fonction des consommateurs de données.
*Dans la cinquième partie*, nous mettrons ces concepts en pratique en présentant le développement en pratique de deux applications, avec la description de problèmes
rencontrés et la solution qui a été choisie : définition des tables, gestion des utilisateurs, ... et mise à disposition.
=== Pour qui ?
Avant tout, pour moi.
Comme le disait le Pr Richard Feynman : ”Si vous ne savez pas expliquer quelque chose simplement, cest que vous ne lavez pas compris”.
Et comme l'ajoutait Aurélie Jean: "Si personne ne vous pose de questions suite à votre explication, c'est que vous n'avez pas été sufisamment clair" cite:[other_side].
Ensuite, ce livre sadresse autant :
1. Au néophyte qui souhaite se lancer dans le développement Web
2. A lartisan qui a besoin dun aide-mémoire et qui ne se rappelle plus toujours du bon ordre des paramètres,
3. A lexpert qui souhaiterait avoir un aperçu dune autre technologie que son domaine privilégié de compétences.
Beaucoup de concepts présentés peuvent être oubliés ou restés inconnus jusquau moment où ils seront réellement nécessaires : à ce moment-là, pour peu que votre mémoire ait déjà entraperçu le terme, il vous sera plus facile dy revenir et de lappliquer.
Dans tous les cas, nous supposerons que le lecteur aura déjà une première expérience en programmation.
S'il a déjà réalisé des interrogations en base de données, cela facilitera la compréhension de ce qu'il y a "sous le capot", de même que quelques notions de programmation orientée objets.
=== Pour aller plus loin
Il existe énormément de ressources, autant spécifiques à Django que plus généralistes.
Il ne sera pas possible de toutes les détailler ; faites un tour sur
* https://stackoverflow.com,
* https://ycombinator.com,
* https://lobste.rs/,
* https://semaphoreci.com/blog,
* https://lecourrierduhacker.com/
* ou https://www.djangoproject.com/.
Restez curieux, ne vous enclavez pas dans une technologie en particulier et gardez une bonne ouverture desprit.
=== Conventions
NOTE: Les notes indiquent des anecdotes.
TIP: Les tips indiquent des trucs et astuces, ou des raccourcis permettant de gagner du temps.
IMPORTANT: Les notes importantes indiquent des éléments pouvant rapidement ripper
WARNING: Les avertissements indiquent un danger ou des conséquences pouvant résulter d'un choix.
Les morceaux de code source seront présentés de la manière suivante :
[source,python]
----
# <folder>/<fichier>.<extension>
def function(param):
"""
"""
callback()
----
Chaque extrait de code reprend :
* Lemplacement du fichier, si c'est pertinent, présenté sous forme de commentaire (ligne 1),
* Des commentaires au niveau des fonctions et méthodes, si cela savère nécessaire
* Un surlignage sur les parties importantes ou récemment modifiées
La plupart des commandes qui seront présentées dans ce livre le seront depuis un shell sous GNU/Linux.
Certaines dentre elles pourraient devoir être adaptées si vous utilisez autre système dexploitation (macOS ou Microsoft Windows).
Les morceaux de code que vous trouverez ci-dessous seront développés pour Python3.9+ et Django 3.2+.
Ils nécessiteront peut-être quelques adaptations pour fonctionner sur une version antérieure.