Release Notes for XWiki 9.2
This is the release notes for XWiki Commons, XWiki Rendering, XWiki Platform and XWiki Enterprise. They share the same release notes as they are released together and have the same version.
This release introduces the Notification menu to follow wiki activity more easily. The Administration has been re-organized with a collapsible menu. The Menu Application becomes responsive with burger menus. For the advanced users, the CKEditor integration adds support for dedicated Insert Macro tool bar buttons and the Extension Manager adds support for conflict resolution configuration when installing an extension. As usual, the release also brings many bug fixes and other small improvements.
New and Noteworthy (since XWiki 9.1.2)
Full list of issues fixed and Dashboard for 9.2.
For Users
Notifications
We have introduced a list of notifications in the top menu, that list some events that have occurred in the wiki recently: a page has been created, a new blog post has been published, etc...
See the Notifications Application's page to have more infos.
Confirmation before clearing notifications
Now a confirmation is asked before clearing all notifications.
Administration Improvements
The Administration has been reorganized. Most of the administration sections from the "Applications" group have been moved to existing or new groups. We applied a consistent style across all the administration sections and we added more hints for the configuration options. The administration menu is now implemented using a collapsible accordion.
CKEditor Integration Improvements
The integration with the CKEditor has been improved to support putting dedicated Insert Macro buttons on the tool bar. We enabled the native (in-browser) spellchecker and we fixed a few bugs.
Improvements of the Menu Application on Mobile
The space taken by the horizontal menus created with the Menu Application has been reduced by introducing menu burgers on Mobile display. The burgers are placed on the left side of the page, to avoid confusion between the Drawer menu and the horizontal menus.
For Admins
Extension Manager improvements
Extension Manager now gives a chance to users requesting it in their profile configure default conflict resolution behavior at the beginning of the install/upgrade/uninstall.
For Developers
Ability to store events in the event stream and display them as notifications
It is now possible to say to the Event Stream Module that some events, sent with the Observation Module, should be stored.
In addition, this events can be displayed in the notifications menu of users. See the tutorial: How to send notifications.
Jobs improvements
- The JobStatus now indicates the job type. There is nothing to do for Job extending AbstractJob but other will have to properly support it in the their JobStatus.
- The Job REST API now automatically injects context information (current user, current caller, current wiki, current document, current secure document, the request URL and parameters) in the job thread.
Filer Stream improvements
Instance Filter output stream now support xobjects without class definition so input filters don't have to generate events for it. It automatically fallback on the xclass located in the current wiki.
Miscellaneous
Extension Manager improvements: Extension Manager now generate events just before starting to install/uninstall/upgrade an extension.
Moved Modules
No modules have been deprecated, retired or moved.
Upgrades
The following runtime dependencies have been upgraded (they have a different release cycle than XWiki Commons, XWiki Rendering, XWiki Platform and XWiki Enterprise):
- reflections 0.9.11
- Commons Validator 1.6
- Jackson 2.8.7
- cssparser 0.9.22
- JGroups 4.0.1
- JSqlParser 0.9.7
- Solr 6.4.2
- slf4j 1.7.25
- Logback 1.2.2
- Apache PDFBox 2.0.5
Translations
The following translations have been updated:
- Czech
- Danish
- German
- French
- Italian
- Latvian
- Dutch
- Portuguese (Brazil)
- Romanian
- Russian
- Slovak
- Swedish
Tested Browsers & Databases
Here is the list of browsers we support and how they have been tested for this release:
Browser | Test Result | |
---|---|---|
Google Chrome | Not Tested | |
Mozilla Firefox 52 | Jira Tickets Marked as Fixed in the Release Notes + New and Noteworthy Features | |
Internet Explorer 10 | Not Tested | |
Internet Explorer 11 | Not Tested |
Here is the list of databases we support and how they have been tested for this release:
Database | Test Result | |
---|---|---|
HyperSQL | Not Tested | |
MySQL | Not Tested | |
Oracle 11.2 | Jira Tickets Marked as Fixed in the Release Notes + New and Noteworthy Features | |
PostgreSQL | Not Tested |
Performances tests compared to 8.4.4
Summary
There hasn't been much work on performance in 9.x so it's very similar to 8.4.4. Solr has been upgraded (from 6.2.1 to 6.4.2) and looks like it affected the speed of the job responsible for finding out what need to be indexed/removed but it does not seems to have any impact on actual indexing or standard document search.
"similar": difference is lower than 10%
"slightly": difference is lower than 20%
Speed
Actions | Difference | |
---|---|---|
Jetty startup | similar | |
First access | not existing page without UI | similar |
not existing page with UI | ||
Reload | not existing page without UI | similar |
not existing page with UI | similar | |
empty page without UI | similar | |
empty page with UI | similar | |
Main.WebHome without UI | similar | |
Main.WebHome with UI | similar | |
SOLR | Full SOLR reindex | similar |
SOLR sync when index is empty | +70% | |
SOLR sync when there is nothing to do | +70% | |
Result of search finding lots of results | similar | |
Result of search finding one result | similar | |
Rendering | Page with 1000 macros without UI | similar |
Page with 1000 html macros without UI | similar |
Memory
Actions | Difference |
---|---|
Heap Memory after jetty startup | -3MB |
Heap Memory after full SOLR index | similar |
More details on performance comparison on single wiki between 9.2 and 8.4.4.
Known issues
Backward Compatibility and Migration Notes
General Notes
When upgrading make sure you compare your xwiki.cfg, xwiki.properties and web.xml files with the newest version since some configuration parameters may have been modified or added. Note that you should add xwiki.store.migration=1 so that XWiki will attempt to automatically migrate your current database to the new schema. Make sure you backup your Database before doing anything.
API Breakages
The following APIs were modified since XWiki 9.1.2:
- The ExtensionId.hashCode field was wrongly introduced as non transient and deserializing some data serialized with the previous XWiki version should at worse initialize it to the default value which is -1 and ok. In any case we're using the ignoreUnknownElements() option on the XStream side so we should be ok anyway!
- Violation type:java.field.serialVersionUIDUnchanged
- Code:## Old:
field org.xwiki.extension.ExtensionId.serialVersionUID
## New:
field org.xwiki.extension.ExtensionId.serialVersionUID
- Violation type:
- Does not break anything: new static field with no impact on the serialization/unserialization
- Violation type:java.field.serialVersionUIDUnchanged
- Code:## Old:
field org.xwiki.extension.job.AbstractExtensionRequest.serialVersionUID
## New:
field org.xwiki.extension.job.AbstractExtensionRequest.serialVersionUID
- Violation type:
- This method was wrongly exposed as protected and was exposing the Event class which is a private class and thus the method couldn't be used as protected anyway
- Violation type:java.method.visibilityReduced
- Code:## Old:
method void org.xwiki.rendering.wikimodel.xhtml.filter.XHTMLWhitespaceXMLFilter::appendInlineEvent(org.xwiki.rendering.wikimodel.xhtml.filter.XHTMLWhitespaceXMLFilter.Event) throws org.xml.sax.SAXException
## New:
method void org.xwiki.rendering.wikimodel.xhtml.filter.XHTMLWhitespaceXMLFilter::appendInlineEvent(org.xwiki.rendering.wikimodel.xhtml.filter.XHTMLWhitespaceXMLFilter.Event) throws org.xml.sax.SAXException
- Violation type:
- This method was wrongly exposed as protected and was exposing the Event class which is a private class and thus the method couldn't be used as protected anyway
- Violation type:java.method.visibilityReduced
- Code:## Old:
method void org.xwiki.rendering.wikimodel.xhtml.filter.XHTMLWhitespaceXMLFilter::sendInlineEvent(org.xwiki.rendering.wikimodel.xhtml.filter.XHTMLWhitespaceXMLFilter.Event) throws org.xml.sax.SAXException
## New:
method void org.xwiki.rendering.wikimodel.xhtml.filter.XHTMLWhitespaceXMLFilter::sendInlineEvent(org.xwiki.rendering.wikimodel.xhtml.filter.XHTMLWhitespaceXMLFilter.Event) throws org.xml.sax.SAXException
- Violation type:
- Not a breakage from REST API point of view
- Violation type:java.annotation.removed
- Code:## Old:
field org.xwiki.rest.model.jaxb.JobStatus.id
## New:
field org.xwiki.rest.model.jaxb.JobStatus.id
- Violation type:
- Not a breakage from REST API point of view
- Violation type:java.annotation.removed
- Code:## Old:
field org.xwiki.rest.model.jaxb.JobStatus.progress
## New:
field org.xwiki.rest.model.jaxb.JobStatus.progress
- Violation type:
- Not a breakage from REST API point of view
- Violation type:java.annotation.attributeValueChanged
- Code:## Old:
class org.xwiki.rest.model.jaxb.JobStatus
## New:
class org.xwiki.rest.model.jaxb.JobStatus
- Violation type:
- Not a breakage from REST API point of view
- Violation type:java.method.numberOfParametersChanged
- Code:## Old:
method org.xwiki.rest.model.jaxb.JobStatus org.xwiki.rest.resources.job.JobStatusResource::getJobStatus(java.lang.String) throws org.xwiki.rest.XWikiRestException
## New:
method org.xwiki.rest.model.jaxb.JobStatus org.xwiki.rest.resources.job.JobStatusResource::getJobStatus(java.lang.String, boolean, boolean, boolean, java.lang.String) throws org.xwiki.rest.XWikiRestException
- Violation type:
Credits
The following people have contributed code to this release (sorted alphabetically):
- Alexandru Cotiugă
- Ecaterina Moraru (Valica)
- Guillaume Delhumeau
- Manuel Smeria
- Marius Dumitru Florea
- Raluca Stavro
- Thomas Mortagne
- Vincent Massol