Доброго дня!
При импорте отчетов в проект без аддона миграции io.jmix.cuba, созданных в проекте с подключенным аддоном миграции, возникает ошибка:
DateTimeParseException: Text '2025-10-24 11:28:38.955' could not be parsed at index 10.
стэктрейс
2025-10-24 11:30:50.839 ERROR 22064 --- [nio-8080-exec-6] i.j.u.exception.DefaultExceptionHandler : Unhandled exception
com.vaadin.server.ServerRpcManager$RpcInvocationException: Unable to invoke method click in com.vaadin.shared.ui.button.ButtonServerRpc
at com.vaadin.server.ServerRpcManager.applyInvocation(ServerRpcManager.java:157) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
at com.vaadin.server.ServerRpcManager.applyInvocation(ServerRpcManager.java:115) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
at com.vaadin.server.communication.ServerRpcHandler.handleInvocation(ServerRpcHandler.java:442) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
at com.vaadin.server.communication.ServerRpcHandler.handleInvocations(ServerRpcHandler.java:407) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
at com.vaadin.server.communication.ServerRpcHandler.handleRpc(ServerRpcHandler.java:275) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
at com.vaadin.server.communication.UidlRequestHandler.synchronizedHandleRequest(UidlRequestHandler.java:83) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
at com.vaadin.server.SynchronizedRequestHandler.handleRequest(SynchronizedRequestHandler.java:40) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
at com.vaadin.server.VaadinService.handleRequest(VaadinService.java:1636) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
at com.vaadin.server.VaadinServlet.service(VaadinServlet.java:465) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
at javax.servlet.http.HttpServlet.service(HttpServlet.java:750) ~[javax.servlet-api-4.0.1.jar:4.0.1]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:199) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:144) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) ~[tomcat-embed-websocket-9.0.102.jar:9.0.102]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:168) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:144) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at io.jmix.core.impl.logging.LogMdcFilter.doFilterInternal(LogMdcFilter.java:28) ~[jmix-core-1.7.1.jar:na]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) ~[spring-web-5.3.39.jar:5.3.39]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:168) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:144) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:337) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:115) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:81) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:122) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:116) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:126) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:81) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:109) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.authentication.rememberme.RememberMeAuthenticationFilter.doFilter(RememberMeAuthenticationFilter.java:106) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.authentication.rememberme.RememberMeAuthenticationFilter.doFilter(RememberMeAuthenticationFilter.java:97) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:149) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.session.ConcurrentSessionFilter.doFilter(ConcurrentSessionFilter.java:147) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.session.ConcurrentSessionFilter.doFilter(ConcurrentSessionFilter.java:125) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:103) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:89) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.header.HeaderWriterFilter.doHeadersAfter(HeaderWriterFilter.java:90) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:75) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) ~[spring-web-5.3.39.jar:5.3.39]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:112) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:82) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:55) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) ~[spring-web-5.3.39.jar:5.3.39]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.session.DisableEncodeUrlFilter.doFilterInternal(DisableEncodeUrlFilter.java:42) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) ~[spring-web-5.3.39.jar:5.3.39]
at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:346) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:221) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:186) ~[spring-security-web-5.7.11.jar:5.7.11]
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:354) ~[spring-web-5.3.39.jar:5.3.39]
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:267) ~[spring-web-5.3.39.jar:5.3.39]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:168) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:144) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) ~[spring-web-5.3.39.jar:5.3.39]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) ~[spring-web-5.3.39.jar:5.3.39]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:168) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:144) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) ~[spring-web-5.3.39.jar:5.3.39]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) ~[spring-web-5.3.39.jar:5.3.39]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:168) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:144) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.springframework.boot.actuate.metrics.web.servlet.WebMvcMetricsFilter.doFilterInternal(WebMvcMetricsFilter.java:96) ~[spring-boot-actuator-2.7.18.jar:2.7.18]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) ~[spring-web-5.3.39.jar:5.3.39]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:168) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:144) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) ~[spring-web-5.3.39.jar:5.3.39]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:117) ~[spring-web-5.3.39.jar:5.3.39]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:168) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:144) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:168) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:90) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:482) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:130) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:93) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:346) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:396) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:63) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:937) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1793) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:52) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1190) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:63) ~[tomcat-embed-core-9.0.102.jar:9.0.102]
at java.base/java.lang.Thread.run(Thread.java:829) ~[na:na]
Caused by: java.lang.reflect.InvocationTargetException: null
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:na]
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:na]
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:na]
at java.base/java.lang.reflect.Method.invoke(Method.java:566) ~[na:na]
at com.vaadin.server.ServerRpcManager.applyInvocation(ServerRpcManager.java:153) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
... 94 common frames omitted
Caused by: java.time.format.DateTimeParseException: Text '2025-10-24 11:28:38.955' could not be parsed at index 10
at java.base/java.time.format.DateTimeFormatter.parseResolved0(DateTimeFormatter.java:2046) ~[na:na]
at java.base/java.time.format.DateTimeFormatter.parse(DateTimeFormatter.java:1948) ~[na:na]
at io.jmix.core.metamodel.datatype.impl.DateTimeDatatype.parse(DateTimeDatatype.java:92) ~[jmix-core-1.7.1.jar:na]
at io.jmix.core.metamodel.datatype.impl.DateTimeDatatype.parse(DateTimeDatatype.java:39) ~[jmix-core-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.readSimpleProperty(GsonSerializationSupport.java:193) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.readFields(GsonSerializationSupport.java:155) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.readEntity(GsonSerializationSupport.java:141) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.readFields(GsonSerializationSupport.java:159) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.readEntity(GsonSerializationSupport.java:141) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport$2.read(GsonSerializationSupport.java:77) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport$2.read(GsonSerializationSupport.java:69) ~[jmix-reports-1.7.1.jar:na]
at com.google.gson.internal.bind.TypeAdapters$34$1.read(TypeAdapters.java:979) ~[gson-2.9.1.jar:na]
at com.google.gson.Gson.fromJson(Gson.java:1058) ~[gson-2.9.1.jar:na]
at com.google.gson.Gson.fromJson(Gson.java:1016) ~[gson-2.9.1.jar:na]
at com.google.gson.Gson.fromJson(Gson.java:959) ~[gson-2.9.1.jar:na]
at com.google.gson.Gson.fromJson(Gson.java:927) ~[gson-2.9.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.convertToReport(GsonSerializationSupport.java:313) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonConverter.convertToReport(GsonConverter.java:38) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.ReportsSerialization.convertToReport(ReportsSerialization.java:53) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.impl.ReportImportExportImpl.fromByteArray(ReportImportExportImpl.java:275) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.impl.ReportImportExportImpl.importReport(ReportImportExportImpl.java:233) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.impl.ReportImportExportImpl.importReportsWithResult(ReportImportExportImpl.java:141) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reportsui.screen.report.importdialog.ReportImportDialog.importReport(ReportImportDialog.java:125) ~[jmix-reports-ui-1.7.1.jar:na]
at io.jmix.reportsui.screen.report.importdialog.ReportImportDialog.onCommitBtnClick(ReportImportDialog.java:85) ~[jmix-reports-ui-1.7.1.jar:na]
at io.jmix.core.common.event.EventHub.publish(EventHub.java:170) ~[jmix-core-1.7.1.jar:na]
at io.jmix.ui.component.impl.AbstractComponent.publish(AbstractComponent.java:85) ~[jmix-ui-1.7.1.jar:na]
at io.jmix.ui.component.impl.ButtonImpl.buttonClicked(ButtonImpl.java:78) ~[jmix-ui-1.7.1.jar:na]
at io.jmix.ui.widget.JmixButton.fireClick(JmixButton.java:77) ~[jmix-ui-1.7.1.jar:na]
at com.vaadin.ui.Button$1.click(Button.java:57) ~[vaadin-server-8.14.4-1-jmix.jar:8.14.4-1-jmix]
... 99 common frames omitted
Ошибка возникает из-за того, что в атрибуте сущности io.jmix.reports.entity.Report _xml, который хранит JSON-объект, даты для атрибутов create_ts и update_ts записаны в виде "createTs":"2025-10-24 11:28:38.955","updateTs":"2025-10-24 11:28:38.955" вместо ожидаемого "createTs":"2025-10-24T11:28:38.955","updateTs":"2025-10-24T11:28:38.955" т.е. с T вместо пробела между датой и временем (символ под 10ым индексом).
полное значение атрибута _xml
{"metaClass":"report_Report","id":"673e47ce-16db-59bb-77c1-4fafea2d1c93","defaultTemplate":{"metaClass":"report_ReportTemplate","id":"386ba46f-80ab-7b38-c571-2c4b56b355de","code":"DEFAULT","customDefinedBy":"100","custom":"false","version":"1","outputNamePattern":"1","reportOutputType":"40","groovy":"false","createdBy":"admin","customDefinition":"","report":{"metaClass":"report_Report","id":"673e47ce-16db-59bb-77c1-4fafea2d1c93"},"name":"1.docx","createTs":"2025-10-24 11:28:38.955","updateTs":"2025-10-24 11:28:38.955","alterable":"false"},"bands":[{"metaClass":"report_BandDefinition","id":"fe177119-d8a5-a4a6-3432-9438b1439a51","orientation":"","childrenBandDefinitions":[],"name":"Root","report":{"metaClass":"report_Report","id":"673e47ce-16db-59bb-77c1-4fafea2d1c93"},"dataSets":[],"position":"0"}],"inputParameters":[],"validationOn":"false","reportType":"10","reportScreens":[],"createTs":"2025-10-24 11:28:38.956","updatedBy":"admin","valuesFormats":[],"templates":[{"metaClass":"report_ReportTemplate","id":"386ba46f-80ab-7b38-c571-2c4b56b355de"}],"version":"4","system":"false","createdBy":"admin","name":"test","updateTs":"2025-10-24 11:28:40.517","reportRoles":[]}
Отчеты созданные в приложении без аддона миграции содержат значения даты в форматном виде.
значения атрибута _xml отчета, созданного без АМ
{"metaClass":"report_Report","id":"06e1050d-015e-bfe0-0c11-1bb12194b2c1","defaultTemplate":{"metaClass":"report_ReportTemplate","id":"b4131ebd-3e22-7a1e-6dc1-1d4e5c822b2c","code":"DEFAULT","customDefinedBy":"100","custom":"false","version":"1","outputNamePattern":"1","reportOutputType":"40","groovy":"false","createdBy":"admin","customDefinition":"","report":{"metaClass":"report_Report","id":"06e1050d-015e-bfe0-0c11-1bb12194b2c1"},"name":"1.docx","createTs":"2025-10-23T16:18:08.055","updateTs":"2025-10-23T16:18:08.055","alterable":"false"},"bands":[{"metaClass":"report_BandDefinition","id":"a7e88ef9-d80f-f6b8-bb37-57ac49d7157c","orientation":"","childrenBandDefinitions":[],"name":"Root","report":{"metaClass":"report_Report","id":"06e1050d-015e-bfe0-0c11-1bb12194b2c1"},"dataSets":[],"position":"0"}],"inputParameters":[],"validationOn":"false","reportType":"10","reportScreens":[],"createTs":"2025-10-23T16:18:08.055","updatedBy":"admin","valuesFormats":[],"templates":[{"metaClass":"report_ReportTemplate","id":"b4131ebd-3e22-7a1e-6dc1-1d4e5c822b2c"}],"version":"2","system":"false","createdBy":"admin","name":"123","updateTs":"2025-10-23T16:18:08.081","reportRoles":[]}
Ошибка возникает при импорте отчетов, а также при открытии окна редактирование Отчетов, на боевой БД. Если поправить руками значения дат в БД, заменив пробел на T, то ошибок не возникает.
Как WA попытались добавить логику в код, которая с помощью регулярки отформатирует значение строкового атрибута, но ловим эту же ошибку при попытке загрузить сущность Отчета с помощью dataManager.
List<Report> reports = dataManager.load(Report.class)
.all()
.list();
скрин участка когда, где возникает ошибка

стэктрейс
2025-10-24 12:19:12.019 INFO 11208 --- [ main] r.cs_consult.simpledoc.app.FirstRunInit : Fixing reports forms started
2025-10-24 12:19:12.103 INFO 11208 --- [ main] ConditionEvaluationReportLoggingListener :
Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled.
2025-10-24 12:19:12.129 ERROR 11208 --- [ main] o.s.boot.SpringApplication : Application run failed
java.time.format.DateTimeParseException: Text '2024-05-16 16:29:07.066' could not be parsed at index 10
at java.base/java.time.format.DateTimeFormatter.parseResolved0(DateTimeFormatter.java:2046) ~[na:na]
at java.base/java.time.format.DateTimeFormatter.parse(DateTimeFormatter.java:1948) ~[na:na]
at io.jmix.core.metamodel.datatype.impl.DateTimeDatatype.parse(DateTimeDatatype.java:92) ~[jmix-core-1.7.1.jar:na]
at io.jmix.core.metamodel.datatype.impl.DateTimeDatatype.parse(DateTimeDatatype.java:39) ~[jmix-core-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.readSimpleProperty(GsonSerializationSupport.java:193) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.readFields(GsonSerializationSupport.java:155) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.readEntity(GsonSerializationSupport.java:141) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.readFields(GsonSerializationSupport.java:159) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.readEntity(GsonSerializationSupport.java:141) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport$2.read(GsonSerializationSupport.java:77) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport$2.read(GsonSerializationSupport.java:69) ~[jmix-reports-1.7.1.jar:na]
at com.google.gson.internal.bind.TypeAdapters$34$1.read(TypeAdapters.java:979) ~[gson-2.9.1.jar:na]
at com.google.gson.Gson.fromJson(Gson.java:1058) ~[gson-2.9.1.jar:na]
at com.google.gson.Gson.fromJson(Gson.java:1016) ~[gson-2.9.1.jar:na]
at com.google.gson.Gson.fromJson(Gson.java:959) ~[gson-2.9.1.jar:na]
at com.google.gson.Gson.fromJson(Gson.java:927) ~[gson-2.9.1.jar:na]
at io.jmix.reports.converter.GsonSerializationSupport.convertToReport(GsonSerializationSupport.java:313) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.converter.GsonConverter.convertToReport(GsonConverter.java:38) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.ReportsSerialization.convertToReport(ReportsSerialization.java:53) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.listener.ReportDetachListener.onBeforeDetach(ReportDetachListener.java:44) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.reports.listener.ReportDetachListener.onBeforeDetach(ReportDetachListener.java:32) ~[jmix-reports-1.7.1.jar:na]
at io.jmix.data.impl.EntityListenerManager.fireListener(EntityListenerManager.java:227) ~[jmix-data-1.7.1.jar:na]
at io.jmix.eclipselink.impl.EclipselinkPersistenceSupport.fireBeforeDetachEntityListener(EclipselinkPersistenceSupport.java:243) ~[jmix-eclipselink-1.7.1.jar:na]
at io.jmix.eclipselink.impl.EclipselinkPersistenceSupport.detach(EclipselinkPersistenceSupport.java:326) ~[jmix-eclipselink-1.7.1.jar:na]
at io.jmix.eclipselink.impl.JmixEntityManager.detach(JmixEntityManager.java:245) ~[jmix-eclipselink-1.7.1.jar:na]
at io.jmix.eclipselink.impl.JpaDataStore.detachEntity(JpaDataStore.java:645) ~[jmix-eclipselink-1.7.1.jar:na]
at io.jmix.eclipselink.impl.JpaDataStore.beforeLoadTransactionCommit(JpaDataStore.java:419) ~[jmix-eclipselink-1.7.1.jar:na]
at io.jmix.core.datastore.AbstractDataStore.loadList(AbstractDataStore.java:151) ~[jmix-core-1.7.1.jar:na]
at io.jmix.core.impl.UnconstrainedDataManagerImpl.loadList(UnconstrainedDataManagerImpl.java:112) ~[jmix-core-1.7.1.jar:na]
at io.jmix.core.FluentLoader$ByCondition.list(FluentLoader.java:819) ~[jmix-core-1.7.1.jar:na]
at ru.cs_consult.simpledoc.app.FirstRunInit.lambda$onApplicationStarted$1(FirstRunInit.java:103) ~[main/:na]
обстановка
Jmix version: 1.7.1
Jmix Studio Plugin Version: 2.6.4-252
IntelliJ version: IntelliJ IDEA 2025.2 (Community Edition)
implementation io.jmix.reports:jmix-reports-starter
implementation io.jmix.reports:jmix-reports-ui-starter
implementation io.jmix.reports:jmix-reports-rest-starter
**отчеты создавались в той же обстановке, только с io.jmix.cuba:jmix-cuba-starter
отчет для воспроизведения, созданный с подключенным io.jmix.cuba
test.zip (1.5 КБ)