Projet 3

Jeu du morpion

Le jeu se joue à la console entre deux joueurs qui entrent alternativement soit le caractère X, soit le caractère O

Un joueur gagne s'il réussit à avoir un alignement sur une des lignes, ou une des colonnes, ou une des diagonales

Si au bout des neuf coups joués il n'y a pas d'alignement, le match est considéré comme nul

Le but de ce projet, au delà de coder un jeu de morpion, est de comprendre l'intérêt de la programmation modulaire et des tests

Dans l'E.N.T vous a été fourni deux fichiers, le fichier tictac.py et morpion.py

Pourquoi deux fichiers ?

Le fichier tictac.py doit contenir toutes les fonctions qui permettent de jouer à la console le jeu du Morpion

Le module doctest importé dans le fichier tictac.py permet de tester les fonctions une par une

Ensuite une fois les tests terminés on peut jouer en exécutant le fichier morpion.py qui importe le module tictac.py

Attendus

Il convient de suivre pas à pas et scrupuleusement les questions suivantes pour la mise au point du projet
  1. Commencer par annoter chaque fonction
  2. Après avoir bien lu et compris la spécification et les tests de la fonction alignementLigne(tableau,numLigne), définir la fonction alignementLigne(tableau,numLigne)
  3. Exécuter le fichier tictac.py revient à tester pour l'instant la fonction alignementLigne(tableau,numLigne)

    Vous devez observer ceci

    Que signifient ces lignes ?

    Après le symbole >>> le module doctest va exécuter la fonction alignementLigne(tableau,numLigne) sur le cas particulier où la valeur de plateau est [[ '#','#','O'],['X','X','X'],['#','O','O']] et la valeur de numLigne est 1 et comparer le résultat qu'il a obtenu avec le résultat espéré que vous avez mis juste en dessous c'est à dire True

    En effet sur ce cas particulier il y a un alignement dans la ligne numéro 1 où il n'y a que des X

    S'il obtient le même résultat que celui que vous avez mis alors il dit que le test est ok

    Cependant à la fin du rapport de tests on observe aussi que beaucoup de fonctions n'ont pas été testées

    C'est normal certaines n'ont pas été définies et d'autres comme affichePlateau(plateau) qui retourne None ne seront pas testées

    A la fin de la mise au point du projet vous devrez avoir comme rapport de tests

    Le message "Test passed" vous assure maintenant que si vos exemples de test ont bien été choisis votre programme est "presque" correct

    Il reste peut-être des erreurs mais la méthode que vous avez utilisé en a éliminé un grand nombre au cours des tests

  4. En adaptant la spécification de la fonction alignementLigne(tableau,numLigne) écrire celle de la fonction alignementColonne(tableau,numColonne)

    Puis ajouter trois lignes de tests

    Puis définir la fonction alignementColonne(tableau,numColonne)

    Tester ensuite la fonction

  5. La méthode utilisée est la suivante
    1. Annoter et spécifier la fonction en ajoutant des tests
    2. Définir la fonction
    3. Passer à la fonction suivante uniquement si les tests sont réussis
  6. Documenter, définir et tester la fonction alignementColonnes(plateau) (regarder l'exemple de alignementLignes(plateau))
  7. Documenter, définir et tester les fonctions alignementDiagonale1(plateau) et alignementDiagonale2(plateau)
  8. Documenter, définir et tester la fonction alignementDiagonales(plateau)
  9. Documenter, définir et tester la fonction alignement(plateau) qui retourne True s'il y a un alignement dans une des trois lignes ou une des trois colonnes ou une des deux diagonales, False sinon
  10. La fonction sontValides(plateau,x,y) est déjà documentée avec des tests. Il reste à la définir et à la tester. A quoi sert cette fonction ?

    La façon choisie de programmer le jeu du Morpion est la suivante :

    • Le premier joueur qui joue a le numéro 0, le second le numéro 1
    • Le premier joueur joue avec le symbole X, le second avec le symbole O

    Le joueur doit préciser en quel endroit du plateau il veut mettre le caractère et cet endroit est repéré par des coordonnées (x,y) où x et y sont deux entiers

    (x,y) sont valides si 0 <= x <= 2 et 0 <= y <= 2 et si plateau[x][y] == '#'

    On ne traitera pas le cas où l'utilisateur entre n'importe quoi à la place de deux entiers

    Tester sontValides(plateau,x,y)

  11. La fonction partieEstFinie(plateau,nbCoups) est déjà documentée avec des exemples de tests. Bien comprendre la documentation pour définir cette fonction

    Tester

  12. A ce stade le jeu est presque fini d'être mis au point et les deux dernières fonctions jouer(plateau,numJoueur) et unePartie(plateau) seront testées en exécutant morpion.py

    La fonction jouer(plateau,numJoueur) consiste dans un premier temps, tant que les coordonnées entrées par un joueur ne sont pas valides, à lui demander d'entrer les coordonnées par l'instruction

    
    i,j  = tuple(input("NumLigne,NumColonne ? -->  "))
    
    
    On demande au joueur d'entrer au clavier une suite de deux nombres,sans espace, où le premier est le numéro de ligne, le second le numéro de colonne par exemple
    
    11
    
    

    Dans un second temps, une fois que les coordonnées sont valides, on affecte à plateau le symbole car associé au numéro du joueur

    
    plateau[lig][col] = car
    
    
  13. Enfin il reste à définir la fonction unePartie(plateau)

    Tant que la partie n'est pas finie on fait jouer un joueur de numéro numJoueur avec la fonction jouer(plateau,numJoueur)

    On fait évoluer le numéro du joueur numJoueur à chaque tour par l'instruction

    
    numJoueur = (numJoueur + 1) % 2
    
    

    Enfin pour que le jeu soit compréhensible on demande à ce qu'il y ait un affichage dans la console :

    • du plateau de jeu à chaque tour
    • un message pour annoncer le tour de X ou O
    • l'affichage du nombre de coups déjà joués

    A la fin du jeu on demande à ce que soit affiché soit un message disant quel joueur a gagné X ou O

    soit un message annonçant un match nul

  14. Arrivé à ce stade vous avez fini ! Vous devez rendre à la date demandé uniquement le fichier tictac.py que vous aurez renommé votre_nom.py