I have a JPA application that uses Spring 3. I am attempting to use @PostConstuct to iniaialise a database with specific Facility codes. When I persist a code within the Class that has the @PostConstuct method - it works. When I call a second class to persist the codes, it fails. Is this something to do with the way I am using the @Autowired annotation?
This is a segment of the Preloader class:
public class Preloader {
@Autowired
private FacilityService service;
@PostConstruct
public void init() {
loadCodeSet();
}
private void loadCodeSet() {
// This works
Facility created = new Facility();
created.setCode("Uni");
created.setDescription("University");
Facility returned = service.create(created);
// This fails
CodeSetLoader cl = new CodeSetLoader();
l.load();
}
This is a segment of the loading class:
public class CodeSetLoader {
@Autowired
private FacilityService facilityService;
public void load() {
loadFacilities();
}
private void loadFacilities() {
Facility test = new Facility();
test.setCode("UNI");
test.setDescription("University");
Facility returned = facilityService.create(test);
}
The exception includes:
Caused by: java.lang.NullPointerException
at util.CodeSetLoader.loadFacilities(CodeSetLoader.java:42)
at util.CodeSetLoader.load(CodeSetLoader.java:24)
at util.Preloader.loadCodeSet(Preloader.java:68)
at util.Preloader.init(Preloader.java:32)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleElement.invoke(InitDestroyAnnotationBeanPostProcessor.java:344)
at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleMetadata.invokeInitMethods(InitDestroyAnnotationBeanPostProcessor.java:295)
at org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:130)
... 22 more
Hoping somebody may be able to assist with this?