Skip to content

Commit

Permalink
Deprecate the store.fetch APIs and replace them will an reload option
Browse files Browse the repository at this point in the history
on `store.find`/`store.findAll`.
  • Loading branch information
bmac committed Jun 11, 2015
1 parent 0f0344d commit 9383d5b
Show file tree
Hide file tree
Showing 3 changed files with 70 additions and 36 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ export default Ember.ArrayProxy.extend(Ember.Evented, {
var store = get(this, 'store');
var modelName = get(this, 'type.modelName');

return store.fetchAll(modelName, this);
return store.findAll(modelName, { reload: true });
},

/**
Expand Down
88 changes: 61 additions & 27 deletions packages/ember-data/lib/system/store.js
Original file line number Diff line number Diff line change
Expand Up @@ -501,26 +501,8 @@ Store = Service.extend({
/**
This method returns a fresh record for a given type and id combination.
If a record is available for the given type/id combination, then
it will fetch this record from the store and call `reload()` on it.
That will fire a request to server and return a promise that will
resolve once the record has been reloaded.
If there's no record corresponding in the store it will simply call
`store.find`.
Example
```app/routes/post.js
import Ember from 'ember';
export default Ember.Route.extend({
model: function(params) {
return this.store.fetchById('post', params.post_id);
}
});
```
@method fetchById
@deprecated Use [findRecord](#method_findRecord) instead
@param {String} modelName
@param {(String|Integer)} id
@param {Object} options
Expand All @@ -529,6 +511,7 @@ Store = Service.extend({
fetchById: function(modelName, id, preload) {
Ember.assert('Passing classes to store methods has been removed. Please pass a dasherized string instead of '+ Ember.inspect(modelName), typeof modelName === 'string');
var options = deprecatePreload(preload, this.modelFor(modelName), 'fetchById');
Ember.deprecate('Using store.fetchById(type, id) has been deprecated. Use store.findRecord(type, id, { reload: true }) to reload a record for a given type.');
if (this.hasRecordForId(modelName, id)) {
return this.peekRecord(modelName, id).reload();
} else {
Expand All @@ -541,12 +524,13 @@ Store = Service.extend({
in the store or not.
@method fetchAll
@deprecated Use [findAll](#method_findAll) instead
@param {String} modelName
@return {Promise} promise
*/
fetchAll: function(modelName) {
Ember.deprecate('Using store.fetchAll(type) has been deprecated. Use store.findAll(type) to retrieve all records for a given type.');
return this.findAll(modelName);
Ember.deprecate('Using store.fetchAll(type) has been deprecated. Use store.findAll(type, { reload: true }) to retrieve all records for a given type.');
return this.findAll(modelName, { reload: true });
},

/**
Expand All @@ -555,12 +539,12 @@ Store = Service.extend({
@param {(String|Integer)} id
@param {Object} preload - optional set of attributes and relationships passed in either as IDs or as actual models
@return {Promise} promise
@deprecated Use [fetchById](#method_fetchById) instead
@deprecated Use [findRecord](#method_findRecord) instead
*/
fetch: function(modelName, id, preload) {
Ember.assert('Passing classes to store methods has been removed. Please pass a dasherized string instead of '+ Ember.inspect(modelName), typeof modelName === 'string');
Ember.deprecate('Using store.fetch() has been deprecated. Use store.fetchById for fetching individual records or store.fetchAll for collections');
return this.fetchById(modelName, id, preload);
Ember.deprecate('Using store.fetch() has been deprecated. Use store.findRecord for fetching individual records or store.fetchAll for collections');
return this.findRecord(modelName, id, { reload: true, preload: preload });
},

/**
Expand All @@ -582,6 +566,40 @@ Store = Service.extend({
/**
This method returns a record for a given type and id combination.
The `find` method will always return a **promise** that will be
resolved with the record. If the record was already in the store,
the promise will be resolved immediately. Otherwise, the store
will ask the adapter's `find` method to find the necessary data.
The `find` method will always resolve its promise with the same
object for a given type and `id`.
Example
```app/routes/post.js
import Ember from 'ember';
export default Ember.Route.extend({
model: function(params) {
return this.store.findRecord('post', params.post_id);
}
});
```
If you would like to force the record to reload, instead of
loading it from the cache when present you can set `reload: true`
in the options object for `findRecord`.
```app/routes/post/edit.js
import Ember from 'ember';
export default Ember.Route.extend({
model: function(params) {
return this.store.findRecord('post', params.post_id, { reload: true });
}
});
```
@method findRecord
@param {String} modelName
@param {(String|Integer)} id
Expand All @@ -591,7 +609,11 @@ Store = Service.extend({
findRecord: function(modelName, id, options) {
Ember.assert('Passing classes to store methods has been removed. Please pass a dasherized string instead of '+ Ember.inspect(modelName), typeof modelName === 'string');
var internalModel = this._internalModelForId(modelName, id);
options = options || {};

if (options.reload && this.hasRecordForId(modelName, id)) {
return this.peekRecord(modelName, id).reload();
}
return this._findByInternalModel(internalModel, options);
},

Expand Down Expand Up @@ -1040,9 +1062,21 @@ Store = Service.extend({
},

/**
This method returns an array of all records adapter can find.
It triggers the adapter's `findAll` method to give it an opportunity to populate
the array with records of that type.
`findAll` ask the adapter's `findAll` method to find the records
for the given type, and return a promise that will be resolved
once the server returns the values. The promise will resolve into
all records of this type present in the store, even if the server
only returns a subset of them.
```app/routes/authors.js
import Ember from 'ember';
export default Ember.Route.extend({
model: function(params) {
return this.store.findAll('author');
}
});
```
@method findAll
@param {String} modelName
Expand Down
16 changes: 8 additions & 8 deletions packages/ember-data/tests/integration/store-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -227,17 +227,17 @@ test("Using store#fetch is deprecated", function() {
store.fetch('car', 1);
});
},
'Using store.fetch() has been deprecated. Use store.fetchById for fetching individual records or store.fetchAll for collections'
'Using store.fetch() has been deprecated. Use store.findRecord for fetching individual records or store.fetchAll for collections'
);
});

module("integration/store - fetchById", {
module("integration/store - findRecord { reload: true }", {
setup: function() {
initializeStore(DS.RESTAdapter.extend());
}
});

test("Using store#fetchById on non existing record fetches it from the server", function() {
test("Using store#findRecord on non existing record fetches it from the server", function() {
expect(2);

ajaxResponse({
Expand All @@ -252,13 +252,13 @@ test("Using store#fetchById on non existing record fetches it from the server",
ok(!car, 'Car with id=20 should not exist');

run(function() {
store.fetchById('car', 20).then(function (car) {
store.findRecord('car', 20, { reload: true }).then(function (car) {
equal(car.get('make'), 'BMCW', 'Car with id=20 is now loaded');
});
});
});

test("Using store#fetchById on existing record reloads it", function() {
test("Using store#findRecord on existing record reloads it", function() {
expect(2);
var car;

Expand All @@ -281,7 +281,7 @@ test("Using store#fetchById on existing record reloads it", function() {
equal(car.get('make'), 'BMC');

run(function() {
store.fetchById('car', 1).then(function(car) {
store.findRecord('car', 1, { reload: true }).then(function(car) {
equal(car.get('make'), 'BMCW');
});
});
Expand All @@ -304,7 +304,7 @@ test("store#fetchAll() is deprecated", function() {
store.fetchAll('car');
});
},
'Using store.fetchAll(type) has been deprecated. Use store.findAll(type) to retrieve all records for a given type.'
'Using store.fetchAll(type) has been deprecated. Use store.findAll(type, { reload: true }) to retrieve all records for a given type.'
);
});

Expand Down Expand Up @@ -424,7 +424,7 @@ test("Using store#fetch on an empty record calls find", function() {
ok(car.get('isEmpty'), 'Car with id=20 should be empty');

run(function() {
store.fetchById('car', 20).then(function (car) {
store.findRecord('car', 20, { reload: true }).then(function (car) {
equal(car.get('make'), 'BMCW', 'Car with id=20 is now loaded');
});
});
Expand Down

0 comments on commit 9383d5b

Please sign in to comment.