Compare commits

...

12 Commits
dt ... master

Author SHA1 Message Date
famille Thevenot
09a7279d52 Merge dt
# Conflicts:
#	src/Test.java
#	src/métiers/Commande.java
#	test/métiers/CommandeTest.java
2024-09-25 22:03:48 +02:00
famille Thevenot
c000fb78ee Merge origin/master
# Conflicts:
#	nbproject/project.properties
#	src/métiers/Commande.java
2024-09-25 18:22:52 +02:00
famille Thevenot
b109399da5 Merge origin/master
# Conflicts:
#	nbproject/project.properties
#	src/métiers/Commande.java
2024-09-25 18:18:10 +02:00
famille Thevenot
08e7254265 Merge origin/master
# Conflicts:
#	nbproject/project.properties
#	src/métiers/Commande.java
2024-09-25 18:15:29 +02:00
sio
6bcc94486f mise à jour Morgann 2024-09-19 11:55:10 +02:00
maissane.elmjidi
9e6a9cc867 ajout page maissane 2024-09-19 11:42:33 +02:00
sio
8dc9d9d385 mise à jour pour Commande et testCommande avec Ines et Ilona 2024-09-19 11:38:57 +02:00
e4956996d6 Merge pull request 'test cas 5' (#4) from morgann into master
Reviewed-on: #4
2024-09-19 10:39:59 +02:00
morgann.david
6ed7fb09f2 test cas 5 2024-09-19 10:26:18 +02:00
sio
45a93f086a mise à jour pour Commande et testCommande 2024-09-19 10:11:37 +02:00
sio
0680043384 test cas1 2024-09-12 11:33:20 +02:00
sio
b02b4b8bcf test cas1 2024-09-12 11:25:21 +02:00
4 changed files with 218 additions and 138 deletions

View File

@ -19,10 +19,20 @@ public class Test {
*/ */
public static void main(String[] args) { public static void main(String[] args) {
Entreprise lEntreprise=new Entreprise("MusicAndCo"); Entreprise lEntreprise=new Entreprise("MusicAndCo");
Commande laCommande = new Commande(1,1,"12/09/2024"); Commande laCommande1 = new Commande(1,1,"12/09/2024");
lEntreprise.ajouterCommande(laCommande);
//ajouter 3 piano droit et 2 violon alto dans la commande //ajouter des instruments de l'entreprise à la commande
//affecter la commande à l'entreprise si la comamnde est possible
lEntreprise.ajouterCommande(laCommande1);
//créer une autre commande
//rechercher et afficher une commande
//supprimer une des 2 commande
} }
} }

View File

@ -1,123 +1,145 @@
/* /*
* 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 métiers; package métiers;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.Objects; import java.util.Objects;
/** /**
* *
* @author ilona * @author ilona
*/ */
public class Commande { public class Commande {
private int noCom, noVendeur; private int noCom, noVendeur;
private String dateCom; private String dateCom;
private final HashMap<Instrument, Integer> lesLignes = new HashMap<>(); private final HashMap<Instrument, Integer> lesLignes = new HashMap<>();
public Commande(int noCom, int noVendeur, String dateCom) { public Commande(int noCom, int noVendeur, String dateCom) {
this.noCom = noCom; this.noCom = noCom;
this.noVendeur = noVendeur; this.noVendeur = noVendeur;
this.dateCom = dateCom; this.dateCom = dateCom;
} }
/** /**
* Ajoute une quantité donnée d'un instrument à la commande * Ajoute une quantité donnée d'un instrument à la commande
* @param unInstrument instrument à ajouter * @param unInstrument instrument à ajouter
* @param qte quantité à ajouter * @param qte quantité à ajouter
* @return true si l'ajout est bon * @return true si l'ajout est bon
*/ */
public boolean ajouter(Instrument unInstrument, int qte){ public boolean ajouter(Instrument unInstrument, int qte){
//il faut gérer l'ajout d'un instrument existant dans la commande, ce sera une mise à jour de la ligne
//il faut empêcher l'ajout d'une ligne avec une quantité à 0 //il faut empêcher l'ajout d'une ligne avec une quantité à 0
//bien s'assurer que le stock est suffisant //bien s'assurer que le stock est suffisant
boolean ajoutOK; boolean ajoutOK=false;
int qteDisponible = unInstrument.getQteStock(); if(qte!=0){
if (qteDisponible<qte){ //ajout d'un instrument existant dans la commande, ce sera une mise à jour de la ligne
ajoutOK = false; if (lesLignes.containsKey(unInstrument))//l'instrument existe
}else { {
ajoutOK = true; //récupération de la quantité en stock
lesLignes.put(unInstrument,qte); int oldQte=unInstrument.getQteStock();
unInstrument.setQteStock(qteDisponible-qte); //réaffectation dans le stock de la quantité commandée
} int qteStock=oldQte+ this.getLesLignes().get(unInstrument);
return ajoutOK; unInstrument.setQteStock(qteStock);
} //suppression ligne commande
/** lesLignes.remove(unInstrument);
* Supprimer un instrument de la commande //nouvel ajout
* @param unInstrument instrument à supprimer this.ajouter(unInstrument,qte);
* @return true si la suppression est effectuée
*/ }
public boolean supprimer(Instrument unInstrument){ else //nouvel instrument
//lesLignes.remove(unInstrument); {
boolean suppOK; //on s'assure qu'il y a assez de stock pour la commande
if (lesLignes.containsKey(unInstrument) == true){
suppOK = true; int qteDisponible = unInstrument.getQteStock();
lesLignes.remove(unInstrument); if (qteDisponible<qte){
} else { ajoutOK = false;
suppOK = false; }else {
} ajoutOK = true;
return suppOK; lesLignes.put(unInstrument,qte);
} //màj qté stock pour déduire la qté commandée
unInstrument.setQteStock(qteDisponible-qte);
///////////////////////////////////////////////////////////////////////////////// }
}
public int getNoCom() { }
return noCom; return ajoutOK;
} }
/**
public int getNoVendeur() { * Supprimer un instrument de la commande
return noVendeur; * @param unInstrument instrument à supprimer
} * @return true si la suppression est effectuée
*/
public String getDateCom() { public boolean supprimer(Instrument unInstrument){
return dateCom; //lesLignes.remove(unInstrument);
} boolean suppOK;
if (lesLignes.containsKey(unInstrument) == true){
public HashMap<Instrument, Integer> getLesLignes() { suppOK = true;
return lesLignes; lesLignes.remove(unInstrument);
} } else {
suppOK = false;
}
public void setNoCom(int noCom) { return suppOK;
this.noCom = noCom; }
}
/////////////////////////////////////////////////////////////////////////////////
public void setNoVendeur(int noVendeur) {
this.noVendeur = noVendeur; public int getNoCom() {
} return noCom;
}
public void setDateCom(String dateCom) {
this.dateCom = dateCom; public int getNoVendeur() {
} return noVendeur;
}
@Override
public boolean equals(Object obj) { public String getDateCom() {
if (this == obj) { return dateCom;
return true; }
}
if (obj == null) { public HashMap<Instrument, Integer> getLesLignes() {
return false; return lesLignes;
} }
if (getClass() != obj.getClass()) {
return false;
} public void setNoCom(int noCom) {
final Commande other = (Commande) obj; this.noCom = noCom;
if (this.noCom != other.noCom) { }
return false;
} public void setNoVendeur(int noVendeur) {
if (this.noVendeur != other.noVendeur) { this.noVendeur = noVendeur;
return false; }
}
return Objects.equals(this.dateCom, other.dateCom); public void setDateCom(String dateCom) {
} this.dateCom = dateCom;
}
} @Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
final Commande other = (Commande) obj;
if (this.noCom != other.noCom) {
return false;
}
if (this.noVendeur != other.noVendeur) {
return false;
}
return Objects.equals(this.dateCom, other.dateCom);
}
}

View File

@ -15,12 +15,12 @@ import métiers.Instrument;
public class Entreprise { public class Entreprise {
private String raisonSociale; private String raisonSociale;
private ArrayList<Commande> lesCommandes = new ArrayList<>(); private ArrayList<Commande> lesCommandes = new ArrayList<>();
private ArrayList<Instrument> lesInstruments = new ArrayList<>();
public Entreprise(String raisonSociale) { public Entreprise(String raisonSociale) {
this.raisonSociale = raisonSociale; this.raisonSociale = raisonSociale;
ArrayList<Instrument> lesInstruments = new ArrayList<>(); Instrument instr1=new Instrument(23,"Piano droit",3, 8300f);
Instrument instr1=new Instrument(23,"Piano droit",3, 8300f);
Instrument instr2=new Instrument(54,"Violon Alto",5, 105f); Instrument instr2=new Instrument(54,"Violon Alto",5, 105f);
Instrument instr3=new Instrument(67,"Guitare Classique",8, 575f); Instrument instr3=new Instrument(67,"Guitare Classique",8, 575f);
lesInstruments.add(instr3); lesInstruments.add(instr3);

View File

@ -5,9 +5,7 @@
package métiers; package métiers;
import java.util.HashMap; import java.util.HashMap;
import org.junit.Before;
import org.junit.Test;
import static org.junit.Assert.*;
/** /**
* *
@ -18,19 +16,21 @@ public class CommandeTest {
public CommandeTest() { public CommandeTest() {
} }
@Before
public void setUp() { public void setUp() {
} }
/** /**
* Test of ajouter method, of class Commande. * Test of ajouter method, of class Commande.
*/ */
@Test
public void testAjouter() { public void testAjouter() {
Instrument instr1=new Instrument(1,"Piano",10, 8300f); Instrument instr1=new Instrument(1,"Piano",10, 8300f);
Instrument instr2=new Instrument(2,"Violon",9, 105f); Instrument instr2=new Instrument(2,"Violon",9, 105f);
Instrument instr3=new Instrument(3,"piano",8, 105f);
Commande laCommande = new Commande(1,1,"12/09/2024"); Commande laCommande = new Commande(1,1,"12/09/2024");
System.out.println("ajouter"); System.out.println("ajouter");
//cas 0
boolean ajoutRes= laCommande.ajouter(instr1, 2); boolean ajoutRes= laCommande.ajouter(instr1, 2);
boolean ajoutAttendu = true; boolean ajoutAttendu = true;
System.out.println("cas0 : cas normal, ajout une ligne de commande"); System.out.println("cas0 : cas normal, ajout une ligne de commande");
@ -42,32 +42,80 @@ public class CommandeTest {
int qteAttendu=2; int qteAttendu=2;
assertEquals("Test0 quantite",qteRes, qteAttendu); assertEquals("Test0 quantite",qteRes, qteAttendu);
//cas 1
System.out.println("Cas1 : ajout autre ligne de commande"); System.out.println("Cas1 : ajout autre ligne de commande");
laCommande.ajouter(instr2, 6); laCommande.ajouter(instr2, 6);
int tailleR=laCommande.getLesLignes().size(); int tailleR=laCommande.getLesLignes().size();
int tailleAttendue=2; int tailleAttendue=2;
assertEquals("Test1 taille",tailleAttendue,tailleR); assertEquals("Test1 taille",tailleAttendue,tailleR);
//Cas2
System.out.println("Cas2 : màj quantité commandée d'une ligne existante"); System.out.println("Cas2 : màj quantité commandée d'une ligne existante");
laCommande.ajouter(instr2, 5); laCommande.ajouter(instr2, 5);
stockRes=instr2.getQteStock(); stockRes=instr2.getQteStock();
stockAttendu=4; stockAttendu=4;
assertEquals("test2 stock",stockAttendu,stockRes ); assertEquals("test2 stock",stockAttendu,stockRes );
/*qteRes=laCommande.getLesLignes().get(instr2); qteRes=laCommande.getLesLignes().get(instr2);
qteAttendu=5; qteAttendu=5;
assertEquals("Test2 quantite", qteAttendu,qteRes);*/ assertEquals("Test2 quantite", qteAttendu,qteRes);
/*INES*/ /*INES*/
System.out.println("Cas3 : ajout nouvelle ligne avec quantité > stock"); System.out.println("Cas3 : ajout nouvelle ligne avec quantité > stock");
boolean test= laCommande.ajouter(instr3, 12);
stockRes=instr3.getQteStock();
stockAttendu=8;
boolean testResultExpected=false;
assertEquals("test3 stock",stockAttendu,stockRes );
assertEquals("La méthode ajouter retourne false",testResultExpected,test );
System.out.println("Nombre de ligne dans le dictionnaire: "+laCommande.getLesLignes().size());
System.out.println("Résultat de la méthode ajouter: " + test);
/*MAISSANE*/ /*MAISSANE*/
System.out.println("Cas4 : ajout nouvelle ligne avec quantité 0"); System.out.println("Cas4 : ajout nouvelle ligne avec quantité 0");
System.out.println("Cas4 : ajout nouvelle ligne avec quantité 0");
boolean AjouterObtenu=laCommande.ajouter(instr3, 0);
boolean AjouterA= false;
assertEquals("Test4 ajout 0 instr3",AjouterA,AjouterObtenu);
int lignes=laCommande.getLesLignes().size();
int nbLigneAttendu = 2;
assertEquals("Test4 taille",nbLigneAttendu,lignes);
qteRes=laCommande.getLesLignes().get(instr3);
qteAttendu=0;
assertEquals("Test4 quantite", qteAttendu,qteRes);
/*MORGANN*/ /*MORGANN*/
System.out.println("Cas5 : mise à 0 quantité commandée d'une ligne existante"); System.out.println("Cas5 : mise à 0 quantité commandée d'une ligne existante");
/*INES*/ laCommande.ajouter(instr2, 0);
stockRes=instr2.getQteStock();
stockAttendu=9;
assertEquals("test5 stock",stockAttendu,stockRes );
tailleR=laCommande.getLesLignes().size();
tailleAttendue=2;
assertEquals("Test1 taille",tailleAttendue,tailleR);
/*ILONA*/
System.out.println("Cas6 : màj d'une ligne existante avec qté>stock"); System.out.println("Cas6 : màj d'une ligne existante avec qté>stock");
System.out.println("Cas6 : màj d'une ligne existante avec qté>stock");
boolean resultatMethode = laCommande.ajouter(instr1, 12);
boolean resultatMethodeAttendu=false;
assertEquals("test6 mise à jour",resultatMethodeAttendu,resultatMethode);
stockRes=instr1.getQteStock();
stockAttendu=2;
assertEquals("test6 stock",stockAttendu,stockRes );
} }
private void assertEquals(String test1_taille, int tailleAttendue, int tailleR) {
throw new UnsupportedOperationException("Not supported yet."); // Generated from nbfs://nbhost/SystemFileSystem/Templates/Classes/Code/GeneratedMethodBody
}
private void assertEquals(String la_méthode_ajouter_retourne_false, boolean testResultExpected, boolean test) {
throw new UnsupportedOperationException("Not supported yet."); // Generated from nbfs://nbhost/SystemFileSystem/Templates/Classes/Code/GeneratedMethodBody
}
/** /**
* Test of supprimer method, of class Commande. * Test of supprimer method, of class Commande.