% INF5153 — Génie logiciel: conception % UQAM — Département d'informatique % Plan de cours — Hiver 2020 * Horaires, locaux et enseignants: Responsable(s) du cours ======================= Coordination ------------ Mosser, Sébastien PK-4820 poste 3904 Enseignement ------------- Benzarti, Imen PK-4115 Description du cours ==================== Sensibiliser l'étudiant aux difficultés de la conception et lui permettre d'élaborer des solutions réutilisables, maintenables et extensibles. Problématique du processus de conception. Critères et architecture. Conception comme activité créatrice. Outils d'aide à la conception. Intégration et essais système. Conception orientée objet. Cadres d'application et patrons de conception. Documentation de conception. Rétro ingénierie. **Ce cours comporte une séance obligatoire de laboratoire.** Préalables académiques : - INF5151 Génie logiciel: analyse et modélisation; - INF3135 Construction et maintenance de logiciels Objectif du cours ================= - Caractériser les propriétés d'une bonne conception. - Définir les principes sous-jacent des approches orientée objet. - Initier les étudiants à la notation UML (classe, séquence, états). - Rendre les étudiants aptes à réaliser des modèles de conception orienté objet originaux - Faire apprécier aux étudiants l'importance des enjeux reliés à la conception. - Familiariser les étudiants aux principaux patrons utilisés pour la conception orientée objet. - Rendre les étudiants aptes à réaliser un document de conception justifiant celle ci. - Rendre les étudiants capable de comparer des conceptions équivalentes, et de les caractériser\ - Initier les étudiants aux nouvelles approches dans le domaine. Formule Pédagogique =================== Le cours fonctionne dans une approche projet, où la réalisation du projet de session est primordiale. Deux seances de cours sont dédiées à des entretiens avec les équipes projets pour faire un point sur le projet de session. Un premier projet individuel est utilisé pour démarrer, puis un projet de session en équipe sur le long terme (10 semaines) est utiliser pour aller plus loin sur la conception d'application orientés objet. Les cours magistraux sont conçus autour des concepts théoriques, et certains cours sont dédiés à des études de cas analysant en profondeur la conception d'application orientée objet. Les notes de cours présentées sont disponibles sur le site web du cours. Deux séances de cours sont dédiées à des études de cas en profondeur. *Les séances de laboratoires sont obligatoire*, et consistent en de la rétroaction de la part de l'équipe enseignante sur le projet de session. Modalités d'évaluation ====================== Description sommaire Date Pondération --------------------------- ------ ------------- Projet 1 (individuel) S4 10% Projet 2 - MVP (groupe) S7 10% Examen commun intra S7 20% Projet 2 - Final (groupe) S15 20% Examen commun final S15 40% - Un travail remis en retard reçoit la note zéro. - Un travail ne respectant pas les consignes de remises reçoit la note de zéro. - Le détail des conditions de réalisation de chaque projet sera précisé avec la description du projet. - La qualité du français fait partie intégrante des critères d'évaluation des travaux et des examens jusqu'à un maximum de 25%. - La note de passage du cours est de 50% pour l'ensemble de l'évaluation. Organisation des séances de cours ================================= \#Semaine Atelier Cours ----------- ----------------- ------------------------------------------------------- \#1 Pourquoi concevoir ? De *Programmeur* à *Développeur* \#2 P1 Encapsulation, Types et Interfaces \#3 P1 Composition *versus* Héritage, Tests \#4 P1 Principes de conception (GRASP, SOLID) \#5 P2-MVP Étude de cas \#6 P2-MVP Intro aux Patrons de conception (Stratégie) \#7 P2-MVP **Examen intra** \#8 *Présentations* *Présentations* \#9 P2-Complet Étude de cas intra & Rétro-action projets \#10 P2-Complet Patrons de conception \#1 \#11 P2-Complet Patrons de conception \#2 \#12 P2-Complet Étude de cas \#13 P2-Complet Mesure & visualisation pour la maintenance \#14 *Présentations* *Présentations* \#15 *Révisions* **Examen Final** Renseignement utiles ==================== Le cours INF5151 est un préalable à ce cours. Particulièrement, il est important que les étudiants sachent lire un diagramme de classe et un diagramme de séquence. Bien qu'un bref rappel de modélisation sera présenté, il est fortement recommandé aux étudiants de rafraîchir leurs connaissances en modélisation en vue de suivre ce cours. Médiagraphie ============ VO - Introduction to Software Design with Java, 2019. Martin Robillard. VO - UML\@Classroom, Springer Verlag, 2015. Martina Seidl, Marion Scholz, Christian Huemer & Gerti Kappel. VR - Clean Code. Robert Martin. Prentice Hall. VR - Head First Design Patterns, a brain friendly guide. Eric Freeman, Elisabeth Robson. O'REILLY. VC - Software Systems Architecture: Working With Stakeholders Using Viewpoints and Perspectives, Addison Wesley, 2011. Nick Rozanski & Eoin (pronounced "Owen") Woods. VC - Pragmatic Unit Testing. Jeff Langr, with Andy Hunt and Dave Thomas. The pragmatic programmers. VC - Design Patterns: Elements of Reusable Object-Oriented Software, Addison Wesley, 1994. Erich Gamma, Richard Helm, Ralph Johnson & John Vlissides. VC - Refactoring: Improving the Design of Existing Code, Addison Wesley, 2018 (2nd edition) Martin Fowler. Légende: A: article - C: comptes rendus - L: logiciel - S: standard - U : url - V: volume C: complémentaire - O: obligatoire - R: recommandé