Move identity map into the store, shouldn't have been in the adapter

This commit is contained in:
Robin Ward
2015-03-06 12:56:32 -05:00
parent ecb553af3f
commit 7c25efc095
5 changed files with 122 additions and 88 deletions

View File

@ -99,6 +99,12 @@ export default function() {
}
});
this.put('/widgets/:widget_id', function(request) {
const w = _widgets.findBy('id', parseInt(request.params.widget_id));
const cloned = JSON.parse(JSON.stringify(w));
return response({ widget: cloned });
});
this.get('/widgets', function() {
return response({ widgets: _widgets });
});

View File

@ -0,0 +1,24 @@
module('rest-model');
import createStore from 'helpers/create-store';
test('update', function() {
const store = createStore();
store.find('widget', 123).then(function(widget) {
equal(widget.get('name'), 'Trout Lure');
widget.update({ name: 'new name' }).then(function() {
equal(widget.get('name'), 'new name');
});
});
});
test('destroyRecord', function() {
const store = createStore();
store.find('widget', 123).then(function(widget) {
widget.destroyRecord().then(function(result) {
ok(result);
});
});
});

View File

@ -23,6 +23,13 @@ test('find', function() {
});
});
test('update', function() {
const store = createStore();
store.update('widget', 123, {name: 'hello'}).then(function(result) {
ok(result);
});
});
test('findAll', function() {
const store = createStore();
store.findAll('widget').then(function(result) {
@ -34,7 +41,9 @@ test('findAll', function() {
test('destroyRecord', function() {
const store = createStore();
store.destroyRecord('widget', 124).then(function(result) {
ok(result);
store.find('widget', 123).then(function(w) {
store.destroyRecord('widget', w).then(function(result) {
ok(result);
});
});
});