ECOM-1F0 1819 BTB: Difference between revisions

From air
Jump to navigation Jump to search
 
(10 intermediate revisions by one other user not shown)
Line 27: Line 27:


!scope="row"| 2
!scope="row"| 2
| [[ECOM 1F0 2018-19 BTB Zoran CHANET | CHANET Zoran]]
| [[User:Zoran.Chanet | CHANET Zoran]]
| zoran.chanet@etu.univ-grenoble-alpes.fr
| zoran.chanet@etu.univ-grenoble-alpes.fr
| Développeur - Back End
| Développeur - Back End
Line 157: Line 157:
* Visibilité de l'état du système
* Visibilité de l'état du système


Le système devrait toujours tenir les utilisateurs informés de ce qui se passe, grâce à une rétroaction appropriée dans un délai raisonnable.
Le système devrait toujours tenir les utilisateurs informés de ce qui se passe, grâce à une rétroaction appropriée dans un délai raisonnable.

---> Pas de rétroaction durant le temps d'attente suite à un appel à l'API




* Correspondance entre le système et le monde réel
* Correspondance entre le système et le monde réel


Le système devrait parler la langue de l'utilisateur, avec des mots, des phrases et des concepts familiers à l'utilisateur, plutôt que des termes orientés système. Suivez les conventions du monde réel, en faisant apparaître les informations dans un ordre naturel et logique.
Le système devrait parler la langue de l'utilisateur, avec des mots, des phrases et des concepts familiers à l'utilisateur, plutôt que des termes orientés système. Suivez les conventions du monde réel, en faisant apparaître les informations dans un ordre naturel et logique.
.


---> Oui, nous avons respecté le langage métier.




* Contrôle et liberté de l'utilisateur
* Contrôle et liberté de l'utilisateur


Les utilisateurs choisissent souvent les fonctions du système par erreur et ont besoin d'une "sortie de secours" clairement marquée pour quitter l'état non désiré sans avoir à passer par un dialogue prolongé. Support annuler et refaire.
Les utilisateurs choisissent souvent les fonctions du système par erreur et ont besoin d'une "sortie de secours" clairement marquée pour quitter l'état non désiré sans avoir à passer par un dialogue prolongé. Support annuler et refaire.

---> Nous n'avons pas implémenter de bouton retour (mais c'est assez rapide à ajouter)




* Cohérence et normes
* Cohérence et normes


Les utilisateurs ne devraient pas avoir à se demander si des mots, des situations ou des actions différents signifient la même chose. Suivre les conventions de la plate-forme.
Les utilisateurs ne devraient pas avoir à se demander si des mots, des situations ou des actions différents signifient la même chose. Suivre les conventions de la plate-forme.

---> L'interface est suffisamment simple pour ne présenter aucune ambigüité




* Prévention des erreurs
* Prévention des erreurs


Encore mieux qu'un bon message d'erreur est une conception soignée qui empêche qu'un problème ne se produise en premier lieu. Éliminez les conditions sujettes aux erreurs ou vérifiez-les et présentez aux utilisateurs une option de confirmation avant qu'ils ne s'engagent dans l'action.
Encore mieux qu'un bon message d'erreur est une conception soignée qui empêche qu'un problème ne se produise en premier lieu. Éliminez les conditions sujettes aux erreurs ou vérifiez-les et présentez aux utilisateurs une option de confirmation avant qu'ils ne s'engagent dans l'action.

---> Hors manipulation manuelle d'url, qui ne pose qu'un problème de page vide, la conception est faite de manière à éviter toute erreur possible.




* Reconnaissance plutôt que rappel
* Reconnaissance plutôt que rappel


Minimisez la charge mémoire de l'utilisateur en rendant visibles les objets, les actions et les options. L'utilisateur ne devrait pas avoir à se souvenir des informations d'une partie du dialogue à l'autre. Les instructions d'utilisation du système doivent être visibles ou facilement récupérables chaque fois que cela est approprié.
Minimisez la charge mémoire de l'utilisateur en rendant visibles les objets, les actions et les options. L'utilisateur ne devrait pas avoir à se souvenir des informations d'une partie du dialogue à l'autre. Les instructions d'utilisation du système doivent être visibles ou facilement récupérables chaque fois que cela est approprié.

---> Le dialogue n'étant composé que de deux fenêtre, le problème ne se pose pas




* Flexibilité et efficacité d'utilisation
* Flexibilité et efficacité d'utilisation


Les accélérateurs - invisibles pour l'utilisateur novice - peuvent souvent accélérer l'interaction pour l'utilisateur expert, de sorte que le système peut répondre à la fois aux besoins des utilisateurs inexpérimentés et expérimentés. Permettre aux utilisateurs de personnaliser les actions fréquentes.
Les accélérateurs - invisibles pour l'utilisateur novice - peuvent souvent accélérer l'interaction pour l'utilisateur expert, de sorte que le système peut répondre à la fois aux besoins des utilisateurs inexpérimentés et expérimentés. Permettre aux utilisateurs de personnaliser les actions fréquentes.

---> Par construction notre solution ne fournit pas de mode expert : ce scénario est destiné à un utilisateur novice.




* Design esthétique et minimaliste
* Design esthétique et minimaliste


Les dialogues ne doivent pas contenir d'informations non pertinentes ou rarement nécessaires. Chaque unité d'information supplémentaire dans un dialogue entre en concurrence avec les unités d'information pertinentes et diminue leur visibilité relative.
Les dialogues ne doivent pas contenir d'informations non pertinentes ou rarement nécessaires. Chaque unité d'information supplémentaire dans un dialogue entre en concurrence avec les unités d'information pertinentes et diminue leur visibilité relative.


---> Actuellement est systématiquement affiché la liste des services d'un producteur, systématiquement vide puisque cette fonctionnalité n'a pas été implémentée


* Aider les utilisateurs à reconnaître, diagnostiquer et récupérer les erreurs.


* Aider les utilisateurs à reconnaître, diagnostiquer et récupérer les erreurs.
Les messages d'erreur doivent être rédigés dans un langage simple (pas de codes), indiquer précisément le problème et proposer une solution constructive.


Les messages d'erreur doivent être rédigés dans un langage simple (pas de codes), indiquer précisément le problème et proposer une solution constructive.


---> Il n'existe pas de oage d'erreur, en cas d'accès incorrect, une page sans contenu est affichée.


* Aide et documentation
* Aide et documentation


Même s'il est préférable que le système puisse être utilisé sans documentation, il peut être nécessaire de fournir de l'aide et de la documentation. Ces informations doivent être faciles à rechercher, axées sur la tâche de l'utilisateur, énumérer les mesures concrètes à prendre et ne pas être trop volumineuses.
Même s'il est préférable que le système puisse être utilisé sans documentation, il peut être nécessaire de fournir de l'aide et de la documentation. Ces informations doivent être faciles à rechercher, axées sur la tâche de l'utilisateur, énumérer les mesures concrètes à prendre et ne pas être trop volumineuses.

---> Aucune documentation n'est fournie.


== Evaluation qualité du projet ==
== Evaluation qualité du projet ==
Line 210: Line 228:


== Evaluation économique du projet ==
== Evaluation économique du projet ==
===Nombre d'heures travaillées===
[[Media:ECOM_BTB_Heures_travaillees.pdf|Nombre d'heures travaillées]]


=== COCOMO ===
=== COCOMO ===
Line 232: Line 252:


== Slides de présentation conception ==
== Slides de présentation conception ==
* [[Media:ECOM-1FO_1819_BTB_YYYYYY.pdf]]
* [[Media:BTB_Audit2.pdf | Slides Audit 2 (PDF)]]


== Slides de présentation finale ==
== Slides de présentation finale ==
*[[Media:ECOM-1FO_1819_BTB_YYYYYY.pdf]]
*[[Media:ECOM_BTB_soutenance.pdf|soutenance finale]]


== Auto-évaluation ==
== Auto-évaluation ==
* [[Media:ECOM-1FO_1819_BTB_YYYYYY.pdf]]
* [[Media:ECOM_BTB_Auto-evaluation.pdf|Auto-évaluation]]


== Slides de présentation client ==
== Slides de présentation client ==
* [[Media:ECOM-1FO_1819_BTB_YYYYYY.pdf]]
* [[Media:BTB_Audit1.pdf | Slides Audit 1 (PDF)]]


== Glossaire ==
== Glossaire ==
'''Essence''' : Type d'un bois (exemple : If, Hêtre, Chêne...)

Latest revision as of 08:42, 11 February 2019

<<<< Retour vers la page ECOM 2018-2019

Description du projet

Le chauffage individuel au bois non performant est une des causes majeures de pics de pollution de la région de Grenoble en période hivernale. Celui-ci est du à des émissions de particules dues à une mauvaise combustion venant d'appareils anciens, d'un défaut d'entretien ou de bois trop humide. Afin de lutter contre ce phénomène, FIBOIS AURA, Grenoble Alpes Métropole et le PNR du Vercors ont décidé de mettre en place une plateforme afin d'encourager de manière innovante les consommateurs à se tourner vers des professionnels en capacité de leur fournir un produit de qualité, sec. L'objectif est donc de regrouper la demande de bois en bûche des particuliers et de l'orienter vers des professionnels en capacité de livrer du combustible de qualité.

C'est dans cette démarche qu'ont été contactés 5 étudiants de 1F05 à Polytech Grenoble afin de mettre en place cette plateforme dans le cadre de leur enseignement portant sur le e-commerce.

Ce projet consiste dans le développement d'un prototype d'application ayant pour fonction la prise de commande en ligne par des consommateurs, le groupage des commandes par secteurs géographiques, le choix de fournisseurs professionnels, l'optimisation logistique pour la livraison et enfin des propositions de services associés.

L'équipe et leurs rôles

NOM Prénom Mail Rôle
1 BOUCHERIMA Amina amina.boucherima@etu.univ-grenoble-alpes.fr Développeur - Front end
2 CHANET Zoran zoran.chanet@etu.univ-grenoble-alpes.fr Développeur - Back End
3 EZ-ZINE Najwa najwa.ez-zine@etu.univ-grenoble-alpes.fr Développeur - Back End
4 MOLION Enzo enzo.molion@etu.univ-grenoble-alpes.fr Scrum Master - Front End
5 VALETTE Léo leo.valette@etu.univ-grenoble-alpes.fr Chef de projet - Intégration Continue - Back End

Gestion d'équipe et de projet

Ayant un délai court et une équipe peu nombreuse, nous avons adopté la méthode Scrum pour la gestion du projet.

En tant que chef de projet, Léo VALETTE a joué le rôle de Product Owner, et Enzo MOLION a été désigné Scrum Master.

Dans le cadre de cette méthode ont été mis en place des Sprints de 3 semaines et des "daily meetings" hebdomadaires. Il a été décidé d'utiliser le site web de gestion de tableau kanban Trello.

L'équipe a ensuite été divisée en deux pôles : frontend et backend. Ce découpage a été fait de manière à séparer les binômes historiques. De plus, Léo VALETTE a été attribué au backend mais réalise également l'interface avec le frontend et a ensuite été pour cette raison désigné responsable de l'intégration continue.

Technologies

Outils

  • Gitlab : pour le dépôt, pour la documentation, l'intégration en continu. Notre dépôt ici
  • Trello : pour la gestion des sprints et des user stories. Notre Trello ici
  • Suite Google Drive : pour la répartition et la gestion des tâches hors code (rédaction de documents etc)

Livrables

Journal

Slides

Dossier de conception système

Dossier de conception système

Analyse des scénarios clients

Maquettes

Scénario 1

SRS

SRS

Diagramme UML

Architecture

Schéma relationnel

Modèles des tâches

Modèles des tâches

IHM abstraite

Dépôt Git

Dépôt GitLab

Application en ligne

website

API OpenAPI

Les heuristiques de NIELSEN

Voici les commentaires que nous pouvons faire pour analyser l'IHM de notre site selon les 10 heuristiques de Nielsen


  • Visibilité de l'état du système
    Le système devrait toujours tenir les utilisateurs informés de ce qui se passe, grâce à une rétroaction appropriée dans un délai raisonnable.

---> Pas de rétroaction durant le temps d'attente suite à un appel à l'API


  • Correspondance entre le système et le monde réel
    Le système devrait parler la langue de l'utilisateur, avec des mots, des phrases et des concepts familiers à l'utilisateur, plutôt que des termes orientés système. Suivez les conventions du monde réel, en faisant apparaître les informations dans un ordre naturel et logique.

.

---> Oui, nous avons respecté le langage métier.


  • Contrôle et liberté de l'utilisateur
    Les utilisateurs choisissent souvent les fonctions du système par erreur et ont besoin d'une "sortie de secours" clairement marquée pour quitter l'état non désiré sans avoir à passer par un dialogue prolongé. Support annuler et refaire.

---> Nous n'avons pas implémenter de bouton retour (mais c'est assez rapide à ajouter)


  • Cohérence et normes
    Les utilisateurs ne devraient pas avoir à se demander si des mots, des situations ou des actions différents signifient la même chose. Suivre les conventions de la plate-forme.

---> L'interface est suffisamment simple pour ne présenter aucune ambigüité


  • Prévention des erreurs
    Encore mieux qu'un bon message d'erreur est une conception soignée qui empêche qu'un problème ne se produise en premier lieu. Éliminez les conditions sujettes aux erreurs ou vérifiez-les et présentez aux utilisateurs une option de confirmation avant qu'ils ne s'engagent dans l'action.

---> Hors manipulation manuelle d'url, qui ne pose qu'un problème de page vide, la conception est faite de manière à éviter toute erreur possible.


  • Reconnaissance plutôt que rappel
    Minimisez la charge mémoire de l'utilisateur en rendant visibles les objets, les actions et les options. L'utilisateur ne devrait pas avoir à se souvenir des informations d'une partie du dialogue à l'autre. Les instructions d'utilisation du système doivent être visibles ou facilement récupérables chaque fois que cela est approprié.

---> Le dialogue n'étant composé que de deux fenêtre, le problème ne se pose pas


  • Flexibilité et efficacité d'utilisation
    Les accélérateurs - invisibles pour l'utilisateur novice - peuvent souvent accélérer l'interaction pour l'utilisateur expert, de sorte que le système peut répondre à la fois aux besoins des utilisateurs inexpérimentés et expérimentés. Permettre aux utilisateurs de personnaliser les actions fréquentes.

---> Par construction notre solution ne fournit pas de mode expert : ce scénario est destiné à un utilisateur novice.


  • Design esthétique et minimaliste
    Les dialogues ne doivent pas contenir d'informations non pertinentes ou rarement nécessaires. Chaque unité d'information supplémentaire dans un dialogue entre en concurrence avec les unités d'information pertinentes et diminue leur visibilité relative.

---> Actuellement est systématiquement affiché la liste des services d'un producteur, systématiquement vide puisque cette fonctionnalité n'a pas été implémentée


  • Aider les utilisateurs à reconnaître, diagnostiquer et récupérer les erreurs.
    Les messages d'erreur doivent être rédigés dans un langage simple (pas de codes), indiquer précisément le problème et proposer une solution constructive.

---> Il n'existe pas de oage d'erreur, en cas d'accès incorrect, une page sans contenu est affichée.

  • Aide et documentation
    Même s'il est préférable que le système puisse être utilisé sans documentation, il peut être nécessaire de fournir de l'aide et de la documentation. Ces informations doivent être faciles à rechercher, axées sur la tâche de l'utilisateur, énumérer les mesures concrètes à prendre et ne pas être trop volumineuses.

---> Aucune documentation n'est fournie.

Evaluation qualité du projet

Rapports SonarQube

Evaluation économique du projet

Nombre d'heures travaillées

Nombre d'heures travaillées

COCOMO

Evaluation économique du projet

Afin de procéder à l'analyse économique de notre projet, nous avons calculé son nombre de lignes de code (dans src, webpack et dans nos fichiers de configuration) qui est de 35721.

Via cette calculatrice, nous avons estimé les salaires des membres de l'équipe. En considérant que nous sommes ingénieurs fullstack, cela revient à 2950$ par mois et par personne.


Cocomo Brûle ta Bûche !

Evaluation de la cybersécurité du projet (option)

Evaluation des performances (option)

Gestion des risques (option)

Slides de présentation conception

Slides de présentation finale

Auto-évaluation

Slides de présentation client

Glossaire

Essence : Type d'un bois (exemple : If, Hêtre, Chêne...)