Mode d'emploi du projet modèle MVC-entity
v0.1 19/07/2016 (Julien Legrand) : 1ère version
Visual Studio 0.1. Avant toute chose, vérifier que le gestionnaire de packages Nuget est à jour dans Visual Studio 0.2. Si nécessaire, executer "console manager nuget" et accepter avec "T" les messages dans l'écran console 0.3. Installer les outils : "Oracle Developer Tools for Visual Studio" présents ici : "\home\bin-span$\Logiciels (Lecture seule)\Oracle\Oracle Developer Tools for Visual Studio" 0.4. Au besoin, changer la politique Powershell du poste quant à la signature du code comme expliqué ici : "http://codebox/snippets/4"
GIT 1.1. Cloner le projet modèle dans le dossier de votre choix : "git clone [adresse du projet]" à faire dans le dossier parent (le dossier CD67.ModeleMVC sera créé automatiquement) 1.2. Renommer le dossier du projet avec le nom de votre choix 1.3. Supprimer le sous-dossier caché ".git" à la racine du projet pour supprimer le lien avec le projet modèle 1.4. Initialiser un nouveau dépôt GIT : "git init" à faire dans le dossier du projet 1.5. C'est le bon moment pour faire un premier commit : "git add ." et "git commit -m "NEW Reprise du projet modèle"" 1.6. Créer un nouveau projet sur CodeBox et copier l'adresse pour GIT (SSH ou HTTP) 1.7. Ajout de la référence du repository en ligne : "git remote add origin [adresse du nouveau projet]" 1.8. 1er envoi sur le serveur : "git push --set-upstream origin master" (par la suite, "git push" suffira)
Renommer et exéctuer la maquette : 2.1. Renommer la solution et les projets en suivant ce schéma : "CD67.[nom appli].[Entity/Factory/MVC/Tests/Batchs]" 2.2. Renommer également les assemblies et espaces de nom de chaque projet (dans les propriétés des projets, onglet "Application") 2.3. Quitter Visual Studio 2.4. Supprimer si nécessaire tous les fichiers commencant par "CD67.ModeleMVC.*" dans les dossiers suivants : "\CD67.ModeleMVC.MVC\bin", "\CD67.ModeleMVC.Factory\bin\Debug", "\CD67.ModeleMVC.Entity\bin\Debug", "CD67.ModeleMVC.Tests\bin\Debug" 2.5. Modifier le noms des dossiers des projets en conséquence et modifier le chemin des fichiers projets dans le fichier solution *.sln 2.6. Ouvrir à nouveau la solution et faire un rechercher/remplacer global à la solution pour remplacer "CD67.ModeleMVC" par "CD67.[nom appli]" 2.7. Nettoyer, régénérer la solution et restorer les packages Nuget 2.8. Définir le projet "CD67.ModeleMVC.MVC" comme projet de démarrage 2.9. Exécuter là pour contrôler qu'elle fonctionne correctement à ce stade avec les données de tests 2.10. Noter dans le code les exemples à disposition 2.11. Un petit commit avant de continuer : "git add ." et "git commit -m "NEW Renommage du projet modèle""
Nouvelle connexion : 3.1. Pour Oracle : Mettre à jour la chaine de connexion "Entities" active dans les fichiers : "CD67.ModeleMVC.Entity\App.config", "CD67.ModeleMVC.MVC\Web.config" et "CD67.ModeleMVC.Tests\App.config" Pour SQL server :
Démarrage du nouveau projet : 4.1. Mettre à jour le modèle par rapport à la base de données pour ajouter de nouvelles tables et vues nécessaire à l'application 4.2. Vérifier les types des entités générées depuis la base de données, particulièrement les chiffres et clés en numéro auto ou avec un trigger/sequence Oracle (le champ "StoreGeneratedPattern" doit être égal à "Identity" pour les clés automatiques) 4.3. Créer vos propres fichiers d'extension avec DataAnnotation ici : "CD67.ModeleMVC.Entity\Extend" 4.4. Créer vos propres factory ici : "CD67.ModeleMVC.Factory" 4.5. Créer vos propres controller/vues ici : "CD67.ModeleMVC.MVC\Controllers" et "CD67.ModeleMVC.MVC\Views" (NOTE : personellement j'utilise à la création du controller le modèle "Contrôleur MV5 avec vues, utilisant Entity Framework" en générant les vues et avec la page de disposition que je souhaite, ensuite je modifie le code du contrôleur pour utiliser les classes "Factory") 4.6. Modifier le fichier "CD67.ModeleMVC.MVC\App_Start\RouteConfig.cs" par rapport à vos contrôleurs et variables nécessaires 4.7. Ajout des tests unitaires pour tester les fonctions principales dans le projet dédié "CD67.ModeleMVC.Tests" (CRUD sur les classes, processus complet, etc.) 4.8. On fait des commits/push à chaque avancée majeure, on fait une fusion avec la branche "master" dès que l'outil est en production, puis son continue les développements sur "develop"
Supprimer ce fichier à la fin pour ne pas que l'on sache que vous avez utilisé un modèle :p
La solution est consituée de 4 projets :
Le modèle se nomme par défaut "EntityModel". Pour se connecter à la base de données afin de faire évoluer le modèle, il faut utiliser la connexion "OracleConnection (CD67.ModeleMVC.MVC)".
Le dossier "Extend" contient les extensions éventuelles de classe Entity (qui se trouvent dans "EntityModel.edmx\EntityModel.tt\"). C'est notamment utile pour ajouter les DataAnnotations permettant de décrire le données en vue d'une génération de contrôles plus appropiés dans les vues MVC. Attention à bien surveiller l'espace de noms lors de la création d'une classe dans ce sous-dossier (erreur fréquente) :
Le dossier "Internal" contient :
Les classes Factory sont nommées ainsi : "[Nom objet]Factory" On crée autant de classe Factory que d'objet à gérer Elles doivent contenir un constructeur public avec le context Entities en paramètre qui se base sur le constructeur de la classe parente. Elles contiennent généralement les fonctions suivantes : getById, getAll, add, update, delete. C'est à adapter à chaque cas.
Le dossier "Internal" contient la classe de base "baseFactory" dont chaque "Factory" hérite.
La partie Model du projet n'est pas nécessaire que pour définir des classes ne servant qu'à l'affichage, les classes mêtiers étant dans le projet Entity.
Le dossier "Views" contient par défaut :
Le dossier "style" contient :
Les scripts et styles sont chargés à l'aide des commandes : "@Scripts.Render("~/bundles/jquery")", "@Scripts.Render("~/bundles/bootstrap")" et "@Styles.Render("~/Content/css")". La configuration de ceci se trouve dans ce fichier : "App_Start\BundleConfig.cs"
Les Glyphicons Bootstrap sont ici : http://getbootstrap.com/components/#glyphicons Et les icônes FontAwesome là : http://fontawesome.io/icons/
Le dossier "Internal" contient du code permettant l'ajout de la commande "@Html.DescriptionFor" dans les vues.
Projet le plus important de la solution :)