| Home » Modeling » EMF "Technology" (Ecore Tools, EMFatic, etc)  » [teneo] Exception when using Enums
 Goto Forum:| 
| [teneo] Exception when using Enums [message #58730] | Mon, 23 October 2006 04:51  |  | 
| Eclipse User  |  |  |  |  | This is a multi-part message in MIME format. --------------090905090207090701020804
 Content-Type: text/plain; charset=ISO-8859-15; format=flowed
 Content-Transfer-Encoding: 7bit
 
 Hi Martin and everybody else reading this !
 
 I have an enum MyEnum in my model and a class which has an attribute
 with the type MyEnum. When I have a single object, set the attribute and
 save everything in a HibernateResource, everything works fine.
 
 But having two objects, where the attribute for both objects is set to
 the same enmu-literal, I get an Exception.
 
 This is the code which does not work:
 
 Resource dbResource = domain.getResourceSet().getResource(uri, true);
 
 
 TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 dbResource.getContents().add(element1);
 
 TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 dbResource.getContents().add(element2);
 
 dbResource.save(null);
 
 
 I'll also attach a little screenshot describing the model and the
 exception stack trace.
 
 greetings,
 Hans
 
 --------------090905090207090701020804
 Content-Type: text/plain;
 name="exception.log"
 Content-Transfer-Encoding: 7bit
 Content-Disposition: inline;
 filename="exception.log"
 
 org.eclipse.emf.teneo.hibernate.HbStoreException: Exception when saving resource test
 at  org.eclipse.emf.teneo.hibernate.resource.HibernateResource.s aveResource(HibernateResource.java:214)
 at  org.eclipse.emf.teneo.resource.StoreResource.save(StoreResou rce.java:271)
 at  de.arcsolutions.remarc.platform.emftest.TwoResourcesLinkTest Case.testTwoResources(TwoResourcesLinkTestCase.java:77)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
 at java.lang.reflect.Method.invoke(Unknown Source)
 at junit.framework.TestCase.runTest(TestCase.java:154)
 at junit.framework.TestCase.runBare(TestCase.java:127)
 at junit.framework.TestResult$1.protect(TestResult.java:106)
 at  junit.framework.TestResult.runProtected(TestResult.java:124)
 at junit.framework.TestResult.run(TestResult.java:109)
 at junit.framework.TestCase.run(TestCase.java:118)
 at junit.framework.TestSuite.runTest(TestSuite.java:208)
 at junit.framework.TestSuite.run(TestSuite.java:203)
 at  org.eclipse.jdt.internal.junit.runner.junit3.JUnit3TestRefer ence.run(JUnit3TestReference.java:128)
 at  org.eclipse.jdt.internal.junit.runner.TestExecution.run(Test Execution.java:38)
 at  org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTe sts(RemoteTestRunner.java:460)
 at  org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTe sts(RemoteTestRunner.java:673)
 at  org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(R emoteTestRunner.java:386)
 at  org.eclipse.pde.internal.junit.runtime.RemotePluginTestRunne r.main(RemotePluginTestRunner.java:58)
 at  org.eclipse.pde.internal.junit.runtime.CoreTestApplication.r un(CoreTestApplication.java:24)
 at  org.eclipse.core.internal.runtime.PlatformActivator$1.run(Pl atformActivator.java:78)
 at  org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher .runApplication(EclipseAppLauncher.java:92)
 at  org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher .start(EclipseAppLauncher.java:68)
 at  org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseS tarter.java:400)
 at  org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseS tarter.java:177)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
 at java.lang.reflect.Method.invoke(Unknown Source)
 at  org.eclipse.core.launcher.Main.invokeFramework(Main.java:336 )
 at org.eclipse.core.launcher.Main.basicRun(Main.java:280)
 at org.eclipse.core.launcher.Main.run(Main.java:977)
 at org.eclipse.core.launcher.Main.main(Main.java:952)
 Caused by: org.hibernate.HibernateException: Illegal attempt to associate a collection with two open sessions
 at  org.hibernate.collection.AbstractPersistentCollection.setCur rentSession(AbstractPersistentCollection.java:410)
 at  org.hibernate.event.def.OnUpdateVisitor.processCollection(On UpdateVisitor.java:40)
 at  org.hibernate.event.def.AbstractVisitor.processValue(Abstrac tVisitor.java:101)
 at  org.hibernate.event.def.AbstractVisitor.processValue(Abstrac tVisitor.java:61)
 at  org.hibernate.event.def.AbstractVisitor.processEntityPropert yValues(AbstractVisitor.java:55)
 at  org.hibernate.event.def.AbstractVisitor.process(AbstractVisi tor.java:123)
 at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formUpdate(DefaultSaveOrUpdateEventListener.java:267)
 at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.ent ityIsDetached(DefaultSaveOrUpdateEventListener.java:216)
 at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:93)
 at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.onS aveOrUpdate(DefaultSaveOrUpdateEventListener.java:70)
 at  org.hibernate.impl.SessionImpl.fireSaveOrUpdate(SessionImpl. java:502)
 at  org.hibernate.impl.SessionImpl.saveOrUpdate(SessionImpl.java :494)
 at  org.hibernate.engine.CascadingAction$1.cascade(CascadingActi on.java:134)
 at org.hibernate.engine.Cascade.cascadeToOne(Cascade.java:213)
 at  org.hibernate.engine.Cascade.cascadeAssociation(Cascade.java :157)
 at  org.hibernate.engine.Cascade.cascadeProperty(Cascade.java:10 8)
 at org.hibernate.engine.Cascade.cascade(Cascade.java:248)
 at org.hibernate.engine.Cascade.cascade(Cascade.java:223)
 at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.cas cadeOnUpdate(DefaultSaveOrUpdateEventListener.java:331)
 at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formUpdate(DefaultSaveOrUpdateEventListener.java:303)
 at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.ent ityIsDetached(DefaultSaveOrUpdateEventListener.java:216)
 at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:93)
 at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.onS aveOrUpdate(DefaultSaveOrUpdateEventListener.java:70)
 at  org.hibernate.impl.SessionImpl.fireSaveOrUpdate(SessionImpl. java:502)
 at  org.hibernate.impl.SessionImpl.saveOrUpdate(SessionImpl.java :494)
 at  org.hibernate.engine.CascadingAction$1.cascade(CascadingActi on.java:134)
 at org.hibernate.engine.Cascade.cascadeToOne(Cascade.java:213)
 at  org.hibernate.engine.Cascade.cascadeAssociation(Cascade.java :157)
 at  org.hibernate.engine.Cascade.cascadeProperty(Cascade.java:10 8)
 at org.hibernate.engine.Cascade.cascade(Cascade.java:248)
 at  org.hibernate.event.def.AbstractFlushingEventListener.cascad eOnFlush(AbstractFlushingEventListener.java:130)
 at  org.hibernate.event.def.AbstractFlushingEventListener.prepar eEntityFlushes(AbstractFlushingEventListener.java:121)
 at  org.hibernate.event.def.AbstractFlushingEventListener.flushE verythingToExecutions(AbstractFlushingEventListener.java:65)
 at  org.hibernate.event.def.DefaultFlushEventListener.onFlush(De faultFlushEventListener.java:26)
 at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:985)
 at  org.eclipse.emf.teneo.hibernate.resource.HibernateResource.s aveResource(HibernateResource.java:210)
 ... 34 more
 
 
 --------------090905090207090701020804
 Content-Type: image/jpeg;
 name="model.jpg"
 Content-Transfer-Encoding: base64
 Content-Disposition: inline;
 filename="model.jpg"
 
 /9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAYEBQYFBAYGBQYHBwYIChAKCgkJ ChQODwwQFxQY
 GBcUFhYaHSUfGhsjHBYWICwgIyYnKSopGR8tMC0oMCUoKSj/2wBDAQcHBwoI ChMKChMoGhYa
 KCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgo KCgoKCj/wAAR
 CAB+AasDASIAAhEBAxEB/8QAHAABAQADAQEBAQAAAAAAAAAAAAYEBQcDCAIB /8QARRAAAQQB
 AgIHBAcGBQMDBQAAAQACAwQFBhESEwcUIVRWk9MWFyIxFTdBdZaz1CMyNpXS 8CRCUWFzM3Gy
 JTSBSFOGkcT/xAAYAQEBAQEBAAAAAAAAAAAAAAAAAQIDBP/EABwRAQEBAAMB AQEAAAAAAAAA
 AAABEQISIQMxUf/aAAwDAQACEQMRAD8A+qUREBERAREQEREBERAREQEREBER AREQEREBERAR
 EQEREBERAREQEREBERAREQEREBERAREQEREBERAREQEREBERAREQEREBERAR TfSXano9HGq7
 dOaSC1XxNuWKWN3C6N7YXFrgR8iCAd14+weI75qT8R5H10FUilfYPEd81J+I 8j66eweI75qT
 8R5H10FUilfYPEd81J+I8j66eweI75qT8R5H10FUihbWntJ07DoLefy8E7Nu KOXVd5rhuNxu
 DY3+RWRR0jp2/EZaOVztmIO4S+HU994B+e24n+faP/2szlxtyVcv6skUr7B4 jvmpPxHkfXT2
 DxHfNSfiPI+utIqkUr7B4jvmpPxHkfXT2DxHfNSfiPI+ugqkUr7B4jvmpPxH kfXT2DxHfNSf
 iPI+ugqkUr7B4jvmpPxHkfXT2DxHfNSfiPI+ugqkUr7B4jvmpPxHkfXT2DxH fNSfiPI+ugqk
 Ur7B4jvmpPxHkfXT2DxHfNSfiPI+ugqkXJNSPl0T0jaRgw9zKSVMlDcbbr3s lYuMk4HV+Ejn
 PfwEcbu1u3z7dx2LraAiIgIiICIiAiIgIiICIiAii9VUxlte4DGWbWRhovxl +y+OlfnqF8jJ
 abWFzontJ2Ej+wnb4lleweI75qT8R5H10FUilfYPEd81J+I8j66eweI75qT8 R5H10FUilfYP
 Ed81J+I8j66eweI75qT8R5H10FUilfYPEd81J+I8j66eweI75qT8R5H10FUi lfYPEd81J+I8
 j66eweI75qT8R5H10FUilfYPEd81J+I8j66eweI75qT8R5H10FUi5t0gaVpY bQWpMnjshqSK
 9SxlmzBIdQ33hkjInOaeF0xB2IHYQQftVP0f5ezm9KUbl7hNlzA2R7RtxkD9 7b7N/wDbs/7f
 JBRIiICIiAiIglelj6rNZfct38h6qlK9LH1Way+5bv5D1VICIiAiIgipMi2r n87G7LYymetM
 PLtDdx/w8PaP2jez/wCPsK2WjLAsuzUjbMFkG8BzYBsx3+Hh+Xaf+3zX7lw+ UjyWQsY/JUoo
 rcrZjHPSfK5pEbI/3hK3s+AH5faszA42xjxefdtRWZ7djnudFCYmt2jYwANL nH5M333+1eXh
 8rPp2z+t3l45J0jaT04/py6NI34DEOjyb8tJeaaUZFp4rtcHSjh+MhxLt3b9 pJTVHSVncFqj
 UWA0jp+KzW0yzHxxYypirFh9tkrQ57Wyw/s6oZGdmhzHb8J23/dHWsjp7F5H O4jM3avMyWJ5
 3UpuY4crmtDJPhB2du0AfEDt9my1Wc6PtMZzK2Mhk8ZzrFnk9aY2xLHDb5Lu KLnxNcI5uE/L
 ja7sAHyAC9TCEt9I2p4ekWbTl+LEYAT5B1TGNytScsvQ8vsnissfy3yB5YTA Ws342x8wPO4h
 dGZfMa0odEWP1hf+lsbn7uXuXq0jC1tg1y58LJe3Z7WyAuDAGs24Glh4AT3X 3faY+nfpf6M/
 xfXfpLl9Yl6v1rh4efyOLlc3b/Pw8W/xb79qe77TAwX0MzGcvGtu/SEMMdiV nVZ+LjD4HBwM
 GztyBGWgcTth8R3DnXS1pXCaZk0M7T+Pix0d3W2LkmgrlzIONrZGhzYgeBhI A3LWji2G++wW
 VnelTK43XtHH1YaOQw8mdgwdp8Fd/BWll4w1nWjJs+Zoa2R8bYeFnFwF/EA4 20fRtpVskcr8
 bLPZZkIMp1mxcnmndYhbwxOdK95e4MBIDHEtG57O0pZ6NtK2cyMpJjZRZGQZ leCO5PHB1tu2
 0/Ja8R8zsG7uHc9u++5QcvHS3rhs2TovwONj1NHDalh03ZhngslrHgRywTcT o7reESEtZynO
 5buDcDt6B0Sa0sawhy4t28bPLRmZE6OCtNTs13Fg44rFaUu5bmvDmhzZHtds 4DYtO/rJ0SaH
 ljkinwMU1YsnjjrTTyyQVhM7ik5ETnlkBJG+8YaR9hCoNOaXxGnJL0uLryiz ee2S1ZsWJbM8
 xa0NbxSyuc8hoGwG+w3OwG5QbpERAREQci6X/rK0B/xX/wDyqrrq5F0v/WVo D/iv/wDlVXXU
 BERAREQEREBERAREQEREErkvrT099y5P8+gqpSuS+tPT33Lk/wA+gqpBFZvV d6nrijhRFWo0
 puD/ABdxrnCbdzf+nwkAbkiIcX+eRpdw/sWWudYfWGrshQBs56jDZtvoMtQU 5Y7FjFTTXa0T
 ojGarW1yGyzN5c7pX7sGxPLkJ7BLqnCxWrVZ9+Pn138p0Ya4l8nDxGOMAftJ ANt2M3cNxuO0
 b7HG36uToQXcfPHYqTtD45WHcOBWrxs9sTY5zR1ZdwusbOOz+Wlmw9F9qmLU 8DObbsGGhPBH
 +zYA+Yiey1kcbQXtZ+65zSVM6R1Bq3UkWnn2dU2akV27Upv6pTrCQ8eEZckc XPje3tlG4AaN
 g54JcCwM6B7ztNfSv0Zvm/pLk9Z6p9A3+dyuLh5nByd+Hi7OLbbfsVqsq4hp 7XWqM1nMHNNf
 xFFttmOe3GOn4X24ZoIJJpY63IfNIGulmaJGzMY3k/GNo5C71l1JqdmgdHXL GoOG/maTbstn
 lRVWueYoeCtE7kT8Ur+NzhEInPlcJCx0bWCI9qUrkOkDTlLK1sb1uzcu2aTc jDHjqFi7x1nO
 LWygwseOEkfPf7R/qEHGsBqjLupW83TsRZPUNzIR5IYx1eKXlySacfPGI2Na JWhz2iIEO4nN
 i4eIkyF9hHnsjkNQY3DYHWlnJYi1dhjObrNpzScZq3pJK4e2Hk/D1es7bg4w JTudnN261UsM
 tVYbEQlbHMxsjRLG6N4BG44mOAc0/wCoIBHyIXqg5VW13mKsmNrf4bLTuu2q UldkZbbkbBas
 QNeSCIw6RsXEOxo4oZTs2LmS1uqoiCV6WPqs1l9y3fyHrG6Iv4Go/wB/YFk9 LH1Way+5bv5D
 1jdEX8DUf7+wILNERAREQEREEr0sfVZrL7lu/kPT2Xy/jvUnkY79KnSx9Vms vuW7+Q9VSCV9
 l8v471J5GO/Sp7L5fx3qTyMd+lW4yeVFG1XrMp2bU07HyNbAWDZrC0Ekvc37 XtX4o5jrORZT
 moW6kr4nzMMxjIcGloP7j3dvxt+a5368Zy676vW5rVey+X8d6k8jHfpU9l8v 471J5GO/SrE1
 r0laf0dlYqGYm4ZTCLMx50MfJhLnND+GSRrpf3H/AAxNkf8AD+7u5od5W+kq hSq5C5exGXr4
 6q+9DFbcIHMtS1BMZY42tlLwdq8xBe1jTwfMEgHojYey+X8d6k8jHfpU9l8v 471J5GO/SpqH
 W9HCZ2LDyUclbvzcgRR1IWv43TNtOY3tcNv/AGkgLjs1vE0uIbxObKZPpTjs 43BT0Jq2nPpG
 aB759QxMfHHUmrWZYZv2c4aON1csAdIHA77t7W7hV+y+X8d6k8jHfpU9l8v4 71J5GO/SrVYX
 pIqyVpW5atZa6nSkyNq/Xrk1OqMksMbZadyeGQVuNrBxuLZWcJka1725VjpB r1LMNK9gs3Xy
 880cMeO5cMszuZHO+N+8cjow1xrTN3Lhwlu7+BnxoMv2Xy/jvUnkY79Knsvl /HepPIx36VaT
 MdMGmMQ6u2/JLDI5j5LMcssET6gZK+J/E18gMpbJDM0iASk8vsB4mcXtN0gz WM7hKeIwWSmp
 2c1YxFq3NHHGwOhbY4+XxSNLtnQB/EGubwBzR+0HAA2vsvl/HepPIx36VPZf L+O9SeRjv0q9
 cXrCplXY5mPpXp57VUWpYQIw+kOayIssAv8A2cgcZd29p/w8wG7mcJ8ukLIZ zFY6lawNrGw8
 d2tTlbdpvn4ufYiha5pbLHw8PMLiDvxbAbt+aB7L5fx3qTyMd+lT2Xy/jvUn kY79KtfY6SMN
 i9UVtM5S1FJlg+CrYmifDEwWJWt4GtgdKZyHF7Nixr2t4+1/wvLdfluk9xxz 58DgclbczJ1q
 BceQWkPsRRyNd+2Bhl2laBHNy3h0jSWcLJCwKD2Xy/jvUnkY79Knsvl/HepP Ix36VSlHpCyE
 U2av5Wb/ANLxk2T5lWtpy5xOiqvmaNrrpOQXERA/IAklnYflV09a15cvUxN/ F5LG5SzM2JtW
 zyXOa18U8rJC6KR7eE9VmbsHFwLRu0AgkHsvl/HepPIx36VPZfL+O9SeRjv0 q1V3pSxsFqet
 Ww+bu2IZmQObXhiDeJ12ak343yNYN5odgCQSHhwGzZOCvwOVgzWMZdrMljaX yQyRSgB8Usb3
 RyRu2JBLXsc0lpLTtuCRsSHHekLF3Mb0laG67ncll+ZFd4eux128rZ1bfh5M Ufz3G/Fv8htt
 279yXIul/wCsrQH/ABX/APyqrrqAiIgIiICIiAiIgIiICIiCVyX1p6e+5cn+ fQVUpXJfWnp7
 7lyf59BVSDl2dwNGDOuZBh5XsqTdZoPb1otpzPAc6SINrPjG7tncJc9nE0Hh BLgb3TWOrYzD
 V4qcBhEg50nG5znvkd2uc9zwHOcSe0uAP+oHyX6t4DD3LT7NvE4+ey/billr Mc92w2G5I3PY
 AFsIYo4YmRQsbHExoaxjBsGgdgAH2BO30tva+Gcc8jln/wBU/wD+Gf8A9ygM fndSWulCzXnz
 /U8lFrN1dlOfIWTNNjQwbRNx7I3RiIxfGLDuHtG5cP3l9KIg+S4shlsr9P6c t5fN6kv3MZmH
 tsYu/YHMczfhhu46QcdVwe0NaIwxruNsW0jXP3ytE3cTU1touV2sfoCoej+u zr/XK7uKXrJ4
 4eOy2RvY4PHAAC3l8I2DSF9VIg+e+kfJZGbWmWgx2qcu7G1ujybKwyU7vLZa mZI7lzkxAN3P
 wu4o+HfYN/cLmnX53WWcr8jI5LLZKFmT6MnWa5iL2MmyR2c6SNjBtzWtcHFz R8DPiPC0bj6U
 RB8wZDL5y71YHUWbhZD0WNzDmwXns5tpu5EriDvxcXCS4EOdw8JJaXNdVdEG WzDdf4DHXM1k
 shVyWhqmXsNuzmXeyZQwPbv+7sx3CeHbi2Dn8T93HuqIJXpY+qzWX3Ld/Ies boi/gaj/AH9g
 WT0sfVZrL7lu/kPWN0RfwNR/v7Ags0REBERAREQSvSx9VmsvuW7+Q9VS0HSF jrWX0DqXG4+P
 m3bmMs14I+IN45HxOa0bnYDckdp7FFydMtWKR8cuj9XMkYS1zXQVgQR8wRz0 HQsphqeUlglt
 CwJYWuax8FmWBwDuEuG7HDcHhb8/9F+MdgaOPudbg62+wI3RB09yafZri0kA PcQNy1vy/wBF
 z730UvCOrPJreunvopeEdWeTW9dZ6zdxdWuZ0xHkcq6/Dk8ljpZoWVrYpSMZ 1qFjnuaxznNL
 mbcyXZ0TmP8AjPxbhpbi3dCYe9iosbd6zPSZdu3XRmQN5jrbbLZWOLQDw7W5 NtiCNm9p2O8p
 76KXhHVnk1vXT30UvCOrPJreutIpqGg6lfUUGdtZXL5DKRvikMtqWPZ5jisx N+BjGtaOG3J2
 MDQS1rtuIvL2K6P8VjLuDtQWLzpMPVq1IA97CHMrw2YWF+zRuS23ITtt2hu2 2xBmffRS8I6s
 8mt66e+il4R1Z5Nb10F3kNM47I2szLebLNHlsfHjLUJfwsdCwzHYEbOBPWHg nf7Bttt2zWV6
 PpreRxV053JWL8F1s0+RmkjisNijr2mRMjEUbYzwy2S7ZzSHBzg/jbsxan30 UvCOrPJreunv
 opeEdWeTW9dBTRaDqVnNdQyuXpSSsMd+SvLG198GWSV3McWExkyTzu3hMRHN OxHCzhyvY+o2
 PGNgu3oHY/LT5iN7DGS6SZ05kjdxMI5ZFmRvYA4DbZ243Uf76KXhHVnk1vXT 30UvCOrPJreu
 gsMDpx+PtZy3zIqk+RyAst6o1p5cLS3aLic3tEjhLK4ADZ1mXhJd+0dtc5io MzSjq2nysjjt
 V7YMZAPHDMyZg7QewujAP+2/y+a5176KXhHVnk1vXT30UvCOrPJreugtX6Yj +nZsjXyeSqxW
 ZmWbVKCRjYbMzGsY17ncPNHwxxAta9rHBmzmkOfxaq10fV7TLPPzubfK/q4r zOkhdJWbBO2e
 JocYzzeF7Rs6fmuAL9iC95dP++il4R1Z5Nb1099FLwjqzya3roKCXQDZaGXx ztR5v6IyfXed
 QAq8tvWjI6ThdyOYNnSuc3d52IG+47DsM1o+plMy/Ltu3qeUDIGQ2a5jJrmL rADmtexzSXNt
 zNPEHDYggBwBUf76KXhHVnk1vXT30UvCOrPJreugoMb0b4fHxTRwWck5ss1a cmawJXcUF6W6
 zd7gXO3kmcCXEktA7eLdxpcHioMNSkq1XyvjktWLZMhBPHNM+Z47AOwOkIH+ 23z+a5176KXh
 HVnk1vXT30UvCOrPJreugx+l/wCsrQH/ABX/APyqrrq+ftRaq9s9faTtVcJl 8fBj22WSvvsi
 aHGV0PDw8Ej/AP7bt99vsX0CgIiICIiAiIgIiICIiAiIghdWYTFZ7pJ03Vzm Mo5KszE5KRsV
 yuyZjXiaiA4BwI32JG/+5Ww93Gh/Bum/5XB/SmS+tPT33Lk/z6CqkEr7uND+ DdN/yuD+lPdx
 ofwbpv8AlcH9K9crmNRVspNBj9Lddpt4eC19IRx8e7QT8BG42O4/+FQVHyy1 IZLEPInexrpI
 uIO4HEdrdx2HY9m6zOUtxc81Ne7jQ/g3Tf8AK4P6U93Gh/Bum/5XB/SuX6H1 jq1mmefFyspe
 y2QpVqUDYny9VDsRFad/17TeYOFu2xlYeIvkJcXcC3cuvNXznk162Eoyw/R8 Vh1hpsubLYyM
 1Jw4IpuEf9MSFvNcYy0xkvJ42aRa+7jQ/g3Tf8rg/pT3caH8G6b/AJXB/Sp+ LL5jJ5fRdya/
 yK5zV3F2alVhZHZkgivsdK8kk8JdXY5se+zCTxGQhrm0uub+Rw3R5qfIwWYh kaePuWa80cOw
 YWse6L4XFwJaA0EnscQTsAeEB5e7jQ/g3Tf8rg/pT3caH8G6b/lcH9K8tLwn Fa0zmFr2b0uO
 hx9K5Gy5bltPbLLJaY8iSVzn7EQx/DvwjYkAFzia9BK+7jQ/g3Tf8rg/pT3c aH8G6b/lcH9K
 qkQcw6TdA6Op9G2rLVPSen4LMGJtyRSxY2Fr43theQ5pDdwQQCCFvOiL+BqP 9/YFk9LH1Way
 +5bv5D1jdEX8DUf7+wILNERAREQEREBeMlSvK8vkrxPefm5zASV7Igx+o1O6 weWE6jU7rB5Y
 WQiDH6jU7rB5YTqNTusHlhZCIMfqNTusHlhOo1O6weWFkIgx+o1O6weWE6jU 7rB5YWQiDH6j
 U7rB5YTqNTusHlhZCIMfqNTusHlhOo1O6weWFkIgx+o1O6weWE6jU7rB5YWQ iDH6jU7rB5YT
 qNTusHlhZCIMfqNTusHlhOo1O6weWFkIgx+o1O6weWFkIiAiIgIiICIiAiIg IiICIiCVyX1p
 6e+5cn+fQVUpXJfWnp77lyf59BVSAimsrrnTuJyk2OyGR5NyHh44+RI7bdoc O0NI+RH2qgqW
 IrlSGzXdxwTMbJG7YjdpG4Ox7fkVmc+NuS+rlzWqOk9OGraqnAYg1rTIY7EX Uo+CZkQAia8c
 OzgwABoP7uw22WVHhMVHHHHHjKLI42QRsa2uwBrIXcULQNuwRuJc0f5T2jZc 1070vxP05cy2
 oaUtWuLVWtRe416vWjLSisf57DmRnZz37PkA4XMaC6Tdq2vvaw00EEmLxuXy hlZXf/g2QuY0
 zWZKrWmV0gjJE0ZZ2PIduHML2Bzm6RdsxtFnJ4KVZvJmfZi2iaOCV/HxyN7O xzuZJu4dp43b
 /Mr1rVoKsZjqwxQxue+QtjYGgve4ue7YfaXOLiftJJ+1RWc1TlfZ2XUGEFGO jTZIJaNuF8lq
 1aZK6J1NhY8Njk5jOU145we9/wALSAOZYOtTChYsChZMsXM4KwdHzJeEkN4T x8Px7At4nDsc
 OLhO4AeOEwmKwNV9XB4yjjaz3mR0VOuyFjnkAFxDQBvsAN/9gtgp/QuXvZzT 5uZWCtXutu3K
 skVZ7nxt5NqWEbOcAXdkY7dhudzs3fYUCAiIglelj6rNZfct38h6xuiL+BqP 9/YFk9LH1Way
 +5bv5D1jdEX8DUf7+wILNERAREQEREBERAREQEREBERAREQEREBERAREQERE BERAREQEREBE
 RAREQEREBERAREQSuS+tPT33Lk/z6CqlBdIGTsab1PhNRHD5LJ4+CjcpTdQE bnxPlkquYXB7
 2/CRC8bj5HYfaFp/fRS8I6s8mt66DqqLlXvopeEdWeTW9dPfRS8I6s8mt66D d4ro1oYmi2tj
 svl4XQvrTVZt4HPqyw1BU5jN4i1xfC3hcHhze0loae1bA6IovkfLYvZKxYk6 iZZppmuc91W0
 +0xx+HYcUkjgWgBobs1gYAFKe+il4R1Z5Nb1099FLwjqzya3roKCfQDTcq2K Oo83Q6tNbsxR
 QirIxstmaSWSQCWB/wAX7VzA75hhIH7zy6wrRPhjLZJ5Z3F738cgaCA5xIb8 IA2aCGjs32A3
 JO5PL/fRS8I6s8mt66e+il4R1Z5Nb10HRcHioMNSkq1XyvjktWLZMhBPHNM+ Z47AOwOkIH+2
 3z+a2C5V76KXhHVnk1vXT30UvCOrPJreug6qi5V76KXhHVnk1vXT30UvCOrP Jreugq+lj6rN
 Zfct38h6xuiL+BqP9/YFB636U4c9ozP4eppTU8dnIY+xUifLFXDGvkjc0FxE xO25G+wP/ZXv
 RI0t0RTa4EOBIII2IOwQWSIiAiIgIiICIiAiIgIiICIiAiIgIiICIiAiIgIi ICIiAiIgIiIC
 IiAiIgIiICIiAiIg/jmhzS1wBaRsQRuCF4dRqd1g8sLIRBj9Rqd1g8sJ1Gp3 WDywshEGP1Gp
 3WDywnUandYPLCyEQY/UandYPLCdRqd1g8sLIRBj9Rqd1g8sJ1Gp3WDywshE GP1Gp3WDywnU
 andYPLCyEQY/UandYPLC9Yoo4WlsMbI2k77NaAN1+0QEREH/2Q==
 --------------090905090207090701020804--
 |  |  |  |  | 
| Re: [teneo] Exception when using Enums [message #58830 is a reply to message #58730] | Tue, 24 October 2006 01:48   |  | 
| Eclipse User  |  |  |  |  | Hi Hans, I have a testcase which tests this and it works. This exception can occur when you try to save an
 object in two different sessions. This occurs for example if you have references between objects in
 different resources. If you save one resource then the refered object in the other resource is also
 saved, when you then save the second resource this error occurs. Also the name of your testcase
 seems to refer to this.
 If this is the case then you can use a SessionController (url probably truncated by line break):
 http://www.elver.org/hibernate/hibernateresources.html#Shari ng+one+Session+between+Resources%2C+One+transaction+when+sav ing+multiple+resources
 
 to share a session between resources.
 
 gr. Martin
 
 Hans Mueller-Dieckert wrote:
 > Hi Martin and everybody else reading this !
 >
 > I have an enum MyEnum in my model and a class which has an attribute
 > with the type MyEnum. When I have a single object, set the attribute and
 > save everything in a HibernateResource, everything works fine.
 >
 > But having two objects, where the attribute for both objects is set to
 > the same enmu-literal, I get an Exception.
 >
 > This is the code which does not work:
 >
 > Resource dbResource = domain.getResourceSet().getResource(uri, true);
 >
 >
 > TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 > element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 > dbResource.getContents().add(element1);
 >
 > TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 > element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 > dbResource.getContents().add(element2);
 >
 > dbResource.save(null);
 >
 >
 > I'll also attach a little screenshot describing the model and the
 > exception stack trace.
 >
 > greetings,
 > Hans
 >
 >
 >  ------------------------------------------------------------ ------------
 >
 > org.eclipse.emf.teneo.hibernate.HbStoreException: Exception when saving resource test
 > 	at  org.eclipse.emf.teneo.hibernate.resource.HibernateResource.s aveResource(HibernateResource.java:214)
 > 	at  org.eclipse.emf.teneo.resource.StoreResource.save(StoreResou rce.java:271)
 > 	at  de.arcsolutions.remarc.platform.emftest.TwoResourcesLinkTest Case.testTwoResources(TwoResourcesLinkTestCase.java:77)
 > 	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 > 	at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
 > 	at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
 > 	at java.lang.reflect.Method.invoke(Unknown Source)
 > 	at junit.framework.TestCase.runTest(TestCase.java:154)
 > 	at junit.framework.TestCase.runBare(TestCase.java:127)
 > 	at junit.framework.TestResult$1.protect(TestResult.java:106)
 > 	at  junit.framework.TestResult.runProtected(TestResult.java:124)
 > 	at junit.framework.TestResult.run(TestResult.java:109)
 > 	at junit.framework.TestCase.run(TestCase.java:118)
 > 	at junit.framework.TestSuite.runTest(TestSuite.java:208)
 > 	at junit.framework.TestSuite.run(TestSuite.java:203)
 > 	at  org.eclipse.jdt.internal.junit.runner.junit3.JUnit3TestRefer ence.run(JUnit3TestReference.java:128)
 > 	at  org.eclipse.jdt.internal.junit.runner.TestExecution.run(Test Execution.java:38)
 > 	at  org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTe sts(RemoteTestRunner.java:460)
 > 	at  org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTe sts(RemoteTestRunner.java:673)
 > 	at  org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(R emoteTestRunner.java:386)
 > 	at  org.eclipse.pde.internal.junit.runtime.RemotePluginTestRunne r.main(RemotePluginTestRunner.java:58)
 > 	at  org.eclipse.pde.internal.junit.runtime.CoreTestApplication.r un(CoreTestApplication.java:24)
 > 	at  org.eclipse.core.internal.runtime.PlatformActivator$1.run(Pl atformActivator.java:78)
 > 	at  org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher .runApplication(EclipseAppLauncher.java:92)
 > 	at  org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher .start(EclipseAppLauncher.java:68)
 > 	at  org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseS tarter.java:400)
 > 	at  org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseS tarter.java:177)
 > 	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 > 	at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
 > 	at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
 > 	at java.lang.reflect.Method.invoke(Unknown Source)
 > 	at  org.eclipse.core.launcher.Main.invokeFramework(Main.java:336 )
 > 	at org.eclipse.core.launcher.Main.basicRun(Main.java:280)
 > 	at org.eclipse.core.launcher.Main.run(Main.java:977)
 > 	at org.eclipse.core.launcher.Main.main(Main.java:952)
 > Caused by: org.hibernate.HibernateException: Illegal attempt to associate a collection with two open sessions
 > 	at  org.hibernate.collection.AbstractPersistentCollection.setCur rentSession(AbstractPersistentCollection.java:410)
 > 	at  org.hibernate.event.def.OnUpdateVisitor.processCollection(On UpdateVisitor.java:40)
 > 	at  org.hibernate.event.def.AbstractVisitor.processValue(Abstrac tVisitor.java:101)
 > 	at  org.hibernate.event.def.AbstractVisitor.processValue(Abstrac tVisitor.java:61)
 > 	at  org.hibernate.event.def.AbstractVisitor.processEntityPropert yValues(AbstractVisitor.java:55)
 > 	at  org.hibernate.event.def.AbstractVisitor.process(AbstractVisi tor.java:123)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formUpdate(DefaultSaveOrUpdateEventListener.java:267)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.ent ityIsDetached(DefaultSaveOrUpdateEventListener.java:216)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:93)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.onS aveOrUpdate(DefaultSaveOrUpdateEventListener.java:70)
 > 	at  org.hibernate.impl.SessionImpl.fireSaveOrUpdate(SessionImpl. java:502)
 > 	at  org.hibernate.impl.SessionImpl.saveOrUpdate(SessionImpl.java :494)
 > 	at  org.hibernate.engine.CascadingAction$1.cascade(CascadingActi on.java:134)
 > 	at org.hibernate.engine.Cascade.cascadeToOne(Cascade.java:213)
 > 	at  org.hibernate.engine.Cascade.cascadeAssociation(Cascade.java :157)
 > 	at  org.hibernate.engine.Cascade.cascadeProperty(Cascade.java:10 8)
 > 	at org.hibernate.engine.Cascade.cascade(Cascade.java:248)
 > 	at org.hibernate.engine.Cascade.cascade(Cascade.java:223)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.cas cadeOnUpdate(DefaultSaveOrUpdateEventListener.java:331)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formUpdate(DefaultSaveOrUpdateEventListener.java:303)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.ent ityIsDetached(DefaultSaveOrUpdateEventListener.java:216)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:93)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.onS aveOrUpdate(DefaultSaveOrUpdateEventListener.java:70)
 > 	at  org.hibernate.impl.SessionImpl.fireSaveOrUpdate(SessionImpl. java:502)
 > 	at  org.hibernate.impl.SessionImpl.saveOrUpdate(SessionImpl.java :494)
 > 	at  org.hibernate.engine.CascadingAction$1.cascade(CascadingActi on.java:134)
 > 	at org.hibernate.engine.Cascade.cascadeToOne(Cascade.java:213)
 > 	at  org.hibernate.engine.Cascade.cascadeAssociation(Cascade.java :157)
 > 	at  org.hibernate.engine.Cascade.cascadeProperty(Cascade.java:10 8)
 > 	at org.hibernate.engine.Cascade.cascade(Cascade.java:248)
 > 	at  org.hibernate.event.def.AbstractFlushingEventListener.cascad eOnFlush(AbstractFlushingEventListener.java:130)
 > 	at  org.hibernate.event.def.AbstractFlushingEventListener.prepar eEntityFlushes(AbstractFlushingEventListener.java:121)
 > 	at  org.hibernate.event.def.AbstractFlushingEventListener.flushE verythingToExecutions(AbstractFlushingEventListener.java:65)
 > 	at  org.hibernate.event.def.DefaultFlushEventListener.onFlush(De faultFlushEventListener.java:26)
 > 	at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:985)
 > 	at  org.eclipse.emf.teneo.hibernate.resource.HibernateResource.s aveResource(HibernateResource.java:210)
 > 	... 34 more
 >
 >
 >
 >  ------------------------------------------------------------ ------------
 >
 
 
 --
 
 With Regards, Martin Taal
 
 Springsite/Elver.org
 Office: Hardwareweg 4, 3821 BV Amersfoort
 Postal: Nassaulaan 7, 3941 EC Doorn
 The Netherlands
 Tel: +31 (0)84 420 2397
 Fax: +31 (0)84 225 9307
 Mail: mtaal@springsite.com - mtaal@elver.org
 Web: www.springsite.com - www.elver.org
 |  |  |  |  | 
| Re: [teneo] Exception when using Enums [message #58906 is a reply to message #58830] | Tue, 24 October 2006 03:40   |  | 
| Eclipse User  |  |  |  |  | Hi Martin, 
 I save everything in a single resource. The name of the test case is
 just because I changed an old test case when trying to check out if I
 can reproduce the Exception with a test case.
 The funny thing is, that when I'm commenting out the marked lines down
 below and run the test case twice, the second time it fails.
 
 If you want to, I could provide you the project containing the testmodel
 and the test case.
 
 For now, here is my full testcode:
 
 
 final String dataStoreName = "enumtest";
 
 final HbDataStore dataStore =
 HbHelper.INSTANCE.createRegisterDataStore(dataStoreName);
 
 EPackage[] packages = new EPackage[] {TestmodelPackage.eINSTANCE};
 
 dataStore.setEPackages(packages);
 
 Properties properties = new Properties();
 
 properties.setProperty("hibernate.connection.driver_class", "com.mysql.jdbc.Driver");
 properties.setProperty("hibernate.connection.url","jdbc:mysql://127.0.0.1:3306/enumtest");
 properties.setProperty("hibernate.connection.username","root ");
 properties.setProperty("hibernate.connection.password","system ");
 properties.setProperty("hibernate.dialect","org.hibernate.dialect.MySQLInnoDBDialect ");
 
 dataStore.setHibernateProperties(properties);
 
 dataStore.initialize();
 
 EditingDomain domain = new AdapterFactoryEditingDomain(new
 ComposedAdapterFactory(ComposedAdapterFactory.Descriptor.Reg istry.INSTANCE),new
 BasicCommandStack());
 
 String uriStr = "hibernate://?" + HibernateResource.DS_NAME_PARAM +
 "=enumtest";
 URI uri = URI.createURI(uriStr);
 Resource dbResource = domain.getResourceSet().getResource(uri, true);
 
 TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 dbResource.getContents().add(element1);
 
 // Commenting the following lines out brings up an Exception when
 // running the test case twice
 TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 dbResource.getContents().add(element2);
 
 dbResource.save(null);
 
 reetings,
 Hans
 
 Martin Taal schrieb:
 > Hi Hans,
 > I have a testcase which tests this and it works. This exception can
 > occur when you try to save an object in two different sessions. This
 > occurs for example if you have references between objects in different
 > resources. If you save one resource then the refered object in the other
 > resource is also saved, when you then save the second resource this
 > error occurs. Also the name of your testcase seems to refer to this.
 > If this is the case then you can use a SessionController (url probably
 > truncated by line break):
 >  http://www.elver.org/hibernate/hibernateresources.html#Shari ng+one+Session+between+Resources%2C+One+transaction+when+sav ing+multiple+resources
 >
 >
 > to share a session between resources.
 >
 > gr. Martin
 >
 |  |  |  |  | 
| Re: [teneo] Exception when using Enums [message #58957 is a reply to message #58906] | Tue, 24 October 2006 05:41   |  | 
| Eclipse User  |  |  |  |  | Hi Hans, Can you send me the test project and test case?
 So if you don't comment out the lines then running twice does not result in an error?
 
 gr. Martin
 
 Hans Mueller-Dieckert wrote:
 > Hi Martin,
 >
 > I save everything in a single resource. The name of the test case is
 > just because I changed an old test case when trying to check out if I
 > can reproduce the Exception with a test case.
 > The funny thing is, that when I'm commenting out the marked lines down
 > below and run the test case twice, the second time it fails.
 >
 > If you want to, I could provide you the project containing the testmodel
 > and the test case.
 >
 > For now, here is my full testcode:
 >
 >
 > final String dataStoreName = "enumtest";
 >
 > final HbDataStore dataStore =
 > HbHelper.INSTANCE.createRegisterDataStore(dataStoreName);
 >
 > EPackage[] packages = new EPackage[] {TestmodelPackage.eINSTANCE};
 >
 > dataStore.setEPackages(packages);
 >
 > Properties properties = new Properties();
 >
 > properties.setProperty("hibernate.connection.driver_class", "com.mysql.jdbc.Driver");
 >
 > properties.setProperty("hibernate.connection.url","jdbc:mysql://127.0.0.1:3306/enumtest");
 >
 > properties.setProperty("hibernate.connection.username","root ");
 > properties.setProperty("hibernate.connection.password","system ");
 > properties.setProperty("hibernate.dialect","org.hibernate.dialect.MySQLInnoDBDialect ");
 >
 >
 > dataStore.setHibernateProperties(properties);
 >
 > dataStore.initialize();
 >
 > EditingDomain domain = new AdapterFactoryEditingDomain(new
 >  ComposedAdapterFactory(ComposedAdapterFactory.Descriptor.Reg istry.INSTANCE),new
 > BasicCommandStack());
 >
 > String uriStr = "hibernate://?" + HibernateResource.DS_NAME_PARAM +
 > "=enumtest";
 > URI uri = URI.createURI(uriStr);
 > Resource dbResource = domain.getResourceSet().getResource(uri, true);
 >
 > TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 > element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 > dbResource.getContents().add(element1);
 >
 > // Commenting the following lines out brings up an Exception when
 > // running the test case twice
 > TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 > element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 > dbResource.getContents().add(element2);
 >
 > dbResource.save(null);
 >
 > reetings,
 > Hans
 >
 > Martin Taal schrieb:
 >> Hi Hans,
 >> I have a testcase which tests this and it works. This exception can
 >> occur when you try to save an object in two different sessions. This
 >> occurs for example if you have references between objects in different
 >> resources. If you save one resource then the refered object in the
 >> other resource is also saved, when you then save the second resource
 >> this error occurs. Also the name of your testcase seems to refer to this.
 >> If this is the case then you can use a SessionController (url probably
 >> truncated by line break):
 >>  http://www.elver.org/hibernate/hibernateresources.html#Shari ng+one+Session+between+Resources%2C+One+transaction+when+sav ing+multiple+resources
 >>
 >>
 >> to share a session between resources.
 >>
 >> gr. Martin
 >>
 
 
 --
 
 With Regards, Martin Taal
 
 Springsite/Elver.org
 Office: Hardwareweg 4, 3821 BV Amersfoort
 Postal: Nassaulaan 7, 3941 EC Doorn
 The Netherlands
 Tel: +31 (0)84 420 2397
 Fax: +31 (0)84 225 9307
 Mail: mtaal@springsite.com - mtaal@elver.org
 Web: www.springsite.com - www.elver.org
 |  |  |  |  | 
| Re: [teneo] Exception when using Enums [message #59009 is a reply to message #58957] | Tue, 24 October 2006 06:27   |  | 
| Eclipse User  |  |  |  |  | Hi Martin, 
 I'll send you the Project soon via mail. When not commenting out these
 lines I can't even run the test case once without an exception.
 
 greeting,
 Hans
 
 
 Martin Taal schrieb:
 > Hi Hans,
 > Can you send me the test project and test case?
 > So if you don't comment out the lines then running twice does not result
 > in an error?
 >
 > gr. Martin
 >
 > Hans Mueller-Dieckert wrote:
 >> Hi Martin,
 >>
 >> I save everything in a single resource. The name of the test case is
 >> just because I changed an old test case when trying to check out if I
 >> can reproduce the Exception with a test case.
 >> The funny thing is, that when I'm commenting out the marked lines down
 >> below and run the test case twice, the second time it fails.
 >>
 >> If you want to, I could provide you the project containing the
 >> testmodel and the test case.
 >>
 >> For now, here is my full testcode:
 >>
 >>
 >> final String dataStoreName = "enumtest";
 >>        final HbDataStore dataStore =
 >> HbHelper.INSTANCE.createRegisterDataStore(dataStoreName);
 >>
 >> EPackage[] packages = new EPackage[] {TestmodelPackage.eINSTANCE};
 >>        dataStore.setEPackages(packages);
 >>        Properties properties = new Properties();
 >>
 >> properties.setProperty("hibernate.connection.driver_class", "com.mysql.jdbc.Driver");
 >>
 >> properties.setProperty("hibernate.connection.url","jdbc:mysql://127.0.0.1:3306/enumtest");
 >>
 >> properties.setProperty("hibernate.connection.username","root ");
 >> properties.setProperty("hibernate.connection.password","system ");
 >> properties.setProperty("hibernate.dialect","org.hibernate.dialect.MySQLInnoDBDialect ");
 >>
 >>
 >> dataStore.setHibernateProperties(properties);
 >>
 >> dataStore.initialize();
 >>        EditingDomain domain = new AdapterFactoryEditingDomain(new
 >>  ComposedAdapterFactory(ComposedAdapterFactory.Descriptor.Reg istry.INSTANCE),new
 >> BasicCommandStack());
 >>
 >> String uriStr = "hibernate://?" + HibernateResource.DS_NAME_PARAM +
 >> "=enumtest";
 >> URI uri = URI.createURI(uriStr);
 >> Resource dbResource = domain.getResourceSet().getResource(uri, true);
 >>     TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 >> element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 >> dbResource.getContents().add(element1);
 >>     // Commenting the following lines out brings up an Exception when
 >> // running the test case twice
 >> TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 >> element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 >> dbResource.getContents().add(element2);
 >>        dbResource.save(null);
 >>
 >> reetings,
 >> Hans
 >>
 >> Martin Taal schrieb:
 >>> Hi Hans,
 >>> I have a testcase which tests this and it works. This exception can
 >>> occur when you try to save an object in two different sessions. This
 >>> occurs for example if you have references between objects in
 >>> different resources. If you save one resource then the refered object
 >>> in the other resource is also saved, when you then save the second
 >>> resource this error occurs. Also the name of your testcase seems to
 >>> refer to this.
 >>> If this is the case then you can use a SessionController (url
 >>> probably truncated by line break):
 >>>  http://www.elver.org/hibernate/hibernateresources.html#Shari ng+one+Session+between+Resources%2C+One+transaction+when+sav ing+multiple+resources
 >>>
 >>>
 >>> to share a session between resources.
 >>>
 >>> gr. Martin
 >>>
 >
 >
 |  |  |  |  | 
| Re: [teneo] Exception when using Enums [message #59309 is a reply to message #59009] | Wed, 25 October 2006 14:55  |  | 
| Eclipse User  |  |  |  |  | Hi Hans, I tested this and with me the error was that the enum property was set to unique, so I got a unique
 constraint violation.
 This was caused by a bug that the unique property of an EAttribute was still being used for enum and
 lob. I have entered a bugzilla for this:
 https://bugs.eclipse.org/bugs/show_bug.cgi?id=162256
 
 I have committed a fix, this will be in the next build (probably friday).
 
 Can you check if setting the unique property of the EnumProperty to false helps? You need to
 regenerate the sources for Teneo to see the new unique value as it reads the runtime model.
 
 gr. Martin
 
 Hans Mueller-Dieckert wrote:
 > Hi Martin,
 >
 > I'll send you the Project soon via mail. When not commenting out these
 > lines I can't even run the test case once without an exception.
 >
 > greeting,
 > Hans
 >
 >
 > Martin Taal schrieb:
 >> Hi Hans,
 >> Can you send me the test project and test case?
 >> So if you don't comment out the lines then running twice does not
 >> result in an error?
 >>
 >> gr. Martin
 >>
 >> Hans Mueller-Dieckert wrote:
 >>> Hi Martin,
 >>>
 >>> I save everything in a single resource. The name of the test case is
 >>> just because I changed an old test case when trying to check out if I
 >>> can reproduce the Exception with a test case.
 >>> The funny thing is, that when I'm commenting out the marked lines
 >>> down below and run the test case twice, the second time it fails.
 >>>
 >>> If you want to, I could provide you the project containing the
 >>> testmodel and the test case.
 >>>
 >>> For now, here is my full testcode:
 >>>
 >>>
 >>> final String dataStoreName = "enumtest";
 >>>        final HbDataStore dataStore =
 >>> HbHelper.INSTANCE.createRegisterDataStore(dataStoreName);
 >>>
 >>> EPackage[] packages = new EPackage[] {TestmodelPackage.eINSTANCE};
 >>>        dataStore.setEPackages(packages);
 >>>        Properties properties = new Properties();
 >>>
 >>> properties.setProperty("hibernate.connection.driver_class", "com.mysql.jdbc.Driver");
 >>>
 >>> properties.setProperty("hibernate.connection.url","jdbc:mysql://127.0.0.1:3306/enumtest");
 >>>
 >>> properties.setProperty("hibernate.connection.username","root ");
 >>> properties.setProperty("hibernate.connection.password","system ");
 >>> properties.setProperty("hibernate.dialect","org.hibernate.dialect.MySQLInnoDBDialect ");
 >>>
 >>>
 >>> dataStore.setHibernateProperties(properties);
 >>>
 >>> dataStore.initialize();
 >>>        EditingDomain domain = new AdapterFactoryEditingDomain(new
 >>>  ComposedAdapterFactory(ComposedAdapterFactory.Descriptor.Reg istry.INSTANCE),new
 >>> BasicCommandStack());
 >>>
 >>> String uriStr = "hibernate://?" + HibernateResource.DS_NAME_PARAM +
 >>> "=enumtest";
 >>> URI uri = URI.createURI(uriStr);
 >>> Resource dbResource = domain.getResourceSet().getResource(uri, true);
 >>>     TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 >>> element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 >>> dbResource.getContents().add(element1);
 >>>     // Commenting the following lines out brings up an Exception when
 >>> // running the test case twice
 >>> TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 >>> element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 >>> dbResource.getContents().add(element2);
 >>>        dbResource.save(null);
 >>>
 >>> reetings,
 >>> Hans
 >>>
 >>> Martin Taal schrieb:
 >>>> Hi Hans,
 >>>> I have a testcase which tests this and it works. This exception can
 >>>> occur when you try to save an object in two different sessions. This
 >>>> occurs for example if you have references between objects in
 >>>> different resources. If you save one resource then the refered
 >>>> object in the other resource is also saved, when you then save the
 >>>> second resource this error occurs. Also the name of your testcase
 >>>> seems to refer to this.
 >>>> If this is the case then you can use a SessionController (url
 >>>> probably truncated by line break):
 >>>>  http://www.elver.org/hibernate/hibernateresources.html#Shari ng+one+Session+between+Resources%2C+One+transaction+when+sav ing+multiple+resources
 >>>>
 >>>>
 >>>> to share a session between resources.
 >>>>
 >>>> gr. Martin
 >>>>
 >>
 >>
 
 
 --
 
 With Regards, Martin Taal
 
 Springsite/Elver.org
 Office: Hardwareweg 4, 3821 BV Amersfoort
 Postal: Nassaulaan 7, 3941 EC Doorn
 The Netherlands
 Tel: +31 (0)84 420 2397
 Fax: +31 (0)84 225 9307
 Mail: mtaal@springsite.com - mtaal@elver.org
 Web: www.springsite.com - www.elver.org
 |  |  |  |  | 
| Re: [teneo] Exception when using Enums [message #594654 is a reply to message #58730] | Tue, 24 October 2006 01:48  |  | 
| Eclipse User  |  |  |  |  | Hi Hans, I have a testcase which tests this and it works. This exception can occur when you try to save an
 object in two different sessions. This occurs for example if you have references between objects in
 different resources. If you save one resource then the refered object in the other resource is also
 saved, when you then save the second resource this error occurs. Also the name of your testcase
 seems to refer to this.
 If this is the case then you can use a SessionController (url probably truncated by line break):
 http://www.elver.org/hibernate/hibernateresources.html#Shari ng+one+Session+between+Resources%2C+One+transaction+when+sav ing+multiple+resources
 
 to share a session between resources.
 
 gr. Martin
 
 Hans Mueller-Dieckert wrote:
 > Hi Martin and everybody else reading this !
 >
 > I have an enum MyEnum in my model and a class which has an attribute
 > with the type MyEnum. When I have a single object, set the attribute and
 > save everything in a HibernateResource, everything works fine.
 >
 > But having two objects, where the attribute for both objects is set to
 > the same enmu-literal, I get an Exception.
 >
 > This is the code which does not work:
 >
 > Resource dbResource = domain.getResourceSet().getResource(uri, true);
 >
 >
 > TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 > element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 > dbResource.getContents().add(element1);
 >
 > TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 > element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 > dbResource.getContents().add(element2);
 >
 > dbResource.save(null);
 >
 >
 > I'll also attach a little screenshot describing the model and the
 > exception stack trace.
 >
 > greetings,
 > Hans
 >
 >
 >  ------------------------------------------------------------ ------------
 >
 > org.eclipse.emf.teneo.hibernate.HbStoreException: Exception when saving resource test
 > 	at  org.eclipse.emf.teneo.hibernate.resource.HibernateResource.s aveResource(HibernateResource.java:214)
 > 	at  org.eclipse.emf.teneo.resource.StoreResource.save(StoreResou rce.java:271)
 > 	at  de.arcsolutions.remarc.platform.emftest.TwoResourcesLinkTest Case.testTwoResources(TwoResourcesLinkTestCase.java:77)
 > 	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 > 	at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
 > 	at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
 > 	at java.lang.reflect.Method.invoke(Unknown Source)
 > 	at junit.framework.TestCase.runTest(TestCase.java:154)
 > 	at junit.framework.TestCase.runBare(TestCase.java:127)
 > 	at junit.framework.TestResult$1.protect(TestResult.java:106)
 > 	at  junit.framework.TestResult.runProtected(TestResult.java:124)
 > 	at junit.framework.TestResult.run(TestResult.java:109)
 > 	at junit.framework.TestCase.run(TestCase.java:118)
 > 	at junit.framework.TestSuite.runTest(TestSuite.java:208)
 > 	at junit.framework.TestSuite.run(TestSuite.java:203)
 > 	at  org.eclipse.jdt.internal.junit.runner.junit3.JUnit3TestRefer ence.run(JUnit3TestReference.java:128)
 > 	at  org.eclipse.jdt.internal.junit.runner.TestExecution.run(Test Execution.java:38)
 > 	at  org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTe sts(RemoteTestRunner.java:460)
 > 	at  org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTe sts(RemoteTestRunner.java:673)
 > 	at  org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(R emoteTestRunner.java:386)
 > 	at  org.eclipse.pde.internal.junit.runtime.RemotePluginTestRunne r.main(RemotePluginTestRunner.java:58)
 > 	at  org.eclipse.pde.internal.junit.runtime.CoreTestApplication.r un(CoreTestApplication.java:24)
 > 	at  org.eclipse.core.internal.runtime.PlatformActivator$1.run(Pl atformActivator.java:78)
 > 	at  org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher .runApplication(EclipseAppLauncher.java:92)
 > 	at  org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher .start(EclipseAppLauncher.java:68)
 > 	at  org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseS tarter.java:400)
 > 	at  org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseS tarter.java:177)
 > 	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 > 	at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
 > 	at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
 > 	at java.lang.reflect.Method.invoke(Unknown Source)
 > 	at  org.eclipse.core.launcher.Main.invokeFramework(Main.java:336 )
 > 	at org.eclipse.core.launcher.Main.basicRun(Main.java:280)
 > 	at org.eclipse.core.launcher.Main.run(Main.java:977)
 > 	at org.eclipse.core.launcher.Main.main(Main.java:952)
 > Caused by: org.hibernate.HibernateException: Illegal attempt to associate a collection with two open sessions
 > 	at  org.hibernate.collection.AbstractPersistentCollection.setCur rentSession(AbstractPersistentCollection.java:410)
 > 	at  org.hibernate.event.def.OnUpdateVisitor.processCollection(On UpdateVisitor.java:40)
 > 	at  org.hibernate.event.def.AbstractVisitor.processValue(Abstrac tVisitor.java:101)
 > 	at  org.hibernate.event.def.AbstractVisitor.processValue(Abstrac tVisitor.java:61)
 > 	at  org.hibernate.event.def.AbstractVisitor.processEntityPropert yValues(AbstractVisitor.java:55)
 > 	at  org.hibernate.event.def.AbstractVisitor.process(AbstractVisi tor.java:123)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formUpdate(DefaultSaveOrUpdateEventListener.java:267)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.ent ityIsDetached(DefaultSaveOrUpdateEventListener.java:216)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:93)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.onS aveOrUpdate(DefaultSaveOrUpdateEventListener.java:70)
 > 	at  org.hibernate.impl.SessionImpl.fireSaveOrUpdate(SessionImpl. java:502)
 > 	at  org.hibernate.impl.SessionImpl.saveOrUpdate(SessionImpl.java :494)
 > 	at  org.hibernate.engine.CascadingAction$1.cascade(CascadingActi on.java:134)
 > 	at org.hibernate.engine.Cascade.cascadeToOne(Cascade.java:213)
 > 	at  org.hibernate.engine.Cascade.cascadeAssociation(Cascade.java :157)
 > 	at  org.hibernate.engine.Cascade.cascadeProperty(Cascade.java:10 8)
 > 	at org.hibernate.engine.Cascade.cascade(Cascade.java:248)
 > 	at org.hibernate.engine.Cascade.cascade(Cascade.java:223)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.cas cadeOnUpdate(DefaultSaveOrUpdateEventListener.java:331)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formUpdate(DefaultSaveOrUpdateEventListener.java:303)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.ent ityIsDetached(DefaultSaveOrUpdateEventListener.java:216)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.per formSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:93)
 > 	at  org.hibernate.event.def.DefaultSaveOrUpdateEventListener.onS aveOrUpdate(DefaultSaveOrUpdateEventListener.java:70)
 > 	at  org.hibernate.impl.SessionImpl.fireSaveOrUpdate(SessionImpl. java:502)
 > 	at  org.hibernate.impl.SessionImpl.saveOrUpdate(SessionImpl.java :494)
 > 	at  org.hibernate.engine.CascadingAction$1.cascade(CascadingActi on.java:134)
 > 	at org.hibernate.engine.Cascade.cascadeToOne(Cascade.java:213)
 > 	at  org.hibernate.engine.Cascade.cascadeAssociation(Cascade.java :157)
 > 	at  org.hibernate.engine.Cascade.cascadeProperty(Cascade.java:10 8)
 > 	at org.hibernate.engine.Cascade.cascade(Cascade.java:248)
 > 	at  org.hibernate.event.def.AbstractFlushingEventListener.cascad eOnFlush(AbstractFlushingEventListener.java:130)
 > 	at  org.hibernate.event.def.AbstractFlushingEventListener.prepar eEntityFlushes(AbstractFlushingEventListener.java:121)
 > 	at  org.hibernate.event.def.AbstractFlushingEventListener.flushE verythingToExecutions(AbstractFlushingEventListener.java:65)
 > 	at  org.hibernate.event.def.DefaultFlushEventListener.onFlush(De faultFlushEventListener.java:26)
 > 	at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:985)
 > 	at  org.eclipse.emf.teneo.hibernate.resource.HibernateResource.s aveResource(HibernateResource.java:210)
 > 	... 34 more
 >
 >
 >
 >  ------------------------------------------------------------ ------------
 >
 
 
 --
 
 With Regards, Martin Taal
 
 Springsite/Elver.org
 Office: Hardwareweg 4, 3821 BV Amersfoort
 Postal: Nassaulaan 7, 3941 EC Doorn
 The Netherlands
 Tel: +31 (0)84 420 2397
 Fax: +31 (0)84 225 9307
 Mail: mtaal@springsite.com - mtaal@elver.org
 Web: www.springsite.com - www.elver.org
 |  |  |  |  | 
| Re: [teneo] Exception when using Enums [message #594679 is a reply to message #58830] | Tue, 24 October 2006 03:40  |  | 
| Eclipse User  |  |  |  |  | Hi Martin, 
 I save everything in a single resource. The name of the test case is
 just because I changed an old test case when trying to check out if I
 can reproduce the Exception with a test case.
 The funny thing is, that when I'm commenting out the marked lines down
 below and run the test case twice, the second time it fails.
 
 If you want to, I could provide you the project containing the testmodel
 and the test case.
 
 For now, here is my full testcode:
 
 
 final String dataStoreName = "enumtest";
 
 final HbDataStore dataStore =
 HbHelper.INSTANCE.createRegisterDataStore(dataStoreName);
 
 EPackage[] packages = new EPackage[] {TestmodelPackage.eINSTANCE};
 
 dataStore.setEPackages(packages);
 
 Properties properties = new Properties();
 
 properties.setProperty("hibernate.connection.driver_class", "com.mysql.jdbc.Driver");
 properties.setProperty("hibernate.connection.url","jdbc:mysql://127.0.0.1:3306/enumtest");
 properties.setProperty("hibernate.connection.username","root ");
 properties.setProperty("hibernate.connection.password","system ");
 properties.setProperty("hibernate.dialect","org.hibernate.dialect.MySQLInnoDBDialect ");
 
 dataStore.setHibernateProperties(properties);
 
 dataStore.initialize();
 
 EditingDomain domain = new AdapterFactoryEditingDomain(new
 ComposedAdapterFactory(ComposedAdapterFactory.Descriptor.Reg istry.INSTANCE),new
 BasicCommandStack());
 
 String uriStr = "hibernate://?" + HibernateResource.DS_NAME_PARAM +
 "=enumtest";
 URI uri = URI.createURI(uriStr);
 Resource dbResource = domain.getResourceSet().getResource(uri, true);
 
 TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 dbResource.getContents().add(element1);
 
 // Commenting the following lines out brings up an Exception when
 // running the test case twice
 TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 dbResource.getContents().add(element2);
 
 dbResource.save(null);
 
 reetings,
 Hans
 
 Martin Taal schrieb:
 > Hi Hans,
 > I have a testcase which tests this and it works. This exception can
 > occur when you try to save an object in two different sessions. This
 > occurs for example if you have references between objects in different
 > resources. If you save one resource then the refered object in the other
 > resource is also saved, when you then save the second resource this
 > error occurs. Also the name of your testcase seems to refer to this.
 > If this is the case then you can use a SessionController (url probably
 > truncated by line break):
 >  http://www.elver.org/hibernate/hibernateresources.html#Shari ng+one+Session+between+Resources%2C+One+transaction+when+sav ing+multiple+resources
 >
 >
 > to share a session between resources.
 >
 > gr. Martin
 >
 |  |  |  |  | 
| Re: [teneo] Exception when using Enums [message #594695 is a reply to message #58906] | Tue, 24 October 2006 05:41  |  | 
| Eclipse User  |  |  |  |  | Hi Hans, Can you send me the test project and test case?
 So if you don't comment out the lines then running twice does not result in an error?
 
 gr. Martin
 
 Hans Mueller-Dieckert wrote:
 > Hi Martin,
 >
 > I save everything in a single resource. The name of the test case is
 > just because I changed an old test case when trying to check out if I
 > can reproduce the Exception with a test case.
 > The funny thing is, that when I'm commenting out the marked lines down
 > below and run the test case twice, the second time it fails.
 >
 > If you want to, I could provide you the project containing the testmodel
 > and the test case.
 >
 > For now, here is my full testcode:
 >
 >
 > final String dataStoreName = "enumtest";
 >
 > final HbDataStore dataStore =
 > HbHelper.INSTANCE.createRegisterDataStore(dataStoreName);
 >
 > EPackage[] packages = new EPackage[] {TestmodelPackage.eINSTANCE};
 >
 > dataStore.setEPackages(packages);
 >
 > Properties properties = new Properties();
 >
 > properties.setProperty("hibernate.connection.driver_class", "com.mysql.jdbc.Driver");
 >
 > properties.setProperty("hibernate.connection.url","jdbc:mysql://127.0.0.1:3306/enumtest");
 >
 > properties.setProperty("hibernate.connection.username","root ");
 > properties.setProperty("hibernate.connection.password","system ");
 > properties.setProperty("hibernate.dialect","org.hibernate.dialect.MySQLInnoDBDialect ");
 >
 >
 > dataStore.setHibernateProperties(properties);
 >
 > dataStore.initialize();
 >
 > EditingDomain domain = new AdapterFactoryEditingDomain(new
 >  ComposedAdapterFactory(ComposedAdapterFactory.Descriptor.Reg istry.INSTANCE),new
 > BasicCommandStack());
 >
 > String uriStr = "hibernate://?" + HibernateResource.DS_NAME_PARAM +
 > "=enumtest";
 > URI uri = URI.createURI(uriStr);
 > Resource dbResource = domain.getResourceSet().getResource(uri, true);
 >
 > TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 > element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 > dbResource.getContents().add(element1);
 >
 > // Commenting the following lines out brings up an Exception when
 > // running the test case twice
 > TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 > element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 > dbResource.getContents().add(element2);
 >
 > dbResource.save(null);
 >
 > reetings,
 > Hans
 >
 > Martin Taal schrieb:
 >> Hi Hans,
 >> I have a testcase which tests this and it works. This exception can
 >> occur when you try to save an object in two different sessions. This
 >> occurs for example if you have references between objects in different
 >> resources. If you save one resource then the refered object in the
 >> other resource is also saved, when you then save the second resource
 >> this error occurs. Also the name of your testcase seems to refer to this.
 >> If this is the case then you can use a SessionController (url probably
 >> truncated by line break):
 >>  http://www.elver.org/hibernate/hibernateresources.html#Shari ng+one+Session+between+Resources%2C+One+transaction+when+sav ing+multiple+resources
 >>
 >>
 >> to share a session between resources.
 >>
 >> gr. Martin
 >>
 
 
 --
 
 With Regards, Martin Taal
 
 Springsite/Elver.org
 Office: Hardwareweg 4, 3821 BV Amersfoort
 Postal: Nassaulaan 7, 3941 EC Doorn
 The Netherlands
 Tel: +31 (0)84 420 2397
 Fax: +31 (0)84 225 9307
 Mail: mtaal@springsite.com - mtaal@elver.org
 Web: www.springsite.com - www.elver.org
 |  |  |  |  | 
| Re: [teneo] Exception when using Enums [message #594709 is a reply to message #58957] | Tue, 24 October 2006 06:27  |  | 
| Eclipse User  |  |  |  |  | Hi Martin, 
 I'll send you the Project soon via mail. When not commenting out these
 lines I can't even run the test case once without an exception.
 
 greeting,
 Hans
 
 
 Martin Taal schrieb:
 > Hi Hans,
 > Can you send me the test project and test case?
 > So if you don't comment out the lines then running twice does not result
 > in an error?
 >
 > gr. Martin
 >
 > Hans Mueller-Dieckert wrote:
 >> Hi Martin,
 >>
 >> I save everything in a single resource. The name of the test case is
 >> just because I changed an old test case when trying to check out if I
 >> can reproduce the Exception with a test case.
 >> The funny thing is, that when I'm commenting out the marked lines down
 >> below and run the test case twice, the second time it fails.
 >>
 >> If you want to, I could provide you the project containing the
 >> testmodel and the test case.
 >>
 >> For now, here is my full testcode:
 >>
 >>
 >> final String dataStoreName = "enumtest";
 >>        final HbDataStore dataStore =
 >> HbHelper.INSTANCE.createRegisterDataStore(dataStoreName);
 >>
 >> EPackage[] packages = new EPackage[] {TestmodelPackage.eINSTANCE};
 >>        dataStore.setEPackages(packages);
 >>        Properties properties = new Properties();
 >>
 >> properties.setProperty("hibernate.connection.driver_class", "com.mysql.jdbc.Driver");
 >>
 >> properties.setProperty("hibernate.connection.url","jdbc:mysql://127.0.0.1:3306/enumtest");
 >>
 >> properties.setProperty("hibernate.connection.username","root ");
 >> properties.setProperty("hibernate.connection.password","system ");
 >> properties.setProperty("hibernate.dialect","org.hibernate.dialect.MySQLInnoDBDialect ");
 >>
 >>
 >> dataStore.setHibernateProperties(properties);
 >>
 >> dataStore.initialize();
 >>        EditingDomain domain = new AdapterFactoryEditingDomain(new
 >>  ComposedAdapterFactory(ComposedAdapterFactory.Descriptor.Reg istry.INSTANCE),new
 >> BasicCommandStack());
 >>
 >> String uriStr = "hibernate://?" + HibernateResource.DS_NAME_PARAM +
 >> "=enumtest";
 >> URI uri = URI.createURI(uriStr);
 >> Resource dbResource = domain.getResourceSet().getResource(uri, true);
 >>     TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 >> element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 >> dbResource.getContents().add(element1);
 >>     // Commenting the following lines out brings up an Exception when
 >> // running the test case twice
 >> TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 >> element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 >> dbResource.getContents().add(element2);
 >>        dbResource.save(null);
 >>
 >> reetings,
 >> Hans
 >>
 >> Martin Taal schrieb:
 >>> Hi Hans,
 >>> I have a testcase which tests this and it works. This exception can
 >>> occur when you try to save an object in two different sessions. This
 >>> occurs for example if you have references between objects in
 >>> different resources. If you save one resource then the refered object
 >>> in the other resource is also saved, when you then save the second
 >>> resource this error occurs. Also the name of your testcase seems to
 >>> refer to this.
 >>> If this is the case then you can use a SessionController (url
 >>> probably truncated by line break):
 >>>  http://www.elver.org/hibernate/hibernateresources.html#Shari ng+one+Session+between+Resources%2C+One+transaction+when+sav ing+multiple+resources
 >>>
 >>>
 >>> to share a session between resources.
 >>>
 >>> gr. Martin
 >>>
 >
 >
 |  |  |  |  | 
| Re: [teneo] Exception when using Enums [message #594831 is a reply to message #59009] | Wed, 25 October 2006 14:55  |  | 
| Eclipse User  |  |  |  |  | Hi Hans, I tested this and with me the error was that the enum property was set to unique, so I got a unique
 constraint violation.
 This was caused by a bug that the unique property of an EAttribute was still being used for enum and
 lob. I have entered a bugzilla for this:
 https://bugs.eclipse.org/bugs/show_bug.cgi?id=162256
 
 I have committed a fix, this will be in the next build (probably friday).
 
 Can you check if setting the unique property of the EnumProperty to false helps? You need to
 regenerate the sources for Teneo to see the new unique value as it reads the runtime model.
 
 gr. Martin
 
 Hans Mueller-Dieckert wrote:
 > Hi Martin,
 >
 > I'll send you the Project soon via mail. When not commenting out these
 > lines I can't even run the test case once without an exception.
 >
 > greeting,
 > Hans
 >
 >
 > Martin Taal schrieb:
 >> Hi Hans,
 >> Can you send me the test project and test case?
 >> So if you don't comment out the lines then running twice does not
 >> result in an error?
 >>
 >> gr. Martin
 >>
 >> Hans Mueller-Dieckert wrote:
 >>> Hi Martin,
 >>>
 >>> I save everything in a single resource. The name of the test case is
 >>> just because I changed an old test case when trying to check out if I
 >>> can reproduce the Exception with a test case.
 >>> The funny thing is, that when I'm commenting out the marked lines
 >>> down below and run the test case twice, the second time it fails.
 >>>
 >>> If you want to, I could provide you the project containing the
 >>> testmodel and the test case.
 >>>
 >>> For now, here is my full testcode:
 >>>
 >>>
 >>> final String dataStoreName = "enumtest";
 >>>        final HbDataStore dataStore =
 >>> HbHelper.INSTANCE.createRegisterDataStore(dataStoreName);
 >>>
 >>> EPackage[] packages = new EPackage[] {TestmodelPackage.eINSTANCE};
 >>>        dataStore.setEPackages(packages);
 >>>        Properties properties = new Properties();
 >>>
 >>> properties.setProperty("hibernate.connection.driver_class", "com.mysql.jdbc.Driver");
 >>>
 >>> properties.setProperty("hibernate.connection.url","jdbc:mysql://127.0.0.1:3306/enumtest");
 >>>
 >>> properties.setProperty("hibernate.connection.username","root ");
 >>> properties.setProperty("hibernate.connection.password","system ");
 >>> properties.setProperty("hibernate.dialect","org.hibernate.dialect.MySQLInnoDBDialect ");
 >>>
 >>>
 >>> dataStore.setHibernateProperties(properties);
 >>>
 >>> dataStore.initialize();
 >>>        EditingDomain domain = new AdapterFactoryEditingDomain(new
 >>>  ComposedAdapterFactory(ComposedAdapterFactory.Descriptor.Reg istry.INSTANCE),new
 >>> BasicCommandStack());
 >>>
 >>> String uriStr = "hibernate://?" + HibernateResource.DS_NAME_PARAM +
 >>> "=enumtest";
 >>> URI uri = URI.createURI(uriStr);
 >>> Resource dbResource = domain.getResourceSet().getResource(uri, true);
 >>>     TestClass element1 = TestmodelFactory.eINSTANCE.createTestClass();
 >>> element1.setEnumProperty(TestEnum.ITEM1_LITERAL);
 >>> dbResource.getContents().add(element1);
 >>>     // Commenting the following lines out brings up an Exception when
 >>> // running the test case twice
 >>> TestClass element2 = TestmodelFactory.eINSTANCE.createTestClass();
 >>> element2.setEnumProperty(TestEnum.ITEM1_LITERAL);
 >>> dbResource.getContents().add(element2);
 >>>        dbResource.save(null);
 >>>
 >>> reetings,
 >>> Hans
 >>>
 >>> Martin Taal schrieb:
 >>>> Hi Hans,
 >>>> I have a testcase which tests this and it works. This exception can
 >>>> occur when you try to save an object in two different sessions. This
 >>>> occurs for example if you have references between objects in
 >>>> different resources. If you save one resource then the refered
 >>>> object in the other resource is also saved, when you then save the
 >>>> second resource this error occurs. Also the name of your testcase
 >>>> seems to refer to this.
 >>>> If this is the case then you can use a SessionController (url
 >>>> probably truncated by line break):
 >>>>  http://www.elver.org/hibernate/hibernateresources.html#Shari ng+one+Session+between+Resources%2C+One+transaction+when+sav ing+multiple+resources
 >>>>
 >>>>
 >>>> to share a session between resources.
 >>>>
 >>>> gr. Martin
 >>>>
 >>
 >>
 
 
 --
 
 With Regards, Martin Taal
 
 Springsite/Elver.org
 Office: Hardwareweg 4, 3821 BV Amersfoort
 Postal: Nassaulaan 7, 3941 EC Doorn
 The Netherlands
 Tel: +31 (0)84 420 2397
 Fax: +31 (0)84 225 9307
 Mail: mtaal@springsite.com - mtaal@elver.org
 Web: www.springsite.com - www.elver.org
 |  |  |  | 
 
 
 Current Time: Sat Oct 25 08:26:41 EDT 2025 
 Powered by FUDForum . Page generated in 0.06242 seconds |