Compare commits
22 Commits
Author | SHA1 | Date | |
---|---|---|---|
02873d405b | |||
|
877fecb923 | ||
bb891a52a8 | |||
6e303b8977 | |||
ed13a79a2f | |||
ed163b1a9a | |||
c1aa2e4775 | |||
894688c5f0 | |||
7970ca8df6 | |||
d0db3d84a3 | |||
6e988ca75a | |||
906f075a95 | |||
09cf3836c2 | |||
c762aac862 | |||
a606a72476 | |||
9f0f1ae00e | |||
1f44c6ee69 | |||
3f63db1a92 | |||
19d2e618c3 | |||
|
9593ca5fab | ||
6e8f63e2c0 | |||
|
a7b45071cc |
4
.gitignore
vendored
4
.gitignore
vendored
@@ -1 +1,5 @@
|
|||||||
/target/
|
/target/
|
||||||
|
<<<<<<< HEAD
|
||||||
|
=======
|
||||||
|
*.xml
|
||||||
|
>>>>>>> 6e8f63e2c0b4f89a6f46070511e8ce4223af4bb7
|
||||||
|
4
aLire.txt
Normal file
4
aLire.txt
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
dépôt gitea : https://gitea.lyc-lecastel.fr/delphine.thevenot/2026TestsBibliotheque.git
|
||||||
|
branche : developpement
|
||||||
|
|
||||||
|
multibranches, fusions difficiles, à revoir
|
@@ -0,0 +1,121 @@
|
|||||||
|
/*
|
||||||
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
||||||
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
||||||
|
*/
|
||||||
|
package com.mycompany.bibliotheque.Controle;
|
||||||
|
|
||||||
|
import com.mycompany.bibliotheque.Metier.Livre;
|
||||||
|
import com.mycompany.bibliotheque.Metier.Utilisateur;
|
||||||
|
import java.util.Scanner;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Classe de contrôle de la classe Livre
|
||||||
|
* @author dthev
|
||||||
|
*/
|
||||||
|
public class LivreValide {
|
||||||
|
// 1. ISBN : exactement 13 chiffres
|
||||||
|
public static boolean isValidIsbn(String isbn) {
|
||||||
|
// TODO Emile: implémenter la validation
|
||||||
|
|
||||||
|
boolean valide = true;
|
||||||
|
if(isbn.length() == 13){
|
||||||
|
int i = 0;
|
||||||
|
while (i < 13 && valide) {
|
||||||
|
if(!Character.isDigit(isbn.charAt(i))){
|
||||||
|
valide = false;
|
||||||
|
}else{
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
valide = false;
|
||||||
|
}
|
||||||
|
return valide;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// 2. Titre : pas de balises HTML/JS (<script>, <img>, etc.)
|
||||||
|
public static boolean isValidTitre(String Titre) {
|
||||||
|
// TODO Salomon: implémenter la validation
|
||||||
|
boolean test = true;
|
||||||
|
int i = 0;
|
||||||
|
while (i < Titre.length() && test) {
|
||||||
|
if(Titre.charAt(i) == '<' || Titre.charAt(i) == '>'){
|
||||||
|
test = false;
|
||||||
|
}else{
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return test;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 3. Auteur : non vide et pas de chiffres ou caractères spéciaux
|
||||||
|
public static boolean isValidAuteur(String auteur) {
|
||||||
|
|
||||||
|
//verification que auteur n'est pas vide ou null
|
||||||
|
if (auteur == null || auteur.isBlank()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
//ajout d'un pattern pour avoir uniquement des minuscules/majuscules
|
||||||
|
String pattern = "^[a-zA-Z -]+$";
|
||||||
|
//verification boolean que le nom d'auteur corresponde au patterne
|
||||||
|
return auteur.matches(pattern);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 4. Titre : longueur maximale 200 caractères
|
||||||
|
public static boolean isLongueurTitreValid(String titre) {
|
||||||
|
// TODO Morgann: implémenter la validation
|
||||||
|
boolean valide = false;
|
||||||
|
if(titre.length()<=200 && titre != "" && titre != null){
|
||||||
|
valide = true;
|
||||||
|
}
|
||||||
|
return valide;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 5. Titre : non null et au moins 2 caractères
|
||||||
|
public static boolean isContenuTitreValide(String titre) {
|
||||||
|
// TODO Steve: implémenter la validation
|
||||||
|
if (titre == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
boolean contenuValide = titre.matches(".*[a-zA-Z].*[a-zA-Z].*");
|
||||||
|
|
||||||
|
return contenuValide;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IsDisponible()
|
||||||
|
* Vérifier livre pas déjà emprunté
|
||||||
|
* @author Emile
|
||||||
|
*/
|
||||||
|
public static boolean isDisponible (Livre leLivre){
|
||||||
|
boolean valide = true;
|
||||||
|
if(leLivre.isEmprunte()){
|
||||||
|
valide = false;
|
||||||
|
}
|
||||||
|
return valide;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IsDisponible()
|
||||||
|
* Vérifier livre pas déjà emprunté
|
||||||
|
* @author Morgann/Emile
|
||||||
|
*/
|
||||||
|
public static boolean retourLivre(Utilisateur user){
|
||||||
|
Scanner sc = new Scanner(System.in);
|
||||||
|
int i=0;
|
||||||
|
for(Livre unLivre:user.getEmprunts()){
|
||||||
|
i++;
|
||||||
|
System.out.println(i+". "+unLivre.getTitre());
|
||||||
|
}
|
||||||
|
System.out.print("Merci de faire le choix du livre à restituer: ");
|
||||||
|
int choix = sc.nextInt();
|
||||||
|
Livre leLivre = user.getEmprunts().get(choix-1);
|
||||||
|
|
||||||
|
leLivre.setEmprunte(false);
|
||||||
|
user.getEmprunts().remove(leLivre);
|
||||||
|
return leLivre.isEmprunte();
|
||||||
|
}
|
||||||
|
}
|
@@ -1,41 +0,0 @@
|
|||||||
/*
|
|
||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
|
||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
|
||||||
*/
|
|
||||||
package com.mycompany.bibliotheque.Contrôle;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Classe de contrôle de la classe Livre
|
|
||||||
* @author dthev
|
|
||||||
*/
|
|
||||||
public class LivreValide {
|
|
||||||
// 1. ISBN : exactement 13 chiffres
|
|
||||||
public static boolean isValidIsbn(String isbn) {
|
|
||||||
// TODO Emile: implémenter la validation
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 2. Titre : pas de balises HTML/JS (<script>, <img>, etc.)
|
|
||||||
public static boolean isValidTitre(String Titre) {
|
|
||||||
// TODO: implémenter la validation
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 3. Auteur : non vide et pas de chiffres ou caractères spéciaux
|
|
||||||
public static boolean isValidAuteur(String auteur) {
|
|
||||||
// TODO: implémenter la validation
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 4. Titre : longueur maximale 200 caractères
|
|
||||||
public static boolean isLongueurTitreValid(String titre) {
|
|
||||||
// TODO Morgann: implémenter la validation
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 5. Titre : non null et au moins 2 caractères
|
|
||||||
public static boolean isContenuTitreValide(String titre) {
|
|
||||||
// TODO Steve: implémenter la validation
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
@@ -10,10 +10,12 @@ package com.mycompany.bibliotheque;
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
import com.mycompany.bibliotheque.Métier.Bibliotheque;
|
import com.mycompany.bibliotheque.Controle.LivreValide;
|
||||||
import com.mycompany.bibliotheque.Métier.Emprunt;
|
import com.mycompany.bibliotheque.Metier.Bibliotheque;
|
||||||
import com.mycompany.bibliotheque.Métier.Utilisateur;
|
import com.mycompany.bibliotheque.Metier.Emprunt;
|
||||||
import com.mycompany.bibliotheque.Métier.Livre;
|
import com.mycompany.bibliotheque.Metier.Utilisateur;
|
||||||
|
import com.mycompany.bibliotheque.Metier.Livre;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Scanner;
|
import java.util.Scanner;
|
||||||
|
|
||||||
public class GestionBibliotheque {
|
public class GestionBibliotheque {
|
||||||
@@ -21,15 +23,18 @@ public class GestionBibliotheque {
|
|||||||
Scanner sc = new Scanner(System.in);
|
Scanner sc = new Scanner(System.in);
|
||||||
int choix=0;
|
int choix=0;
|
||||||
Bibliotheque laBibli = new Bibliotheque();
|
Bibliotheque laBibli = new Bibliotheque();
|
||||||
|
ArrayList<Livre> mesLivres = new ArrayList<>();
|
||||||
Livre l1 = new Livre("Le secret des secrets","Dan Brown","9782709668385",true);
|
Livre l1 = new Livre("Le secret des secrets","Dan Brown","9782709668385",true);
|
||||||
Utilisateur u1 = new Utilisateur("Alice");
|
mesLivres.add(l1);
|
||||||
|
Utilisateur u1 = new Utilisateur("Alice", mesLivres);
|
||||||
|
|
||||||
System.out.println("Bienvenue dans la bibliothèque !");
|
System.out.println("Bienvenue dans la bibliothèque !");
|
||||||
while (choix!=4){
|
while (choix!=4){
|
||||||
System.out.println("1. Afficher un livre");
|
System.out.println("1. Afficher un livre");
|
||||||
System.out.println("2. Ajouter un livre");
|
System.out.println("2. Ajouter un livre");
|
||||||
System.out.println("3. Afficher les livres");
|
System.out.println("3. Afficher les livres");
|
||||||
System.out.println("4. Quitter");
|
System.out.println("4. Restituer un livre");
|
||||||
|
System.out.println("5. Quitter");
|
||||||
System.out.print("Merci de faire votre choix : ");
|
System.out.print("Merci de faire votre choix : ");
|
||||||
choix = sc.nextInt();
|
choix = sc.nextInt();
|
||||||
switch (choix) {
|
switch (choix) {
|
||||||
@@ -44,6 +49,21 @@ public class GestionBibliotheque {
|
|||||||
System.out.println("---"+leLivre.toString());
|
System.out.println("---"+leLivre.toString());
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case 4:
|
||||||
|
boolean restitution = LivreValide.retourLivre(u1);
|
||||||
|
String message = "";
|
||||||
|
|
||||||
|
if (restitution) {
|
||||||
|
message += "Le livre a été restitué !\n";
|
||||||
|
message += "\\nVous avez désormais "+u1.getEmprunts().size()+" livres empruntés sur 3 !\n";
|
||||||
|
message += "Merci, "+u1.getNom()+", d'avoir emprunté chez nous !";
|
||||||
|
|
||||||
|
} else {
|
||||||
|
message += "Le livre n'a pas été restitué.";
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.println(message);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
||||||
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
||||||
|
*/
|
||||||
|
package com.mycompany.bibliotheque.Metier;
|
||||||
|
|
||||||
|
import com.mycompany.bibliotheque.Controle.LivreValide;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Classe métier
|
||||||
|
* @author dthev
|
||||||
|
*/
|
||||||
|
public class Bibliotheque {
|
||||||
|
private List<Livre> lesLivres = new ArrayList<>();
|
||||||
|
|
||||||
|
// 5. ISBN doit être unique
|
||||||
|
public boolean addLivre(Livre b) {
|
||||||
|
//ajoute b si valide et si n'existe pas - à écrire
|
||||||
|
String issues = "";
|
||||||
|
if (!LivreValide.isValidIsbn(b.getIsbn())) issues += "1 ";
|
||||||
|
if (!LivreValide.isValidTitre(b.getTitre())) issues += "2 ";
|
||||||
|
if (!LivreValide.isValidAuteur(b.getAuteur())) issues += "3 ";
|
||||||
|
if (!LivreValide.isLongueurTitreValid(b.getTitre())) issues += "4 ";
|
||||||
|
if (!LivreValide.isContenuTitreValide(b.getTitre())) issues += "5";
|
||||||
|
|
||||||
|
System.out.println(issues);
|
||||||
|
|
||||||
|
if (issues.length() < 1) {
|
||||||
|
System.out.println("valide");
|
||||||
|
for (Livre livre : this.getLesLivres()) {
|
||||||
|
if (livre.getIsbn().equals(b.getIsbn())) return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
lesLivres.add(b);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
} else return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Livre> getLesLivres() {
|
||||||
|
return lesLivres;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setLesLivres(List<Livre> lesLivres) {
|
||||||
|
this.lesLivres = lesLivres;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@@ -2,10 +2,10 @@
|
|||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
||||||
*/
|
*/
|
||||||
package com.mycompany.bibliotheque.Métier;
|
package com.mycompany.bibliotheque.Metier;
|
||||||
|
|
||||||
import com.mycompany.bibliotheque.Métier.Utilisateur;
|
import com.mycompany.bibliotheque.Metier.Utilisateur;
|
||||||
import com.mycompany.bibliotheque.Métier.Livre;
|
import com.mycompany.bibliotheque.Metier.Livre;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
@@ -2,7 +2,7 @@
|
|||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
||||||
*/
|
*/
|
||||||
package com.mycompany.bibliotheque.Métier;
|
package com.mycompany.bibliotheque.Metier;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
@@ -2,22 +2,21 @@
|
|||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
||||||
*/
|
*/
|
||||||
package com.mycompany.bibliotheque.Métier;
|
package com.mycompany.bibliotheque.Metier;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author dthev
|
* @author dthev
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import com.mycompany.bibliotheque.Métier.Livre;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class Utilisateur {
|
public class Utilisateur {
|
||||||
private String nom;
|
private final String nom;
|
||||||
private List<Livre> emprunts;
|
private final ArrayList<Livre> emprunts;
|
||||||
|
|
||||||
public Utilisateur(String nom) {
|
public Utilisateur(String nom, ArrayList<Livre> mesLivres) {
|
||||||
this.nom = nom;
|
this.nom = nom;
|
||||||
this.emprunts = new ArrayList<>();
|
this.emprunts = new ArrayList<>();
|
||||||
}
|
}
|
||||||
@@ -30,8 +29,18 @@ public class Utilisateur {
|
|||||||
return emprunts;
|
return emprunts;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// TODO: ajouter un emprunt si l'utilisateur a moins de 3 livres
|
// TODO: ajouter un emprunt si l'utilisateur a moins de 3 livres
|
||||||
|
/**
|
||||||
|
* @author Medhi
|
||||||
|
* @param livre
|
||||||
|
*/
|
||||||
public boolean emprunterLivre(Livre livre) {
|
public boolean emprunterLivre(Livre livre) {
|
||||||
return false; // à compléter
|
if (emprunts.size() < 3) {
|
||||||
|
emprunts.add(livre);
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
@@ -1,33 +0,0 @@
|
|||||||
/*
|
|
||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
|
||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
|
||||||
*/
|
|
||||||
package com.mycompany.bibliotheque.Métier;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Classe métier
|
|
||||||
* @author dthev
|
|
||||||
*/
|
|
||||||
public class Bibliotheque {
|
|
||||||
private List<Livre> lesLivres = new ArrayList<>();
|
|
||||||
|
|
||||||
// 5. ISBN doit être unique
|
|
||||||
public boolean addLivre(Livre b) {
|
|
||||||
//ajoute b si valide et si n'existe pas - à écrire
|
|
||||||
lesLivres.add(b);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<Livre> getLesLivres() {
|
|
||||||
return lesLivres;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setLesLivres(List<Livre> lesLivres) {
|
|
||||||
this.lesLivres = lesLivres;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
@@ -4,8 +4,8 @@
|
|||||||
*/
|
*/
|
||||||
package com.mycompany.bibliotheque;
|
package com.mycompany.bibliotheque;
|
||||||
|
|
||||||
import com.mycompany.bibliotheque.Métier.Bibliotheque;
|
import com.mycompany.bibliotheque.Metier.Bibliotheque;
|
||||||
import com.mycompany.bibliotheque.Métier.Livre;
|
import com.mycompany.bibliotheque.Metier.Livre;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -29,14 +29,50 @@ public class BibliothequeTest {
|
|||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testAddLivre() {
|
public void testAddLivre() {
|
||||||
System.out.println("addLivre");
|
System.out.println("addLivre");
|
||||||
Livre b = null;
|
|
||||||
Bibliotheque instance = new Bibliotheque();
|
Bibliotheque instance = new Bibliotheque();
|
||||||
boolean expResult = false;
|
|
||||||
boolean result = instance.addLivre(b);
|
// Ajout d'un livre avec ISBN invalide
|
||||||
assertEquals(expResult, result);
|
Livre livre = new Livre("Naruto", "Masashi Kishimoto", "1234ABCD567", false);
|
||||||
// TODO review the generated test code and remove the default call to fail.
|
boolean ajoutLivre = instance.addLivre(livre);
|
||||||
fail("The test case is a prototype.");
|
System.out.println("Refus de l'ISBN invalide");
|
||||||
|
assertFalse("L'ISBN du livre n'est pas censé être valide avec lettres !", ajoutLivre);
|
||||||
|
|
||||||
|
// Ajout d'un livre avec titre invalide
|
||||||
|
livre = new Livre("<script>Dragon Ball</script>", "Akira Toriyama", "8762709652385", false);
|
||||||
|
ajoutLivre = instance.addLivre(livre);
|
||||||
|
System.out.println("Refus de titre invalide");
|
||||||
|
assertFalse("Le titre du livre n'est pas censé être valide avec des balises !", ajoutLivre);
|
||||||
|
|
||||||
|
// Ajout d'un livre avec auteur invalide
|
||||||
|
livre = new Livre("Dr. STONE", "Bo1ch1", "8762207682385", false);
|
||||||
|
ajoutLivre = instance.addLivre(livre);
|
||||||
|
System.out.println("Refus d'auteur invalide");
|
||||||
|
assertFalse("L'auteur du livre n'est pas censé être valide avec des caractères non alphabétiques !", ajoutLivre);
|
||||||
|
|
||||||
|
// Ajout d'un livre avec longueur de titre invalide
|
||||||
|
livre = new Livre("Dandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadandadan", "Yukinobu Tatsu", "1702203672985", false);
|
||||||
|
ajoutLivre = instance.addLivre(livre);
|
||||||
|
System.out.println("Refus de longueur de titre invalide");
|
||||||
|
assertFalse("Le titre n'est pas censé être valide avec une longueur excédant les 200 caractères !", ajoutLivre);
|
||||||
|
|
||||||
|
// Ajout d'un livre avec contenu de titre invalide
|
||||||
|
livre = new Livre("007", "Steve Maingana", "3712503622788", false);
|
||||||
|
ajoutLivre = instance.addLivre(livre);
|
||||||
|
System.out.println("Refus de contenu de titre invalide invalide");
|
||||||
|
assertFalse("Le titre n'est pas censé être valide sans au moins 2 caractères alphabétiques !", ajoutLivre);
|
||||||
|
|
||||||
|
// Premier ajout de livre
|
||||||
|
livre = new Livre("Frieren", "Kanehito Yamada", "6785708652385", false);
|
||||||
|
ajoutLivre = instance.addLivre(livre);
|
||||||
|
System.out.println("Premier ajout d'un même livre");
|
||||||
|
System.out.println(ajoutLivre);
|
||||||
|
assertTrue("La bibliothèque ne permet pas de doublon !", ajoutLivre);
|
||||||
|
|
||||||
|
// Second ajout du même livre
|
||||||
|
ajoutLivre = instance.addLivre(livre);
|
||||||
|
System.out.println("Refus d'ajout du même livre");
|
||||||
|
assertFalse("La bibliothèque ne permet pas de doublon !", ajoutLivre);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
*/
|
*/
|
||||||
package com.mycompany.bibliotheque;
|
package com.mycompany.bibliotheque;
|
||||||
|
|
||||||
import com.mycompany.bibliotheque.Métier.Livre;
|
import com.mycompany.bibliotheque.Metier.Livre;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.*;
|
||||||
@@ -16,7 +16,7 @@ public void testCreationLivre() {
|
|||||||
|
|
||||||
assertNotNull(b);
|
assertNotNull(b);
|
||||||
assertEquals("1984", b.getTitre());
|
assertEquals("1984", b.getTitre());
|
||||||
assertEquals("George Orwel", b.getAuteur()); // corrigé
|
assertEquals("George Orwell", b.getAuteur()); // corrigé
|
||||||
assertEquals("1234567890123", b.getIsbn());
|
assertEquals("1234567890123", b.getIsbn());
|
||||||
assertFalse(b.isEmprunte()); // si la méthode existe
|
assertFalse(b.isEmprunte()); // si la méthode existe
|
||||||
}
|
}
|
||||||
|
@@ -4,7 +4,8 @@
|
|||||||
*/
|
*/
|
||||||
package com.mycompany.bibliotheque;
|
package com.mycompany.bibliotheque;
|
||||||
|
|
||||||
import com.mycompany.bibliotheque.Contrôle.LivreValide;
|
import com.mycompany.bibliotheque.Controle.LivreValide;
|
||||||
|
import com.mycompany.bibliotheque.Metier.Livre;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.*;
|
||||||
@@ -29,12 +30,49 @@ public class LivreValideTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testIsValidIsbn() {
|
public void testIsValidIsbn() {
|
||||||
System.out.println("isValidIsbn");
|
System.out.println("isValidIsbn");
|
||||||
String isbn = "";
|
|
||||||
boolean expResult = false;
|
|
||||||
boolean result = LivreValide.isValidIsbn(isbn);
|
//Test 1 : un isbn avec moins de 13 carractères
|
||||||
assertEquals(expResult, result);
|
System.out.println("Test1 : un isbn avec moins de 13 carractères");
|
||||||
// TODO review the generated test code and remove the default call to fail.
|
String isbn1 = "1234568912";
|
||||||
fail("The test case is a prototype.");
|
boolean expResult1 = false;
|
||||||
|
boolean result1 = LivreValide.isValidIsbn(isbn1);
|
||||||
|
assertEquals("Le nombre de carractère est censé est trop petit",expResult1, result1);
|
||||||
|
assertFalse("Trop petit",LivreValide.isValidIsbn(isbn1));
|
||||||
|
System.out.println("Le test1 est validé");
|
||||||
|
System.out.println("--------------------------------------------------");
|
||||||
|
System.out.println(" ");
|
||||||
|
|
||||||
|
//Test2 : lettre dans l'isbn
|
||||||
|
System.out.println("Test2 : lettre dans l'isbn");
|
||||||
|
String isbn2 = "123456789ABC2";
|
||||||
|
boolean expResult2 = false;
|
||||||
|
boolean result2 = LivreValide.isValidIsbn(isbn2);
|
||||||
|
assertEquals("Les alphas ne sont pas autorisés", expResult2, result2);
|
||||||
|
System.out.println("Le test2 est validé");
|
||||||
|
System.out.println("--------------------------------------------------");
|
||||||
|
System.out.println(" ");
|
||||||
|
|
||||||
|
//Test3 : mauvais nombre de carratère 15
|
||||||
|
System.out.println("Test3: isbn comportant plus de 13 chiffres");
|
||||||
|
String isbn3 = "1234568912123568";
|
||||||
|
boolean expResult3 = false;
|
||||||
|
boolean result3 = LivreValide.isValidIsbn(isbn3);
|
||||||
|
assertEquals("Le nombre de carractère est censé est trop grand",expResult3, result3);
|
||||||
|
System.out.println("Le test3 est validé");
|
||||||
|
System.out.println("--------------------------------------------------");
|
||||||
|
System.out.println(" ");
|
||||||
|
|
||||||
|
//Test4 : Un isbn valide
|
||||||
|
System.out.println("Test4: Un isbn valide");
|
||||||
|
String isbn4 = "1234568912126";
|
||||||
|
boolean expResult4 = true;
|
||||||
|
boolean result4 = LivreValide.isValidIsbn(isbn4);
|
||||||
|
assertEquals("L'isbn est censé être valide",expResult4, result4);
|
||||||
|
System.out.println("Le test4 est validé");
|
||||||
|
System.out.println("--------------------------------------------------");
|
||||||
|
System.out.println(" ");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -44,27 +82,71 @@ public class LivreValideTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testIsValidTitre() {
|
public void testIsValidTitre() {
|
||||||
System.out.println("isValidTitre");
|
System.out.println("isValidTitre");
|
||||||
String Titre = "";
|
|
||||||
boolean expResult = false;
|
System.out.println("Test1 : un titre comportant un '<'");
|
||||||
boolean result = LivreValide.isValidTitre(Titre);
|
String Titre1 = "La chat<perché";
|
||||||
assertEquals(expResult, result);
|
boolean expResult1 = false;
|
||||||
// TODO review the generated test code and remove the default call to fail.
|
boolean result1 = LivreValide.isValidTitre(Titre1);
|
||||||
fail("The test case is a prototype.");
|
assertEquals("Le chevron < n'est pas censé etre accepté",expResult1, result1);
|
||||||
|
System.out.println("Le test1 est validé");
|
||||||
|
System.out.println("--------------------------------------------------");
|
||||||
|
System.out.println(" ");
|
||||||
|
|
||||||
|
System.out.println("Test2 : un titre comportant un '>'");
|
||||||
|
String Titre2 = "La chat >perché";
|
||||||
|
boolean expResult2 = false;
|
||||||
|
boolean result2 = LivreValide.isValidTitre(Titre2);
|
||||||
|
assertEquals("Le chevron > n'est pas censé etre accepté",expResult2, result2);
|
||||||
|
System.out.println("Le test2 est validé");
|
||||||
|
System.out.println("--------------------------------------------------");
|
||||||
|
System.out.println(" ");
|
||||||
|
|
||||||
|
|
||||||
|
System.out.println("Test3 : un titre valide");
|
||||||
|
String Titre3 = "La chat perché";
|
||||||
|
boolean expResult3 = true;
|
||||||
|
boolean result3 = LivreValide.isValidTitre(Titre3);
|
||||||
|
assertEquals("Ce titre est cencé être valide",expResult3, result3);
|
||||||
|
System.out.println("Le test3 est validé");
|
||||||
|
System.out.println("--------------------------------------------------");
|
||||||
|
System.out.println(" ");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test of isValidAuteur method, of class LivreValide.
|
* Test of isValidAuteur method, of class LivreValide.
|
||||||
* @author Medhi/Steve
|
* @author Medhi
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testIsValidAuteur() {
|
public void testIsValidAuteur() {
|
||||||
System.out.println("isValidAuteur");
|
System.out.println("isValidAuteur");
|
||||||
String auteur = "";
|
|
||||||
boolean expResult = false;
|
//Verification Bonne
|
||||||
boolean result = LivreValide.isValidAuteur(auteur);
|
String auteurTrue = "George";
|
||||||
assertEquals(expResult, result);
|
boolean expResult = true;
|
||||||
// TODO review the generated test code and remove the default call to fail.
|
boolean result = LivreValide.isValidAuteur(auteurTrue);
|
||||||
fail("The test case is a prototype.");
|
assertEquals("Cas d'utilisation prévu",expResult, result);
|
||||||
|
|
||||||
|
//Verification avec un nombre
|
||||||
|
String auteurFalse1 = "George4";
|
||||||
|
boolean expResult1 = false;
|
||||||
|
boolean result1 = LivreValide.isValidAuteur(auteurFalse1);
|
||||||
|
assertEquals("Non valide car un nombre est présent", expResult1,result1);
|
||||||
|
|
||||||
|
//Verification avec des caractères spéciaux
|
||||||
|
String auteurFalse2 = "George_";
|
||||||
|
boolean expResult2 = false;
|
||||||
|
boolean result2 = LivreValide.isValidAuteur(auteurFalse2);
|
||||||
|
assertEquals("Non valide car des caractères spéciaux sont présent", expResult2,result2);
|
||||||
|
|
||||||
|
//Verification avec des espace
|
||||||
|
String auteurTrue3 = "George Orwell";
|
||||||
|
boolean result3 = LivreValide.isValidAuteur(auteurTrue3);
|
||||||
|
assertTrue("",result3);
|
||||||
|
|
||||||
|
//Verification avec -
|
||||||
|
String auteurTrue4 = "George-Orwell";
|
||||||
|
boolean result4 = LivreValide.isValidAuteur(auteurTrue4);
|
||||||
|
assertTrue("",result4);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -74,12 +156,30 @@ public class LivreValideTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testIsLongueurTitreValid() {
|
public void testIsLongueurTitreValid() {
|
||||||
System.out.println("isLongueurTitreValid");
|
System.out.println("isLongueurTitreValid");
|
||||||
String titre = "";
|
|
||||||
boolean expResult = false;
|
//test 1 : aucune valeur saisie
|
||||||
boolean result = LivreValide.isLongueurTitreValid(titre);
|
System.out.println("Test avec aucune valeur saisie");
|
||||||
assertEquals(expResult, result);
|
String titre1 = "";
|
||||||
// TODO review the generated test code and remove the default call to fail.
|
boolean expResult1 = false;
|
||||||
fail("The test case is a prototype.");
|
boolean result1 = LivreValide.isLongueurTitreValid(titre1);
|
||||||
|
assertEquals(expResult1, result1);
|
||||||
|
System.out.println("Titre invalide. Aucune valeur n'a été saisie\n");
|
||||||
|
|
||||||
|
//test 2 : titre inférieur à 200
|
||||||
|
System.out.println("Test avec valeur saisie OK");
|
||||||
|
String titre2 = "Hadal Blacksite bestiary";
|
||||||
|
boolean expResult2 = true;
|
||||||
|
boolean result2 = LivreValide.isLongueurTitreValid(titre2);
|
||||||
|
assertEquals(expResult2, result2);
|
||||||
|
System.out.println("Titre valide. Le titre a moins de 200 caractères\n");
|
||||||
|
|
||||||
|
System.out.println("Test avec un titre avec plus de 200 caractères");
|
||||||
|
String titre3 = "YOU !! You could've had everything you ever wanted... Everything I ever wanted... And you still went out of your way to take everything I had left in the process. You entitled brat. You expect me to sit idly by and keep smiling, As if nothing ever happened? Oh, I'm smiling alright... GRINNING ear to ear. Don't even start with that 'following orders' schlock. You knew what you were doing all too well. Sure took your sweet time. Enjoyed every last second of it? Good. *Chuckles* EXCELLENT, even! I'll merely return the favor. And you bet, I'll be enjoying, every last moment, of THIS!!! THE BEST PART!? I get to do this, over, and over, again. You'll come back, I'll know, and I'll be waiting... You have no one to blame but yourself. You're in a hell of your own making... And you're NEVER GETTING OUT!!! *grrgh* WHAT!!! WHAT IS IT THIS TIME!?!?";
|
||||||
|
boolean expResult3 = false;
|
||||||
|
boolean result3 = LivreValide.isLongueurTitreValid(titre3);
|
||||||
|
assertEquals(expResult3, result3);
|
||||||
|
System.out.println("Titre invalide. Titre trop long\n");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -90,11 +190,46 @@ public class LivreValideTest {
|
|||||||
public void testIsContenuTitreValide() {
|
public void testIsContenuTitreValide() {
|
||||||
System.out.println("isTitreValid");
|
System.out.println("isTitreValid");
|
||||||
String titre = "";
|
String titre = "";
|
||||||
boolean expResult = false;
|
assertFalse("Le titre ne doit pas être vide !", LivreValide.isContenuTitreValide(titre));
|
||||||
boolean result = LivreValide.isContenuTitreValide(titre);
|
titre = null;
|
||||||
assertEquals(expResult, result);
|
assertFalse("Le titre ne peut pas être nul !", LivreValide.isContenuTitreValide(titre));
|
||||||
// TODO review the generated test code and remove the default call to fail.
|
titre = "Ti";
|
||||||
fail("The test case is a prototype.");
|
assertTrue("Le titre fait au moins 2 caractères alphabétiques !", LivreValide.isContenuTitreValide(titre));
|
||||||
|
titre = "T";
|
||||||
|
assertFalse("Le titre fait au moins 2 caractères alphabétiques !", LivreValide.isContenuTitreValide(titre));
|
||||||
|
titre = "1234";
|
||||||
|
assertFalse("Le titre fait au moins 2 caractères alphabétiques !", LivreValide.isContenuTitreValide(titre));
|
||||||
|
titre = "Ti2";
|
||||||
|
assertTrue("Le titre fait au moins 2 caractères alphabétiques !", LivreValide.isContenuTitreValide(titre));
|
||||||
|
titre = "*$!";
|
||||||
|
assertFalse("Le titre fait au moins 2 caractères alphabétiques !", LivreValide.isContenuTitreValide(titre));
|
||||||
|
titre = "Ti!";
|
||||||
|
assertTrue("Le titre fait au moins 2 caractères alphabétiques !", LivreValide.isContenuTitreValide(titre));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test testIsDisponible()
|
||||||
|
* Vérifier livre pas déjà emprunté
|
||||||
|
* @author Emile
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testIsDisponible(){
|
||||||
|
System.out.println("isDisponible");
|
||||||
|
Livre unLivre = new Livre("Le comte de MonteCristo","Alexandre Dumas", "1234567891245", false);
|
||||||
|
|
||||||
|
System.out.println("Test1 : un livre disponible");
|
||||||
|
boolean result1 = LivreValide.isDisponible(unLivre);
|
||||||
|
assertTrue("Le chevron < n'est pas censé etre accepté", result1);
|
||||||
|
System.out.println("Le test1 est validé");
|
||||||
|
System.out.println("--------------------------------------------------");
|
||||||
|
System.out.println(" ");
|
||||||
|
|
||||||
|
unLivre.setEmprunte(true);
|
||||||
|
System.out.println("Test2 : un livre indiisponible");
|
||||||
|
boolean result2 = LivreValide.isDisponible(unLivre);
|
||||||
|
assertFalse("Le chevron < n'est pas censé etre accepté", result2);
|
||||||
|
System.out.println("Le test2 est validé");
|
||||||
|
System.out.println("--------------------------------------------------");
|
||||||
|
System.out.println(" ");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -4,8 +4,9 @@
|
|||||||
*/
|
*/
|
||||||
package com.mycompany.bibliotheque;
|
package com.mycompany.bibliotheque;
|
||||||
|
|
||||||
import com.mycompany.bibliotheque.Métier.Utilisateur;
|
import com.mycompany.bibliotheque.Metier.Utilisateur;
|
||||||
import com.mycompany.bibliotheque.Métier.Livre;
|
import com.mycompany.bibliotheque.Metier.Livre;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -52,19 +53,29 @@ public class UtilisateurTest {
|
|||||||
fail("The test case is a prototype.");
|
fail("The test case is a prototype.");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test of emprunterLivre method, of class Utilisateur.
|
* Test of emprunterLivre method, of class Utilisateur.
|
||||||
|
* @author Madhi
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testEmprunterLivre() {
|
public void testEmprunterLivre() {
|
||||||
System.out.println("emprunterLivre");
|
System.out.println("emprunterLivre");
|
||||||
Livre livre = null;
|
|
||||||
Utilisateur instance = null;
|
Livre a = new Livre("1984", "George Orwell", "1234567890123", false);
|
||||||
boolean expResult = false;
|
Livre b = new Livre("1984", "Test2", "1232667890123", false);
|
||||||
boolean result = instance.emprunterLivre(livre);
|
Livre c = new Livre ("1888","Test3","1232667890123",false);
|
||||||
assertEquals(expResult, result);
|
Livre d = new Livre ("1263","Test4","1236267890123",false);
|
||||||
// TODO review the generated test code and remove the default call to fail.
|
|
||||||
fail("The test case is a prototype.");
|
ArrayList<Livre> mesLivres = new ArrayList<>();
|
||||||
|
|
||||||
|
Utilisateur utilisateur = new Utilisateur("Medhi", mesLivres);
|
||||||
|
boolean result = utilisateur.emprunterLivre(a);
|
||||||
|
|
||||||
|
assertTrue("L'utilisateur a trop de livres",result);
|
||||||
|
result = utilisateur.emprunterLivre(b);
|
||||||
|
result = utilisateur.emprunterLivre(c);
|
||||||
|
result = utilisateur.emprunterLivre(d);
|
||||||
|
assertFalse("L'utilisateur n'a pas encore trois emprunts ",result);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user