You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@wicket.apache.org by "Sven Meier (JIRA)" <ji...@apache.org> on 2014/11/24 17:12:12 UTC
[jira] [Updated] (WICKET-5772) LoadableDetachableModel caches null
value if load() fails, bug in getObject() {attached = true;}
[ https://issues.apache.org/jira/browse/WICKET-5772?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Sven Meier updated WICKET-5772:
-------------------------------
Assignee: Sven Meier
The fix is trivial indeed.
@devs: any objections against this change on 6.x? Although unlikely, even such a small change could break existing applications.
> LoadableDetachableModel caches null value if load() fails, bug in getObject() {attached = true;}
> ------------------------------------------------------------------------------------------------
>
> Key: WICKET-5772
> URL: https://issues.apache.org/jira/browse/WICKET-5772
> Project: Wicket
> Issue Type: Bug
> Components: wicket
> Affects Versions: 1.4.23, 6.18.0, 7.0.0-M4
> Reporter: Martin Makundi
> Assignee: Sven Meier
> Labels: easyfix, easytest, patch
> Original Estimate: 10m
> Remaining Estimate: 10m
>
> If you have a LoadableDetachableModel whose load() operation fails at an instance, the LoadableDetachableModel will cache null value because
> getObject() method sets attached = true; before load() invocation has returned.
> This results in methods trusting LoadableDetachableModel using the null value for their operations which is logically incorrect as null might not be a legal value at all. Such behavior would result in unexpected difficult-to-debug behavior in depending components.
> Easy fix:
> Move:
> attached = true;
> after line:
> transientModelObject = load();
> Test case:
> /**
> * LoadableDetachableModel must not return null as an attached value if load()
> * fails.
> */
> public void testWhenLoadFails() {
> final LoadableDetachableModel<Void> loadableDetachableModel = new LoadableDetachableModel<Void>() {
> /**
> * @see org.apache.wicket.model.LoadableDetachableModel#load()
> */
> @Override
> protected Void load() {
> throw new UnsupportedOperationException("Let's assume this fails for some reason.");
> }
> };
> try {
> loadableDetachableModel.getObject();
> fail(UnsupportedOperationException.class + " expected.");
> } catch (final UnsupportedOperationException e) {
> LoggerFactory.getLogger(LoadableDetachableModel.class).debug("Expected behavior due to " + UnsupportedOperationException.class);
> }
> try {
> assertNotSame(LoadableDetachableModel.class + " should not return null if it's load() has failed\n", null,
> loadableDetachableModel.getObject());
> } catch (final UnsupportedOperationException e) {
> LoggerFactory.getLogger(LoadableDetachableModel.class).debug("Expected behavior due to " + UnsupportedOperationException.class);
> }
> }
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)