Skip to content

Commit

Permalink
Support custom stores defined on the container as
Browse files Browse the repository at this point in the history
  • Loading branch information
bmac committed Jun 12, 2015
1 parent 1dc03ca commit c061ad4
Show file tree
Hide file tree
Showing 9 changed files with 27 additions and 26 deletions.
6 changes: 3 additions & 3 deletions packages/ember-data/lib/initializers/store-injections.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
@param {Ember.Registry} registry
*/
export default function initializeStoreInjections(registry) {
registry.injection('controller', 'store', 'store:application');
registry.injection('route', 'store', 'store:application');
registry.injection('data-adapter', 'store', 'store:application');
registry.injection('controller', 'store', 'store:main');
registry.injection('route', 'store', 'store:main');
registry.injection('data-adapter', 'store', 'store:main');
}
8 changes: 4 additions & 4 deletions packages/ember-data/lib/initializers/store.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import {JSONSerializer, RESTSerializer} from "ember-data/serializers";
import {RESTAdapter} from "ember-data/adapters";
import ContainerProxy from "ember-data/system/container-proxy";
import Store from "ember-data/system/store";

/**
Configures a registry for use with an Ember-Data
Expand All @@ -18,16 +17,17 @@ export default function initializeStore(registry, application) {
registry.optionsForType('serializer', { singleton: false });
registry.optionsForType('adapter', { singleton: false });

registry.register('store:application', application && application.Store || Store);
if (application && application.Store) {
registry.register('store:application', application.Store);
}

// allow older names to be looked up

var proxy = new ContainerProxy(registry);
proxy.registerDeprecations([
{ deprecated: 'serializer:_default', valid: 'serializer:-default' },
{ deprecated: 'serializer:_rest', valid: 'serializer:-rest' },
{ deprecated: 'adapter:_rest', valid: 'adapter:-rest' },
{ deprecated: 'store:main', valid: 'store:application' }
{ deprecated: 'adapter:_rest', valid: 'adapter:-rest' }
]);

// new go forward paths
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import Store from "ember-data/system/store";
/**
Configures a registry for use with an Ember-Data
store.
Expand All @@ -24,7 +25,14 @@ export default function initializeStoreService(applicationOrRegistry) {
container = registry;
}
}
if (registry.has('store:application')) {
var customStoreFactory = container.lookupFactory('store:application');
registry.register('store:main', customStoreFactory);
} else {
registry.register('store:main', Store);
}

// Eagerly generate the store so defaultStore is populated.
var store = container.lookup('store:application');
var store = container.lookup('store:main');
registry.register('service:store', store, { instantiate: false });
}
4 changes: 4 additions & 0 deletions packages/ember-data/lib/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,10 @@ if (Ember.VERSION.match(/^1\.[0-7]\./)) {
". Please upgrade your version of Ember, then upgrade Ember Data");
}

if (Ember.VERSION.match(/^1\.12\.0/)) {
throw new Ember.Error("Ember Data does not work with Ember 1.12.0. Please upgrade to Ember 1.12.1 or higher.");
}

// support RSVP 2.x via resolve, but prefer RSVP 3.x's Promise.cast
Ember.RSVP.Promise.cast = Ember.RSVP.Promise.cast || Ember.RSVP.resolve;

Expand Down
4 changes: 2 additions & 2 deletions packages/ember-data/tests/integration/application-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ var app, App, container;
*/

function getStore() {
return lookup('store:application');
return lookup('store:main');
}

function lookup(thing) {
Expand Down Expand Up @@ -69,7 +69,7 @@ test("registering App.Store is deprecated but functional", function() {
'has been deprecated. Please use `App.ApplicationStore` instead.');

run(function() {
ok(lookup('store:application').get('isCustomButDeprecated'), "the custom store was instantiated");
ok(lookup('store:main').get('isCustomButDeprecated'), "the custom store was instantiated");
});

var fooController = lookup('controller:foo');
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ module('integration/backwards-compat/non-dasherized-lookups - non dasherized loo
name: DS.attr()
});
});
store = App.__container__.lookup('store:application');
store = App.__container__.lookup('store:main');
},
teardown: function() {
run(App, 'destroy');
Expand Down Expand Up @@ -67,7 +67,7 @@ module('integration/backwards-compat/non-dasherized-lookups - non dasherized loo
postNotes: DS.hasMany('post_note')
});
});
store = App.__container__.lookup('store:application');
store = App.__container__.lookup('store:main');
},

teardown: function() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ module("DS.DebugAdapter", {

});

store = App.__container__.lookup('store:application');
store = App.__container__.lookup('store:main');
debugAdapter = App.__container__.lookup('data-adapter:main');

debugAdapter.reopen({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,7 @@ test("embedded records should be created in multiple stores", function() {

run(function() {
json_main = serializer_main.extractSingle(env.store, env.store.modelFor('home-planet'), json_hash_main);
equal(env.store.hasRecordForId('super-villain', "1"), true, "superVillain should exist in store:application");
equal(env.store.hasRecordForId('super-villain', "1"), true, "superVillain should exist in store:main");
});

run(function() {
Expand Down
13 changes: 1 addition & 12 deletions packages/ember-data/tests/integration/setup-container-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ module("integration/setup-container - Setting up a container", {
});

test("The store should be registered into a container.", function() {
ok(container.lookup('store:application') instanceof Store, "the custom store is instantiated");
ok(container.lookup('store:main') instanceof Store, "the custom store is instantiated");
});

test("The store should be registered into the container as a service.", function() {
Expand Down Expand Up @@ -86,17 +86,6 @@ test("serializers are not returned as singletons - each lookup should return a d
notEqual(serializer1, serializer2);
});

test("the deprecated store:main is resolved as store:application", function() {
var deprecated;
var valid = container.lookup('store:application');
expectDeprecation(function() {
deprecated = container.lookup('store:main');
});

ok(deprecated.constructor === valid.constructor, "they should resolve to the same thing");
});


test("adapters are not returned as singletons - each lookup should return a different instance", function() {
var adapter1, adapter2;
adapter1 = container.lookup('adapter:-rest');
Expand Down

0 comments on commit c061ad4

Please sign in to comment.