-
Notifications
You must be signed in to change notification settings - Fork 214
ReleaseNotes0_5_0
Mojito 0.5.0 is now tagged and available on npm.
IMPORTANT This release contains notably backward compatibility changes, all in the name of significantly increased performance.
None of the NPM tags have changed. If you want to try this version, you need to ask for version 0.5.0
explicitly.
In the past, a subset of the addons provided by Mojito framework were attached on every ActionContext
object (which are created per request, per mojit instance in the page).
The specific list was mojito-config-addon, mojito-url-addon, mojito-assets-addon, mojito-cookie-addon, mojito-params-addon, mojito-composite-addon.
This resulted in overhead for every mojit in the page.
As part of 0.5.0, all requirements have to be specified in the controller definition. e.g:
YUI.add('Foo', function(Y, NAME) {
Y.namespace('mojito.controllers')[NAME] = {
index: function(ac) {
// ac.params.* is now available
}
};
}, '0.0.1', {requires: ['mojito', 'mojito-params-addon']});
As of 0.5.0, no addon is attached unless it is required. The only public members of ActionContent
object are ac.done
, ac.error
, and ac.flush
.
Recommendations to upgrade:
- check every controller in your app, and check if it is using
ac.*
, and add the corresponding requirements. - the most common addons are: config, params, url, assets.
Models are no longer computed and attached to ActionContext
by default.
In other words, ac.models.foo
is no longer a valid way to access a model.
Computing and attaching models automatically, even when they were not really needed, added overhead during the page rendering process.
Instead, we want Mojito to be more strict in defining and exposing structures automatically.
In 0.5.0, if you need to use a model in a controller (defined at the mojit level, or at the application level), you need to:
- require a new addon called
mojito-models-addon
in your controller. - require the module in your controller.
- use
ac.models.get('foo')
to get a reference of the model.
Here is an example:
YUI.add('DemoModelFoo', function(Y, NAME) {
Y.namespace('mojito.models')[NAME] = {
init: function(config) {
this.config = config;
},
getData: function(callback) {}
};
}, '0.0.1', {requires: []});
YUI.add('Foo', function(Y, NAME) {
Y.namespace('mojito.controllers')[NAME] = {
index: function(ac) {
ac.models.get('DemoModelFoo').getData(function (data) {
// data from model available here
});
}
};
}, '0.0.1', {requires: ['mojito', 'mojito-models-addon', 'DemoModelFoo']});
Note: the model name doesn't have to match the yui module name for the model anymore.
The init
method on the controller is now deprecated and should be removed.
In many cases, the init
method was just storing a reference of the config
parameter to use it later on.
This is no longer available, and the init
method will not be executed.
If you need to access the mojit config
in an actions, you should:
- require
mojito-config-addon
in the controller. - use
ac.config.get()
to get theconfig
Note: do not try to store a reference of that config, as it is not safe, More details below.
For performance reasons, to avoid computing app config per mojit instance, per request, when the majority of the time it is not needed, we completed the transition to mojito-config-addon
add-on.
This change affects ac.app.*
, specifically ac.app.config
which was commonly used to access the computed application.json
configuration per context
.
If you need to access the application config
in an action or another add-on, you should:
- require
mojito-config-addon
in the controller. - use
ac.config.getAppConfig()
to get the formerac.app.config
Mojito now imposes a timeout on the dispatch of the action in the controllers.
Starting with 0.5.0 there is a "reaper" which imposes a timeout.
Actions must call ac.done()
or ac.error()
before the timer expires or the system will log a warning and invoke ac.error()
with a timeout error.
This can be configured by the actionTimeout
setting in application.json
.
It contains the maximum number of milliseconds that a controller action is allowed to run before the action is timed out.
The default value is 60000
(60 seconds).
Mojito is more restrictive in how you names mojits and add-ons. There are 4 new rules:
-
addon
namespace should match the filename. E.g.ac.foo
corresponds toaddons/ac/foo.common.js
. - The name of the mojit, which is the name of the folder, should match the language bundle, including the filename of the bundle and its definition. E.g.
Foo
mojit can havelang/Foo_da-DK.js
, and the content should beYUI.add('lang/Foo_da-DK', function (Y) { Y.Intl.add('Foo', 'da-DK', {}); });
- Controller YUI module name should be same as directory.
- YUI modules need to have unique names, regardless of selector.
In previous versions, the console log was separated for client and server, and between Mojito and YUI.
We decided to leverage the YUI Logger, and unify this setting under a single configuration, actually the YUI configuration in application.json
:
"log": {
"client": {
"level": "error",
"yui": false
},
"server": {
"level": "error",
"yui": false
}
}
is now:
"yui": {
"config": {
"debug": true,
"logLevel": "error"
}
}
and we recommend this setting for production:
"yui": {
"config": {
"debug": false,
"logLevel": "none"
}
}
To customize this for client or server, you can use the runtime context.
Also, you can now use logExclude
and logInclude
.
More information at http://yuilibrary.com/yui/docs/api/classes/config.html.
The following are gone:
embedJsFilesInHtmlFrame
shareYUIInstance
- in the
yui
section:base
dependencyCalculations
extraModules
loader
url
urlContains
In the past, mojito test
without any other parameter was running all unit tests for mojito framework, and this is no longer the case.
We moved all the tests to arrow
, more details here: https://github.com/yahoo/mojito/tree/develop/tests
You can continue using mojito test app path/to/app
and mojito test mojit path/to/mojit
, and the behavior is still the same.
Note: this change is only relevant for contributors.
The .guid
member of Mojito metadata (such as binder metadata) is now gone.
Often there's an associated member which more specifically expresses the intent of the unique ID (for example .viewId
or .instanceId
).
- Speed: TODO more details.
- Logging now uses
Y.log
directly, instead of our own wrapper. This simplifies usage and enables listening of the YUI log events. - Upgraded
yui
dependency to3.7.3
(or greater). - Combo handling is now built in to Mojito server.
- Hybrid app archetype.
TODO
- #70 Simplify logging
- #525 example unit tests crash or fail
- #651 Expanded instances are bleeding
- #736 Content Error in documentation
- bz 5904449 garbled console output on node 0.8+
- bz 5914052 do real buffer calculus for better UTF8 and binary support
- bz 5472979 server resources in build
- bz 5886351 cli bin/mojito uses wrong copy
- bz 5892364 (archetype) mojito-client not loaded for hybrid app
TODO
- #800
- #801
- #803
- #805
- #807
- #808
- #810
- #811
- #813
- #814
- #815
- #816
- #817
- #818
- #819
- #820
- #821
- #822
- #825
- #826
- #827
- #828
- #829
- #830
- #832
- #833
- #834
- #836
Special thanks to the Yahoo! Search team for inspiring the work and contributing a great deal to Mojito.
Also thanks to @lazybean for his contributions to the documentation.