Partage
  • Partager sur Facebook
  • Partager sur Twitter

[Erreur] Mockito test DAO

    26 février 2020 à 0:05:15

    Bonjour,

    J'ai un problème avec mockito, je souhaiterai faire des tests unitaires sur les méthodes qui composent mon DAO en commençant par la méthode saveTicket(). Seulement je n'arrive pas à simuler le traitement avec les mocks jusqu'au bout de la méthode (jusqu'à l'exécution). Le test plante lorsque l'objet prepareStatement est setter.

    voici le DAO avec la méthode saveTicket():

    public class TicketDAO {
    
        private static final Logger logger = LogManager.getLogger("TicketDAO");
    
        public DataBaseConfig dataBaseConfig = new DataBaseConfig();
    
        public boolean saveTicket(Ticket ticket){
            Connection con = null;
            PreparedStatement ps = null;
            try {
                con = dataBaseConfig.getConnection();
                ps = con.prepareStatement(DBConstants.SAVE_TICKET);
                //ID, PARKING_NUMBER, VEHICLE_REG_NUMBER, PRICE, IN_TIME, OUT_TIME)
                //ps.setInt(1,ticket.getId());
                ps.setInt(1,ticket.getParkingSpot().getId());
                ps.setString(2, ticket.getVehicleRegNumber());
                ps.setDouble(3, ticket.getPrice());
                ps.setTimestamp(4, Timestamp.valueOf(ticket.getInTime()));
    //            ps.setTimestamp(5, (ticket.getOutTime() == null)?null: (new Timestamp(ticket.getOutTime().getTime())) );
                ps.setBoolean(5, ticket.isAvailableDiscount());
                return ps.execute();
            }catch (Exception ex){
                logger.error("Error fetching next available slot",ex);
            }finally {
            	dataBaseConfig.closePreparedStatement(ps);
                dataBaseConfig.closeConnection(con);
                
            }
            return false;
        }

    voici ma classe de test:

    @ExtendWith(MockitoExtension.class)
    public class TicketDAOTest {
    
    	@InjectMocks
    	private TicketDAO ticketDAO;
    
    	@Mock
    	private static DataBaseConfig mockDataConfig;
    	@Mock
    	private static Connection mockConn;
    	@Mock
    	private static PreparedStatement mockPreparedStmnt;
    	@Mock
    	private static ResultSet mockResultSet;
    	@Mock
    	Timestamp mockTimestamp;
    	
    	
    	 @BeforeAll
    	    public static void setUpClass() throws Exception {
    	    }
    	 
    	  @AfterAll
    	    public static void tearDownClass() {
    	    }
    	 
    	
    	@BeforeEach
        public void setUp() throws SQLException, ClassNotFoundException, IOException {
           MockitoAnnotations.initMocks(this);
           when(mockDataConfig.getConnection()).thenReturn(mockConn);
           doNothing().when(mockConn).commit();
    
           when(mockConn.prepareStatement(anyString())).thenReturn(mockPreparedStmnt);
           doNothing().when(mockPreparedStmnt).setString(any(),anyString());
        
       }
    
    	  @Test
    	   public void testSaveTicket() throws SQLException {
    		  	Ticket ticket = new Ticket();
    		  	ticket.setId(1);
    		  	ticket.setVehicleRegNumber("ABCDEF");
    		  	ticket.setPrice(0);
    		  	LocalDateTime inTime = LocalDateTime.now(ZoneId.systemDefault());
    		  	ticket.setInTime(inTime);
    		  	ticket.setAvailableDiscount(Boolean.TRUE);
    		  	
    		  	when(mockConn.prepareStatement(DBConstants.SAVE_TICKET)).thenReturn(mockPreparedStmnt);
    	        ticketDAO.saveTicket(ticket);
    	        verify(mockPreparedStmnt).execute();
    	    }
    }
    


    Le code à la ligne 70 me renvoie un NullPointerException voici les logs:

    Merci d'avance pour votre aide.

    -
    Edité par Rémi01 26 février 2020 à 11:39:33

    • Partager sur Facebook
    • Partager sur Twitter
      26 février 2020 à 4:39:35

      Bonjour,

      Le message qui suit est une réponse automatique activée par un membre de l'équipe. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
      Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

      Pour plus d'informations, nous vous invitons à lire les règles générales du forum

      Mauvais titre

      Le titre est un élément important qui ne doit pas être négligé. N'oubliez pas cette règle simple : le titre idéal résume la question que vous allez poser en une petite phrase. Il doit permettre aux visiteurs de se repérer facilement dans le forum visité et d'identifier le sujet à sa seule lecture.

      Vous pouvez utiliser divers préfixes comme [Erreur], [MySQL], [Compatibilité], etc... Aussi, pensez à consulter les règles propres à chaque forum (visibles dans les topics épinglés en haut des sections).

      De plus, choisir un bon titre permet de rendre plus faciles les recherches des autres membres.

      Les titres de type "besoin d'aide" ou "problème" ne sont pas tolérés.

      Pour modifier votre titre, éditez le premier message de votre sujet.

      (titre originel : Problème Mockito test DAO)

      Merci de colorer votre code à l'aide du bouton Code

      Les forums d'Openclassrooms disposent d'une fonctionnalité permettant de colorer et mettre en forme les codes source afin de les rendre plus lisibles et faciles à manipuler par les intervenants. Pour cela, il faut utiliser le bouton Code de l'éditeur, choisir un des langages proposés et coller votre code dans la zone prévue. Si vous utilisez l'éditeur de messages en mode Markdown, il faut utiliser les balises <pre class="brush: java;">Votre code ici</pre>.

      Merci de modifier votre message d'origine en fonction.

      Liens conseillés

      -
      Edité par AbcAbc6 26 février 2020 à 4:41:04

      • Partager sur Facebook
      • Partager sur Twitter

      [Erreur] Mockito test DAO

      × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
      × Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
      • Editeur
      • Markdown