Objectify no almacena de forma síncrona, incluso con ahora

Mi servlet debería realizar lo siguiente: cuando un usuario se registra en un lugar, verifico si actualmente está registrado en algún lugar (incluso si es el mismo lugar), si es así, anúltelo y vuelva a registrarlo.

Tengo el siguiente código, que he simplificado para mostrar mi problema:

    Date tempDate = new Date();


    Visit v = ofy().load().type(Visit.class)
            .filter(Visit.USER_ID, 5L)
            .filter(Visit.EXIT_DATE, null).first().get();

    if(v != null)
        exitVenue(5L, 7L, tempDate);

    Visit visit = new Visit(5L, 7L, tempDate);      
    ofy().save().entity(visit).now();

    Date tempDate2 = new Date();


    Visit v2 = ofy().load().type(Visit.class)
            .filter(Visit.USER_ID, 5L)
            .filter(Visit.EXIT_DATE, null).first().get();

    if(v2 != null)
        exitVenue(5L, 7L, tempDate2);

    Visit visit2 = new Visit(5L, 7L, tempDate2);        
    ofy().save().entity(visit2).now();
}


public void exitVenue(Long userID, Long venueID, Date exitDate) {

    Visit visit = ofy().load().type(Visit.class)
            .filter(Visit.USER_ID, userID)
            .filter(Visit.VENUE_ID, venueID)
            .filter(Visit.EXIT_DATE, null).first().get();

    if(visit == null){
        log.info("ERROR : User " + userID + " exited venue " + venueID + ", but Visit was not found");
        return;
    }
    visit.setExitDate(exitDate);

    ofy().save().entity(visit).now();
}

El problema es que cuando realizo esta operación por segunda vez, no siempre se encuentra una visita en el almacén de datos (cada segunda prueba, más o menos). ¿Y estoy confundido? ¿No se supone que 'ahora ()' lo almacene de inmediato y solo entonces continúe corriendo?

Muchas gracias por tu ayuda, Dan.

Respuestas a la pregunta(1)

Su respuesta a la pregunta