Upgrade to version 6.1.0 from 6.0.6 fails if some images do not exist in image folder

Description

In the case some from the images in the image library is missing (in the case of previous failure the image has been deleted deleted or something else happened the image file just does not exist), then the upgrade fails and the database remains inconsistent, so the upgrade cannot be executed.
The upgrade should be made so it does not fail completely, but just should not take over the concrete image or delete it or, replace with some standard "failed upgrade" picture with the same file name, log this event into the log and continue. Or, at least, if it fails from that reason, it should write down the list of all pictures missing, otherwise the recostruction of the image folder and file structure can become very very problematic - to figure out one missing picture one new run of upgrade is necessary, then again the DB restore, etc.
Following errors are in the log in the case of such problem:

14:41:57,921 INFO [DialectDetector:80] Determine dialect for PostgreSQL 9
14:41:57,968 INFO [DialectDetector:145] Found dialect org.hibernate.dialect.PostgreSQLDialect
14:42:29,640 INFO [BaseDB:406] Database supports case sensitive queries
14:42:29,890 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.UpgradeProcess_6_1_0
14:42:29,890 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.v6_1_0.UpgradeSchema
14:42:33,000 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.v6_1_0.UpgradeUserName
14:42:33,203 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.v6_1_0.UpgradeAdminPortlets
14:42:33,390 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.v6_1_0.UpgradeBlogs
14:42:33,718 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.v6_1_0.UpgradeCamelCasePortletPreferences
14:42:35,546 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.v6_1_0.UpgradeCountry
14:42:35,750 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.v6_1_0.UpgradeDocumentLibrary
14:42:36,031 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.v6_1_0.UpgradeExpando
14:42:36,046 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.v6_1_0.UpgradeGroup
14:42:36,406 INFO [UpgradeProcess:205] Upgrading com.liferay.portal.upgrade.v6_1_0.UpgradeImageGallery
14:42:37,312 ERROR [MainServlet:198] com.liferay.portal.kernel.events.ActionException: com.liferay.portal.kernel.upgrade.UpgradeException: com.liferay.portal.kernel.upgrade.UpgradeException: com.liferay.portlet.documentlibrary.NoSuchFileException: C:\DEVELOP\Liferay_6.1.0\bin\data\images\10\42\10423.png
com.liferay.portal.kernel.events.ActionException: com.liferay.portal.kernel.upgrade.UpgradeException: com.liferay.portal.kernel.upgrade.UpgradeException: com.liferay.portlet.documentlibrary.NoSuchFileException: C:\DEVELOP\Liferay_6.1.0\bin\data\images\10\42\10423.png
at com.liferay.portal.events.StartupAction.run(StartupAction.java:58)
at com.liferay.portal.servlet.MainServlet.processStartupEvents(MainServlet.java:1267)
at com.liferay.portal.servlet.MainServlet.init(MainServlet.java:195)
at javax.servlet.GenericServlet.init(GenericServlet.java:160)
at org.apache.catalina.core.StandardWrapper.initServlet(StandardWrapper.java:1266)
at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1185)
at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:1080)
at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:5001)
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5289)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:866)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:842)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:615)
at org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:649)
at org.apache.catalina.startup.HostConfig$DeployDescriptor.run(HostConfig.java:1581)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:619)
Caused by: com.liferay.portal.kernel.upgrade.UpgradeException: com.liferay.portal.kernel.upgrade.UpgradeException: com.liferay.portlet.documentlibrary.NoSuchFileException: C:\DEVELOP\Liferay_6.1.0\bin\data\images\10\42\10423.png
at com.liferay.portal.kernel.upgrade.UpgradeProcess.upgrade(UpgradeProcess.java:211)
at com.liferay.portal.upgrade.UpgradeProcessUtil._upgradeProcess(UpgradeProcessUtil.java:93)
at com.liferay.portal.upgrade.UpgradeProcessUtil.upgradeProcess(UpgradeProcessUtil.java:46)
at com.liferay.portal.events.StartupHelper.upgradeProcess(StartupHelper.java:81)
at com.liferay.portal.events.StartupHelperUtil.upgradeProcess(StartupHelperUtil.java:40)
at com.liferay.portal.tools.DBUpgrader.upgrade(DBUpgrader.java:119)
at com.liferay.portal.events.StartupAction.doRun(StartupAction.java:144)
at com.liferay.portal.events.StartupAction.run(StartupAction.java:52)
... 20 more
Caused by: com.liferay.portal.kernel.upgrade.UpgradeException: com.liferay.portlet.documentlibrary.NoSuchFileException: C:\DEVELOP\Liferay_6.1.0\bin\data\images\10\42\10423.png
at com.liferay.portal.kernel.upgrade.UpgradeProcess.upgrade(UpgradeProcess.java:211)
at com.liferay.portal.kernel.upgrade.UpgradeProcess.upgrade(UpgradeProcess.java:225)
at com.liferay.portal.upgrade.UpgradeProcess_6_1_0.doUpgrade(UpgradeProcess_6_1_0.java:67)
at com.liferay.portal.kernel.upgrade.UpgradeProcess.upgrade(UpgradeProcess.java:208)
... 27 more
Caused by: com.liferay.portlet.documentlibrary.NoSuchFileException: C:\DEVELOP\Liferay_6.1.0\bin\data\images\10\42\10423.png
at com.liferay.portal.image.FileSystemHook.getImageAsStream(FileSystemHook.java:74)
at com.liferay.portal.upgrade.v6_1_0.UpgradeImageGallery.migrateImage(UpgradeImageGallery.java:357)
at com.liferay.portal.upgrade.v6_1_0.UpgradeImageGallery.migrateImageFiles(UpgradeImageGallery.java:398)
at com.liferay.portal.upgrade.v6_1_0.UpgradeImageGallery.doUpgrade(UpgradeImageGallery.java:248)
at com.liferay.portal.kernel.upgrade.UpgradeProcess.upgrade(UpgradeProcess.java:208)
... 30 more

Activity

Show:

Mark Jin February 19, 2012 at 6:26 PM

PASSED Manual Testing using the following steps:

1. Start liferay 606.
2. Add some image without folder.
3. Upgrade.

Reproduced on:
Tomcat 7.0 + MySQL 5. 6.1.0 GA1.

Fixed on:
Tomcat 7.0 + MySQL 5. 6.1.x GIT ID: 68b99679c98d9eb177b10d681371d8fc291e7e66.
Tomcat 7.0 + MySQL 5. 6.2.x GIT ID: fcfb50d00f9c3b05bf819a0509ec7cd998da0440.

Michael Saechang February 16, 2012 at 3:11 PM

Committed on:
6.1.x GIT ID: 522a6f6415c59533da50965cf575116f7c68316e.
6.2.x GIT ID: e449f6d9ddb15cc224d0f67a308659808bd7d230.

Alexander Chow February 14, 2012 at 10:47 AM

And thanks, everybody, for your feedback.

Alexander Chow February 14, 2012 at 10:47 AM

We are fixing this by logging the exception and continuing forward with the upgrade process.

Drew Blessing February 2, 2012 at 6:28 AM

Hi Roy,

I don't think this is a Liferay bug. The changes from 6.0.6 to 6.1 have been substantial. As such, the upgrade process is going to take a little work on your part to make sure you have settings correct and have the database and files in the right place. I had a lot of trouble with my upgrade process at first, too. However, I used the great resources in the community forums and on the Liferay IRC channel (#liferay). I know there are people in IRC that would be happy to help - I am usually there, too. I hope this helps.

Fixed
Pinned fields
Click on the next to a field label to start pinning.

Details

Assignee

Reporter

Branch Version/s

6.1.x

Backported to Branch

Committed

Affects versions

Priority

Zendesk Support

Created January 23, 2012 at 7:12 AM
Updated June 24, 2023 at 3:52 PM
Resolved October 4, 2012 at 5:11 PM