0

I get this error:

" NullPointerException: null No source available, here is the exception stack trace:

->java.lang.NullPointerException:

 com.avaje.ebean.Ebean.save(Ebean.java:585)" 

after clicking on "Apply this script now" on the initial page that states "Database 'default' needs evolution!".

I have single table inheritance (the only one supported by ebean), where Usuario is the parent table and Operador is child.

I have the next models:

@Entity
@Table(name="usuario")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "DTYPE", discriminatorType = DiscriminatorType.STRING)
@DiscriminatorValue("usuario")
public class Usuario {
    @Id
    public Long id;

    @Constraints.Required
    public String username;

    @Constraints.Required
    public String password;

    @Constraints.Required
    public String nombre;

    @Constraints.Required
    public String apellido;

    @Constraints.Required
    @Constraints.Email
    public String email;
}

@Entity
@DiscriminatorValue("operador")
public class Operador extends Usuario {
    @Formats.DateTime(pattern = "dd/mm/yyyy hh:mm:ss")
    public Date ultimaSesion;
}

This is the table definitions for Usuario (defined in /conf/evolutions/defaults/1.sql):

# --- !Ups
create table usuario (
  id serial,
  DTYPE varchar(10) not null,
  nombre varchar(30) not null,
  apellido varchar(35) not null,
  username varchar(30) not null,
  password varchar(255) not null,
  email varchar(255) not null,
  ultima_sesion timestamp,
  constraint pk_usuario primary key (id)
);

As you can see, table Usuario has DTYPE and ultima_sesion (which will be inherited by Operador class)

And this is initial-data.yml:

usuario:
    - !!models.Usuario
        username: usuario1
        password: usuario1pass
        nombre: NombreUsuario1
        apellido: ApellidoUsuario1
        email: email@usuario1.com

    - !!models.Operador
        username: usuario2
        password: usuario2pass
        nombre: NombreUsuario2
        apellido: ApellidoUsuario2
        email: email@usuario2.com
        ultimaSesion: 2013-06-15T17:18:23.18-06:00

    - !!models.Usuario
        username: usuario2
        password: usuario2pass
        nombre: NombreUsuario3
        apellido: ApellidoUsuario2
        email: email@usuario3.com

I load the initial-data using the Global class stored in /app as follows:

public class Global extends GlobalSettings {
    public void onStart(Application app) {
        InitialData.insert(app);
    }

    static class InitialData {
        public static void insert(Application app) {
            if(Ebean.find(Usuario.class).findRowCount() == 0) {
                Map<String, List<Object>> usuario = (Map<String, List<Object>>) Yaml.load("initial-data.yml");
                Ebean.save(usuario.get("usuario"));
            }
        }

    }
}

I can't see where the mistake could be. Maybe it is the way I'm trying to instantiate Operador on initial-data.yml? I suppose it is ok to do !!models.Operador since it is a subclass of Usuario.

Thanks for any help you can provide.

Franco
  • 11,845
  • 7
  • 27
  • 33

0 Answers0