For help with installation, bugs reports or feature requests, please head over to our new forums.
	
Genuitec Community on GitHub
Tagged: spring DSL scaffolding java
- This topic has 7 replies, 2 voices, and was last updated 8 years, 5 months ago by support-tony. 
- 
		AuthorPosts
- 
		
			
				
Hello, I have a scaffolded Spring application. After a recent DB modification and a rescaffolding, there must have been a little bug that created an ill-defined relation in one of the Spring DSL datatypes. Namely, the inverse relation is not the right one. 
 I want to avoid rescaffolding again, because it takes a long time for me (see previous messages in the forum), so I went and edited the inverse relation name in the Spring DSL datatype, then I did a “Generate artifacts from Spring DSL” from the edited datatype.
 However, the generated java file still has the old inverse relationship – it is not taking into account my modification. I also tried removing the java file and regenerating it from scratch, but it yelded the same results.
 Is there anything I am not getting about how this is supposed to be done?Thank you. Here below a few more details that might be useful for your reference. The database has a table fundstructureelement, primary key is itsidcolumn.
 Then there is amasterfeedertable, which has 3 columns:id,masterandfeeder. The primary key isid, whilemasterandfeederare foreign keys to theidoffundstructureelement.The generated SpringDSL datatype for fundstructureelement, Fundstructureelement.datatype, shows that there are two relations:
 masterfeedersForMaster --> Inverse name: fundstructureelementByMaster(this looks fine)
 masterfeedersForFeeder --> Inverse name: fundstructureelementByMaster(this is not right: the inverse name should befundstructureelementByFeeder)Note that the Masterfeeder.datatypecorrectly has the following relations:
 fundstructureelementByMaster --> Inverse name: masterfeedersForMaster
 fundstructureelementByFeeder --> Inverse name: masterfeedersForFeederWhat I did was going to Fundstructureelement.datatype, click on the inverse name formasterfeedersForFeeder, and selectfundstructureelementByFeederin the dropdown (I have bothfundstructureelementByMasterandfundstructureelementByFeederas possible proposed values).
 Then I did the “Generate artifacts from Spring DSL”.However in the Fundstructureelement.javafile that is generated I have the following:/** * @ModelReference [platform:/resource/oligoWorld/.springDSL/ch/oligofunds/oligoworld/domain/Fundstructureelement.datatype#//@relationships%5Bname='masterfeedersForFeeder'%5D] */ @OneToMany(mappedBy = "fundstructureelementByMaster", cascade = { CascadeType.REMOVE }, fetch = FetchType.LAZY) @XmlElement(name = "", namespace = "") java.util.Set<ch.oligofunds.oligoworld.domain.Masterfeeder> masterfeedersForFeeder;At this point, I have one error in the Problems view: 
 fundstructureelementByMaster must be referenced by its inverse relationship(referring toMasterfeeder.datatype)And if I run the Spring application, it fails to start with: May 19, 2017 10:57:52 AM org.apache.catalina.core.ContainerBase addChildInternal SEVERE: ContainerBase.addChild: start: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/oligoWorld]] at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:154) at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901) at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877) at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:649) at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1247) at org.apache.catalina.startup.HostConfig$DeployDirectory.run(HostConfig.java:1897) at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) at java.util.concurrent.FutureTask.run(FutureTask.java:266) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) at java.lang.Thread.run(Thread.java:745) Caused by: java.lang.NoClassDefFoundError: org/springframework/web/context/WebApplicationContext at java.lang.Class.getDeclaredFields0(Native Method) at java.lang.Class.privateGetDeclaredFields(Class.java:2583) at java.lang.Class.getDeclaredFields(Class.java:1916) at org.apache.catalina.util.Introspection.getDeclaredFields(Introspection.java:106) at org.apache.catalina.startup.WebAnnotationSet.loadFieldsAnnotation(WebAnnotationSet.java:270) at org.apache.catalina.startup.WebAnnotationSet.loadApplicationServletAnnotations(WebAnnotationSet.java:139) at org.apache.catalina.startup.WebAnnotationSet.loadApplicationAnnotations(WebAnnotationSet.java:65) at org.apache.catalina.startup.ContextConfig.applicationAnnotationsConfig(ContextConfig.java:415) at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:892) at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:386) at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117) at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90) at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5380) at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) ... 10 more Caused by: java.lang.ClassNotFoundException: org.springframework.web.context.WebApplicationContext at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1720) at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1571) ... 24 more- 
		This topic was modified 8 years, 5 months ago by Luis Pedro. 
 May 19, 2017 at 4:07 am #523389PS: I might add that I tried manually changing the mappedByattribute in the Java file, but the result is the same.May 19, 2017 at 4:43 am #523399Ok, I had a litte progress; after manually editing the Java to reflect the modification in the datatype, I removed the app from tomcat and republished it from scratch, which allowed me to at least run it. However the error in the Problem view stays, and the fact that my DSL modification were not reflected in the code is still an issue. How can I find a way to do this without errors popping up and in a more reliable way? May 22, 2017 at 5:08 am #523757
 support-tonyKeymasterLuis, This looks like a bug and I’ve filed a problem report for the developers to investigate. It looks as though an associated XML file is not being generated correctly and not being updated when you changed the mapping to the correct one. Please try this workaround. Open your project folder in a system explorer (right click on the project and select Open in Explorer). Make sure you are viewing hidden files as you will need to look for the “.springDSL” folder. Under there are the folders that correspond you your package name, down to your domain package. You’ll find the files fundstructureelement.datatype and fundstructureelement.datatypebinding. You’ve already corrected the first, via MyEclipse but you’ll need to manually edit the second to make a similar correction. Once that is done, save the file and then go back to MyEclipse and refresh the project to pick up externally made edits. Now, when you Generate Artifacts from Spring DSL, you should get the correctly generated java file. The edits to the datatypebinding file can be made inside MyEclipse, via the Navigator view, but can lead to some unwanted settings that are tedious to undo, so it’s probably easier to made the edits outside. Please let us know how you get on. May 23, 2017 at 10:10 am #523954Hello Tony, A-ha, I see. As a matter of fact, the datatypebinding _did_ miss the correction. I can’t test this now, but as a rescaffolding is coming up soon anyway, I will make sure to give that a shot. 
 Thanks, best.May 24, 2017 at 12:08 am #524053
 support-tonyKeymasterLuis, Good; it looks like that is the underlying problem, when trying to manually correct the mapping. Please let us know how you get on when needing to do the correction again. Apologies for the inconvenience. May 26, 2017 at 9:50 am #524388Tony, I can confirm the workaround (editing the .datatypebinding by hand, refreshing, and regenerating the class from the DSL) works indeed. 
 Remains to be seen, why the inverse relationships name were generated wrong in the first place. As I see it, this seems a separate bug. Is there a problem when a table has two separate foreign keys referencing the same parent table?
 I seem to recall that I had similar problems with other relationships in my DB in the past, when I had this same kind of pattern; only, I had not identified this inverse relationship generation problem at the time, so I had worked around this by removing foreign keys and ensuring consistency in the code instead. This might have been the cause those other times as well. It may be worth having a look at that too.May 28, 2017 at 11:15 pm #524587
 support-tonyKeymasterLuis, Thanks for letting us know that the workaround works for you. Yes, indeed, looking back, we have had a similar issue but not for someone working with Spring DSL. I have added further information to the bug (which may be two bugs, as you say) to help developers track this down. 
- 
		This topic was modified 8 years, 5 months ago by 
- 
		AuthorPosts

 
					