239 lines
7.0 KiB
Java
Raw Normal View History

2020-11-25 14:46:24 +01:00
package TD6.grapheSimple;
import static org.junit.jupiter.api.Assertions.*;
import java.util.Collection;
import java.util.List;
import java.util.Set;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import TD6.grapheX.Arc;
import TD6.grapheX.Sommet;
//@todo to be improved!
public class GrapheSimpleTest extends GrapheSimple<Sommet> {
GrapheSimple<Sommet> graphe = new GrapheSimple<>();
Sommet s1 = new Sommet("S1");
Sommet s2 = new Sommet("S2");
Sommet s3= new Sommet("S3");
Sommet s4= new Sommet("S4");
int distance_s1_s2 = 1;
int distance_s1_s3 = 2;
int distance_s2_s1 = 2;
int distance_s2_s3 = 1;
int distance_s3_s4 = 2;
int distance_s4_s1 = 10;
/*
* s1 -1-> s2 -1-> s3
* s2-2-> s1
* s3 -2-> s4
* s4 -10-> s1
*
*/
@BeforeEach
public void setUp() throws Exception {
graphe = new GrapheSimple<>();
}
public void initGlobalGraph(){
graphe = new GrapheSimple<>();
graphe.ajouterSommet(s1);
graphe.ajouterSommet(s2);
graphe.ajouterSommet(s3);
graphe.ajouterSommet(s4);
graphe.ajouterArc(s1, s2, distance_s1_s2);
graphe.ajouterArc(s1, s2, distance_s1_s2*2);
graphe.ajouterArc(s1, s3, distance_s1_s3);
graphe.ajouterArc(s2, s1, distance_s2_s1);
graphe.ajouterArc(s2, s3, distance_s2_s3);
graphe.ajouterArc(s3, s4, distance_s3_s4);
graphe.ajouterArc(s4, s1, distance_s4_s1);
}
@Test
public void testTailleInitiale() {
assertEquals(0,graphe.taille());
}
@Test
public void testAjouterSommetInitial() {
graphe.ajouterSommet(s1);
assertEquals(1,graphe.taille());
assertEquals(s1,graphe.getSommet("S1"));
}
@Test
public void testAjouterArcInitial() {
graphe.ajouterSommet(s1);
graphe.ajouterSommet(s2);
graphe.ajouterSommet(s3);
graphe.ajouterArc(s1, s2, distance_s1_s2);
assertEquals(3,graphe.taille());
assertTrue(graphe.existeArc(s1, s2));
assertFalse(graphe.existeArc(s1, s3));
List<Arc<Sommet>> arcs = graphe.arcs(s1, s2);
assertEquals(1,arcs.size());
}
@Test
public void testVoisinsSommet() {
initGlobalGraph();
Collection<Arc<Sommet>> voisins = graphe.voisins(s1);
assertEquals(3, voisins.size());
//System.out.println("voisins de s1 :" + voisins);
voisins = graphe.voisins(s2);
assertEquals(2, voisins.size(), "voisins de s2 : " + voisins);
//System.out.println("voisins de s2 : " + voisins);
}
@Test
public void testArcs() {
initGlobalGraph();
List<Arc<Sommet>> arcs = graphe.arcs(s1, s2);
//System.out.println("de s1 a s2 : " + arcs);
assertEquals(2, arcs.size());
arcs = graphe.arcs(s1, s3);
//System.out.println("de s1 a s3 : " + arcs);
assertEquals(1, arcs.size());
arcs = graphe.arcs(s1, s4);
//System.out.println("de s1 a s4 : " + arcs);
assertTrue(arcs==null);
arcs = graphe.arcs(s4, s1);
//System.out.println("de s4 a s1 : " + arcs);
assertEquals(1, arcs.size());
}
@Test
public void testParcoursCheminsDe() {
initGlobalGraph();
List<Chemin<Sommet>> chemins = graphe.chemins(s1);
assertEquals(3, chemins.size());
System.out.println("Chemins a partir de s1: " + chemins);
chemins = graphe.chemins(s2);
System.out.println("Chemins a partir de s2: " + chemins);
assertEquals(2, chemins.size());
chemins = graphe.chemins(s3);
System.out.println("Chemins a partir de s3: " + chemins);
assertEquals(2, chemins.size());
chemins = graphe.chemins(s4);
assertEquals(3, chemins.size());
System.out.println("Chemins a partir de s4: " + chemins);
}
@Test
public void testParcoursCheminsDeA() {
initGlobalGraph();
List<Chemin<Sommet>> chemins = graphe.chemins(s1,s2);
System.out.println("Chemins de s1 a s2: " + chemins);
assertEquals(2, chemins.size());
chemins = graphe.chemins(s1,s3);
System.out.println("Chemins de s1 a s3: " + chemins);
assertEquals(3, chemins.size(), "Chemins de s1 a s3:");
chemins = graphe.chemins(s1,s4);
System.out.println("Chemins de s1 a s4: " + chemins);
assertEquals(3, chemins.size());
chemins = graphe.chemins(s2,s3);
System.out.println("Chemins de s2 a s3: " + chemins);
assertEquals(2, chemins.size());
chemins = graphe.chemins(s4,s1);
System.out.println("Chemins de s4 a s1: " + chemins);
assertEquals(1, chemins.size(), "Chemins de s4 a s1: ");
}
@Test
public void testCheminLePlusCourt() {
initGlobalGraph();
Chemin<Sommet> chemin = graphe.cheminLePlusCourt(s1, s2);
assertEquals(distance_s1_s2, chemin.distance());
chemin = graphe.cheminLePlusCourt(s1, s3);
assertEquals(distance_s1_s3, chemin.distance());
chemin = graphe.cheminLePlusCourt(s1, s4);
assertEquals(4, chemin.distance());
chemin = graphe.cheminLePlusCourt(s2, s3);
assertEquals(distance_s2_s3, chemin.distance());
chemin = graphe.cheminLePlusCourt(s4, s1);
assertEquals(distance_s4_s1, chemin.distance());
}
@Test
public void testVoisinsDeRangs() {
initGlobalGraph();
Set<Sommet> voisins = graphe.voisinsAuRang(s1, 1);
System.out.println("voisins s1 au rang 1: " + voisins);
assertEquals(2, voisins.size());
assertTrue(voisins.contains(s2));
assertTrue(voisins.contains(s3));
voisins = graphe.voisinsAuRang(s1, 2);
System.out.println("voisins s1 au rang 2: " + voisins);
assertEquals(1, voisins.size());
assertTrue(voisins.contains(s4));
voisins = graphe.voisinsAuRang(s2, 1);
System.out.println("voisins s2 au rang 1: " + voisins);
assertEquals(2, voisins.size());
assertTrue(voisins.contains(s1));
assertTrue(voisins.contains(s3));
voisins = graphe.voisinsAuRang(s2, 2);
System.out.println("voisins s2 au rang 2: " + voisins);
assertEquals(1, voisins.size());
assertTrue(voisins.contains(s4));
voisins = graphe.voisinsAuRang(s4, 2);
System.out.println("voisins s4 au rang 2: " + voisins);
assertEquals(2, voisins.size());
assertTrue(voisins.contains(s2));
assertTrue(voisins.contains(s3));
}
@Test
public void testExtraireChemin() {
Chemin<Sommet> cheminComplet = new Chemin<>();
cheminComplet.add(new Arc<Sommet>(s1,s2));
cheminComplet.add(new Arc<Sommet>(s2,s3));
cheminComplet.add(new Arc<Sommet>(s3,s4));
System.out.println("chemin de s1 a s4 " + cheminComplet);
Chemin<Sommet> c= cheminComplet.extraireChemin(s1, s4);
System.out.println("chemin de s1 a s4 apres extraction " + c);
assertEquals(3,c.getArcs().size());
assertEquals(s1,c.getArcs().get(0).origine());
assertEquals(s4,c.getArcs().get(2).destination());
c= cheminComplet.extraireChemin(s1, s3);
System.out.println("chemin de s1 a s3 apres extraction " + c);
assertEquals(2,c.getArcs().size());
assertEquals(s1,c.getArcs().get(0).origine());
assertEquals(s3,c.getArcs().get(1).destination());
c= cheminComplet.extraireChemin(s2, s3);
System.out.println("chemin de s2 a s3 apres extraction " + c);
assertEquals(1,c.getArcs().size());
assertEquals(s2,c.getArcs().get(0).origine());
assertEquals(s3,c.getArcs().get(0).destination());
c= cheminComplet.extraireChemin(s2, s4);
System.out.println("chemin de s2 a s4 apres extraction " + c);
assertEquals(2,c.getArcs().size());
assertEquals(s2,c.getArcs().get(0).origine());
assertEquals(s4,c.getArcs().get(1).destination());
}
}