Solucionado (ver solução)
Solucionado
(ver solução)
4
respostas

NULL not allowed for column "LEILAO_ID"; SQL statement:

Ao tentar implemetar os testes da LanceDao, recebi o erro: NULL not allowed for column "LEILAO_ID"; SQL statement: Eu entendi que o motivo é o ID_LEILAO que não foi informado para gravação da tabela LANCE. Porém não consegui resolver o problema. Alguém pode ajudar.

4 respostas

Oi ALISSON

Envia aqui seu código para darmos uma olhada

package br.com.alura.leilao.dao;

import java.time.LocalDate;

import javax.persistence.EntityManager;

import org.junit.Assert; import org.junit.jupiter.api.AfterEach;

import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test;

import br.com.alura.leilao.model.Lance; import br.com.alura.leilao.model.Leilao; import br.com.alura.leilao.model.Usuario; import br.com.alura.leilao.util.JPAUtil; import br.com.alura.leilao.util.buider.UsuarioBuilder; import br.com.alura.leilao.util.builder.LanceBuilder; import br.com.alura.leilao.util.builder.LeilaoBuilder;

class LanceDaoTest {

private LanceDao dao;
private EntityManager em;

@BeforeEach
public void beforeEach() {
    this.em = JPAUtil.getEntityManager();
    this.dao = new LanceDao(em);
    em.getTransaction().begin();
}

@AfterEach
public void afterEach() {
    em.getTransaction().rollback();
}

@Test
void deveriaBuscarMaiorLanceCadastrado() {
    Usuario usuario = new UsuarioBuilder()
            .comNome("Fulano")
            .comEmail("fulano@email.com")
            .comSenha("12345678")
            .criar();

    em.persist(usuario);

    Leilao leilao = new LeilaoBuilder()
            .comNome("Mochila")
            .comValorInicial("500")
            .comData(LocalDate.now())
            .comUsuario(usuario)
            .criar();

    em.persist(leilao);

    Lance lance = new LanceBuilder()
            .comUsuario(usuario)
            .comValor("500")
            .criar();

    em.persist(lance);

    Lance acheiMaiorLance = this.dao.buscarMaiorLanceDoLeilao(leilao);
    Assert.assertNotNull(acheiMaiorLance);
}

}

solução!

Oi Allison,

É que faltou setar no Lance o leilão e com isso foi null pro banco de dados:

Lance lance = new LanceBuilder()
    .comUsuario(usuario)
    .comValor("500")

    //Faltou:
    .comLeilao(leilao)
    .criar();

Bom noite Rodrigo, funcionou. Porém, fiz adaptações no construtor e na query. Obrigado,