Search code examples
javajakarta-eeeclipselinkuuid

EclipseLink's @UuidGenerator leads to NullPointerException


I've tried to start using EclipseLink's @UuidGenerator annonation for ID generation but it failed with NPE.

I'm using Java EE 6 + GlassFish 4.1. Entity were created from servlet. EclipseLink version is 2.6.0-M3. Simple long id "@GeneratedValue(strategy = GenerationType.AUTO)" works fine.

Entity code:

@Entity
@UuidGenerator(name="QUANTITY_GEN")
public class Quantity implements Serializable 
{
    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue(generator = "QUANTITY_GEN")
    private String id;

...

}

Servlet code:

@WebServlet(name = "Qtest", urlPatterns =
{
    "/Qtest"
})
public class Qtest extends HttpServlet
{
    @EJB
    private QuantityFacade quantityFacade;

    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException
    {
        ...

        Quantity qt = new Quantity();
        quantityFacade.create(qt);

        ...
    }
}

Trace:

Caused by: java.lang.NullPointerException
    at org.eclipse.persistence.internal.sequencing.SequencingManager.getNextValue(SequencingManager.java:1067)
    at org.eclipse.persistence.internal.sequencing.ClientSessionSequencing.getNextValue(ClientSessionSequencing.java:70)
    at org.eclipse.persistence.internal.descriptors.ObjectBuilder.assignSequenceNumber(ObjectBuilder.java:361)
    at org.eclipse.persistence.internal.descriptors.ObjectBuilder.assignSequenceNumber(ObjectBuilder.java:320)
    at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.assignSequenceNumber(UnitOfWorkImpl.java:486)
    at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.registerNotRegisteredNewObjectForPersist(UnitOfWorkImpl.java:4290)
    at org.eclipse.persistence.internal.sessions.RepeatableWriteUnitOfWork.registerNotRegisteredNewObjectForPersist(RepeatableWriteUnitOfWork.java:518)
    at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.registerNewObjectForPersist(UnitOfWorkImpl.java:4235)
    at org.eclipse.persistence.internal.jpa.EntityManagerImpl.persist(EntityManagerImpl.java:496)
    at com.sun.enterprise.container.common.impl.EntityManagerWrapper.persist(EntityManagerWrapper.java:287)
    at uuidtest.AbstractFacade.create(AbstractFacade.java:24)

Please advise maybe there is some obvious error?


Solution

  • It seems it's really EclipseLink's bug and it will hardly be fixed soon so I've used a work around - direct id generation as described here http://blog.xebia.com/2009/06/03/jpa-implementation-patterns-using-uuids-as-primary-keys/

    @Id
    private String id;
    
    public AbstractBaseEntity() {
        this.id = UUID.randomUUID().toString();
    }