Thread Rating:
  • 0 Vote(s) - 0 Average
  • 1
  • 2
  • 3
  • 4
  • 5
Projet Calculateur
#38
Et assez rapidement, on teste les marines dans la boite Leviathan: l'escouade Infernus.

Un nouveau TU est écrit:
Code:
package com.calculateur.warhammer.calcul.mort.arbre.calcul;

import org.apache.commons.math3.fraction.Fraction;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.Test;

import com.calculateur.warhammer.base.exception.FunctionnalExeption;
import com.calculateur.warhammer.calcul.mort.arbre.ENatureNoeud;
import com.calculateur.warhammer.calcul.mort.arbre.INoeudArbre;
import com.calculateur.warhammer.calcul.mort.arbre.calcul.builder.space.marine.SpaceMarineBuilderAttaque;
import com.calculateur.warhammer.calcul.mort.arbre.calcul.builder.tyranide.TermagantBuilderDefense;
import com.calculateur.warhammer.calcul.mort.arbre.data.DataCalculProbabiliteBuilder;
import com.calculateur.warhammer.calcul.mort.arbre.data.IDataCalculProbabilite;
import com.calculateur.warhammer.calcul.test.utils.FractionCheminBuilder;
import com.calculateur.warhammer.data.action.IContexteAction;
import com.calculateur.warhammer.data.enumeration.EBlessure;
import com.calculateur.warhammer.data.enumeration.EGestionDe;
import com.calculateur.warhammer.data.enumeration.EMouvement;
import com.calculateur.warhammer.data.enumeration.ESimule;
import com.calculateur.warhammer.data.identifiable.batiment.RecordBatiment;
import com.calculateur.warhammer.data.regles.detachement.space.marine.ESermentInstantChoix;

public class SpaceMarineInfernusVsTermagantTirTest extends AbstractCalculArbreTest{

    @Test
    public void testMarineContreTermagantDecouvert() throws FunctionnalExeption {
        IContexteAction contexte = getContexteAction(false);
        IDataCalculProbabilite data = getData(contexte, ESermentInstantChoix.NON);
        testMarineContreTermagantSansRelance(data);
    }
    
    @Test
    public void testMarineContreTermagantCouvert() throws FunctionnalExeption {
        IContexteAction contexte = getContexteAction(true);
        IDataCalculProbabilite data = getData(contexte, ESermentInstantChoix.NON);
        testMarineContreTermagantSansRelance(data);
    }
    
    private void testMarineContreTermagantSansRelance(IDataCalculProbabilite dada) throws FunctionnalExeption {
        Fraction probaBlesse = new Fraction(2, 3);
        Fraction probaRateSauvegarde = new Fraction(2,3);
        Fraction probaAttendu = FractionCheminBuilder.getInstance().addFraction(probaBlesse).addFraction(probaRateSauvegarde).build();
        Integer pool = 26;
        INoeudArbre noeud = doTestStandard(dada, probaAttendu, pool);
        int nombreChemin = 0;
        Integer blessure;
        for(INoeudArbre aNoeud:noeud.arbre()) {
            if(aNoeud.getNatureNoeud() == ENatureNoeud.REUSSITE) {
                nombreChemin++;
                Assertions.assertThat(aNoeud.mapBlessure()).hasSize(1);
                blessure = aNoeud.mapBlessure().get(EBlessure.NORMALES);
                Assertions.assertThat(blessure).isEqualTo(1);
                Assertions.assertThat(aNoeud.mapBlessuresAleatoires()).isEmpty();
            }
        }
        Assertions.assertThat(nombreChemin).isEqualTo(1);
    }
    
    @Test
    public void testMarineContreTermagantDecouvertSermentInstant() throws FunctionnalExeption {
        IContexteAction contexte = getContexteAction(false);
        IDataCalculProbabilite data = getData(contexte, ESermentInstantChoix.OUI);
        testMarineContreTermagantAvecRelance(data);
    }
    
    @Test
    public void testMarineContreTermagantCouvertSermentInstant() throws FunctionnalExeption {
        IContexteAction contexte = getContexteAction(true);
        IDataCalculProbabilite data = getData(contexte, ESermentInstantChoix.OUI);
        testMarineContreTermagantAvecRelance(data);
    }
    
    private void testMarineContreTermagantAvecRelance(IDataCalculProbabilite dada) throws FunctionnalExeption {
        Fraction probaBlesse = new Fraction(2, 3);
        Fraction probaRateBlesse = new Fraction(1,3);
        Fraction probaRateSauvegarde = new Fraction(2,3);
        
        Fraction chemin1 = FractionCheminBuilder.getInstance().addFraction(probaBlesse).addFraction(probaRateSauvegarde).build();
        Fraction chemin2 = FractionCheminBuilder.getInstance().addFraction(probaRateBlesse).addFraction(probaBlesse).addFraction(probaRateSauvegarde).build();
        Fraction probaAttendu = chemin1.add(chemin2);
        
        Integer pool = 34;
        INoeudArbre noeud = doTestStandard(dada, probaAttendu, pool);
        int nombreChemin = 0;
        Integer blessure;
        for(INoeudArbre aNoeud:noeud.arbre()) {
            if(aNoeud.getNatureNoeud() == ENatureNoeud.REUSSITE) {
                nombreChemin++;
                Assertions.assertThat(aNoeud.mapBlessure()).hasSize(1);
                blessure = aNoeud.mapBlessure().get(EBlessure.NORMALES);
                Assertions.assertThat(blessure).isEqualTo(1);
                Assertions.assertThat(aNoeud.mapBlessuresAleatoires()).isEmpty();
            }
        }
        Assertions.assertThat(nombreChemin).isEqualTo(2);
    }
    
    
    private IDataCalculProbabilite getData(IContexteAction contexteAction,ESermentInstantChoix choix) {
        SpaceMarineBuilderAttaque builderAttaquant = SpaceMarineBuilderAttaque.getInstance(contexteAction, 10).equipeAvecPyroBlaster();
        builderAttaquant.addBatiment(contexteAction.getBatimentAttaquant());
        builderAttaquant.addSermentInstant(choix);
        
        TermagantBuilderDefense builderDefenseur = TermagantBuilderDefense.getInstance(contexteAction, 10);
        builderDefenseur.addBatiment(contexteAction.getBatimentDefenseur());
        
        return DataCalculProbabiliteBuilder.getInstance()
                .addContextAction(contexteAction).addAttaquant(builderAttaquant.build()).addDefenseur(builderDefenseur.build())
                .addGestionNombreAttaque(EGestionDe.SIMULATION_OPTIMISTE).addGestionJetToucheBlessure(EGestionDe.SIMULATION_OPTIMISTE)
                .addGestionSauvegardeDefenseur(EGestionDe.SIMULATION_OPTIMISTE).build();
                
        
    }
    
    private IContexteAction getContexteAction(boolean defenseurCouvert) {
        return ContextActionForTestProbaBuilder.getInstance()
                .addSimule(ESimule.TIR_PHASE_TIR)
                .addNumeroTour(2)
                .addEffectifInitialAttaquant(10)
                .addNombreAttaquant(10)
                .addMouvementAttaquant(EMouvement.IMMOBILE)
                .addBatimentAttaquant(new RecordBatiment(false, false))
                .addNombreDefenseur(10)
                .addMouvementDefenseur(EMouvement.IMMOBILE)
                .addBatimentDefenseur(new RecordBatiment(defenseurCouvert, false))
                .addDistanceEntreBelligerant(6.0)
                .build();
    }
}

Ce qui permet de finir le code de calcul:
Code:
package com.calculateur.warhammer.calcul.mort.arbre.calcul;

import com.calculateur.warhammer.base.exception.FunctionnalExeption;
import com.calculateur.warhammer.calcul.mort.arbre.INoeudArbre;
import com.calculateur.warhammer.calcul.mort.arbre.NoeudJetBlessure;
import com.calculateur.warhammer.calcul.mort.arbre.NoeudJetTouche;
import com.calculateur.warhammer.calcul.mort.arbre.data.IDataCalculProbabilite;
import com.calculateur.warhammer.calcul.mort.parametres.IParametres;
import com.calculateur.warhammer.calcul.mort.validation.IValidationCalcul;
import com.calculateur.warhammer.calcul.mort.validation.ValidationContextAction;

public class CalculArbre implements ICalculArbre{

    private final IParametres parametres;
    
    private final IValidationCalcul validationContext;
    
    public CalculArbre(IParametres parametres) {
        this.parametres = parametres;
        validationContext = new ValidationContextAction();
    }

    @Override
    public INoeudArbre getRacine(IDataCalculProbabilite data) throws FunctionnalExeption {
        //Validation
        validationContext.valideCalcul(data);
        
        for(IValidationCalcul validationCalcul:parametres.getFactoryValidation().getValidations(data.getContexteAction().getSimule())) {
            validationCalcul.valideCalcul(data);
        }
        
        //Initialisation diverse
        parametres.getFactoryInitialisation().getInterfaceInitialisationAttaquant().initialiseAttaquant(data.getAttaquant());
        
        Integer nombreAttaque = parametres.getFactoryAttaque().getInterfaceCalculNombreAttaque(data.getGestionNombreAttaque()).getNombreAttaque(data)
                * data.getAttaquant().getNombre();
        INoeudArbre racine;
        
        if(data.getAttaquant().getRegles().isIgnoreJetTouche()) {
            racine = NoeudJetBlessure.getJetBlessureAsRacine(data, parametres, nombreAttaque);
        }else {
            racine = NoeudJetTouche.getJetToucheAsRacine(nombreAttaque, data, parametres);
        }
        return racine;
    }

}
Reply


Messages In This Thread
Projet Calculateur - by Philou - 12-09-2022, 09:47 AM
RE: Projet Calculateur - by Philou - 12-09-2022, 09:52 AM
RE: Projet Calculateur - by Philou - 17-09-2022, 09:14 PM
RE: Projet Calculateur - by Philou - 25-09-2022, 07:26 AM
RE: Projet Calculateur - by Philou - 25-09-2022, 08:54 AM
RE: Projet Calculateur - by Philou - 03-10-2022, 10:54 AM
RE: Projet Calculateur - by Philou - 16-10-2022, 11:36 AM
RE: Projet Calculateur - by Philou - 24-10-2022, 01:08 PM
RE: Projet Calculateur - by Philou - 25-10-2022, 09:52 AM
RE: Projet Calculateur - by sdm - 25-10-2022, 11:06 PM
RE: Projet Calculateur - by Philou - 25-10-2022, 11:23 PM
RE: Projet Calculateur - by Philou - 26-10-2022, 03:09 PM
RE: Projet Calculateur - by Philou - 25-10-2022, 11:25 PM
RE: Projet Calculateur - by Philou - 06-11-2022, 05:27 PM
RE: Projet Calculateur - by Philou - 19-11-2022, 10:36 AM
RE: Projet Calculateur - by Philou - 23-11-2022, 08:34 AM
RE: Projet Calculateur - by Philou - 24-11-2022, 08:49 PM
RE: Projet Calculateur - by Philou - 04-12-2022, 06:57 PM
RE: Projet Calculateur - by Philou - 11-12-2022, 12:11 PM
RE: Projet Calculateur - by Philou - 18-12-2022, 06:47 PM
RE: Projet Calculateur - by Philou - 19-12-2022, 09:05 PM
RE: Projet Calculateur - by Philou - 03-01-2023, 09:34 PM
RE: Projet Calculateur - by Philou - 07-01-2023, 06:36 PM
RE: Projet Calculateur - by Philou - 01-02-2023, 08:21 PM
RE: Projet Calculateur - by Philou - 16-02-2023, 08:31 PM
RE: Projet Calculateur - by Gaeriel - 17-02-2023, 10:56 PM
RE: Projet Calculateur - by Philou - 17-02-2023, 11:32 PM
RE: Projet Calculateur - by Philou - 05-03-2023, 05:45 PM
RE: Projet Calculateur - by Philou - 06-03-2023, 08:55 PM
RE: Projet Calculateur - by Philou - 08-03-2023, 08:28 PM
RE: Projet Calculateur - by Philou - 12-03-2023, 07:56 AM
RE: Projet Calculateur - by Philou - 23-03-2023, 06:44 PM
RE: Projet Calculateur - by Philou - 28-03-2023, 08:58 PM
RE: Projet Calculateur - by Philou - 27-04-2023, 08:05 PM
RE: Projet Calculateur - by Philou - 30-04-2023, 10:29 AM
RE: Projet Calculateur - by Philou - 02-05-2023, 08:03 AM
RE: Projet Calculateur - by Philou - 19-05-2023, 11:36 AM
RE: Projet Calculateur - by Philou - 19-05-2023, 05:44 PM
RE: Projet Calculateur - by Philou - 20-05-2023, 09:10 PM
RE: Projet Calculateur - by Philou - 22-06-2023, 07:38 AM
RE: Projet Calculateur - by Philou - 24-06-2023, 07:09 AM
RE: Projet Calculateur - by Philou - 26-06-2023, 07:44 PM
RE: Projet Calculateur - by Philou - 28-06-2023, 07:09 AM
RE: Projet Calculateur - by Philou - 28-06-2023, 07:43 PM
RE: Projet Calculateur - by Philou - 30-06-2023, 07:22 PM
RE: Projet Calculateur - by Philou - 08-08-2023, 07:54 PM
RE: Projet Calculateur - by Philou - 19-08-2023, 10:30 AM
RE: Projet Calculateur - by Philou - 19-08-2023, 06:20 PM
RE: Projet Calculateur - by Philou - 20-08-2023, 10:17 AM
RE: Projet Calculateur - by Philou - 22-01-2024, 09:02 PM
RE: Projet Calculateur - by Philou - 09-05-2024, 10:21 AM
RE: Projet Calculateur - by Philou - 11-05-2024, 05:41 PM
RE: Projet Calculateur - by Philou - 25-05-2024, 08:41 AM
RE: Projet Calculateur - by Philou - 24-04-2025, 04:09 PM

Forum Jump:


Users browsing this thread: 1 Guest(s)