ember-appkit-rails 0.4.0 → 0.5.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (121) hide show
  1. checksums.yaml +4 -4
  2. data/lib/ember/appkit/rails.rb +4 -0
  3. data/lib/ember/appkit/rails/engine.rb +6 -1
  4. data/lib/ember/appkit/rails/teaspoon.rb +5 -0
  5. data/lib/ember/appkit/rails/teaspoon/engine.rb +3 -0
  6. data/lib/ember/appkit/rails/teaspoon/suite.rb +7 -0
  7. data/lib/ember/appkit/rails/version.rb +1 -1
  8. data/lib/ember/appkit/rails/views/teaspoon/spec/_eak_rails.html.erb +10 -0
  9. data/lib/generators/ember/bootstrap_generator.rb +27 -9
  10. data/lib/generators/ember/component_generator.rb +2 -2
  11. data/lib/generators/ember/controller_generator.rb +4 -4
  12. data/lib/generators/ember/generator_helpers.rb +4 -0
  13. data/lib/generators/ember/install_generator.rb +150 -0
  14. data/lib/generators/ember/model_generator.rb +7 -2
  15. data/lib/generators/ember/resource_generator.rb +1 -1
  16. data/lib/generators/ember/route_generator.rb +2 -2
  17. data/lib/generators/ember/scaffold_generator.rb +17 -3
  18. data/lib/generators/ember/serializer_override.rb +18 -0
  19. data/lib/generators/ember/view_generator.rb +2 -2
  20. data/{test/dummy/config/adapters/application.js.es6.erb → lib/generators/templates/adapters/application.es6.erb} +0 -0
  21. data/lib/generators/templates/application.js.erb +1 -0
  22. data/lib/generators/templates/{array_controller.js.es6 → array_controller.es6} +0 -0
  23. data/lib/generators/templates/{component.js.es6 → component.es6} +0 -0
  24. data/lib/generators/templates/{controller.js.es6 → controller.es6} +0 -0
  25. data/lib/generators/templates/environment.js.erb +2 -0
  26. data/lib/generators/templates/environments/development.js.erb +5 -5
  27. data/lib/generators/templates/environments/production.js.erb +2 -2
  28. data/lib/generators/templates/environments/test.js.erb +1 -1
  29. data/lib/generators/templates/initializers/teaspoon.rb +63 -0
  30. data/lib/generators/templates/{model.js.es6 → model.es6} +0 -0
  31. data/lib/generators/templates/{object_controller.js.es6 → object_controller.es6} +0 -0
  32. data/lib/generators/templates/{route.js.es6 → route.es6} +0 -0
  33. data/lib/generators/templates/{router.js.es6 → router.es6} +0 -0
  34. data/lib/generators/templates/scaffold/route/{edit.js.es6 → edit.es6} +1 -1
  35. data/lib/generators/templates/scaffold/route/{index.js.es6 → index.es6} +1 -1
  36. data/lib/generators/templates/scaffold/route/{new.js.es6 → new.es6} +1 -1
  37. data/lib/generators/templates/scaffold/route/{show.js.es6 → show.es6} +1 -1
  38. data/lib/generators/templates/scaffold/template/form.hbs +3 -4
  39. data/lib/generators/templates/scaffold/template/index.hbs +2 -2
  40. data/lib/generators/templates/scaffold/template/show.hbs +2 -2
  41. data/lib/generators/templates/scaffold_controller/controller.rb +2 -2
  42. data/lib/generators/templates/test/model.es6 +7 -0
  43. data/lib/generators/templates/test/route.es6 +23 -0
  44. data/lib/generators/templates/test/teaspoon_env.rb +38 -0
  45. data/lib/generators/templates/test/test_helper.js +55 -0
  46. data/lib/generators/templates/{view.js.es6 → view.es6} +0 -0
  47. data/test/dummy/config/adapters/application.es6.erb +3 -0
  48. data/test/dummy/config/application.js +1 -0
  49. data/test/dummy/config/environment.js.erb +2 -0
  50. data/test/dummy/config/environments/development.js.erb +5 -5
  51. data/test/dummy/config/environments/production.js.erb +2 -2
  52. data/test/dummy/config/environments/test.js.erb +1 -1
  53. data/test/dummy/config/initializers/secret_token.rb +1 -1
  54. data/test/dummy/config/initializers/teaspoon.rb +63 -0
  55. data/test/dummy/config/{router.js.es6 → router.es6} +0 -0
  56. data/test/dummy/log/test.log +71 -8
  57. data/test/dummy/test/teaspoon_env.rb +38 -0
  58. data/test/dummy/test/test_helper.js +55 -0
  59. data/test/dummy/tmp/cache/assets/test/sprockets/{eeb5bd38d1dad0d908461fd114f702bc → 08230536deeb8bca57aa54c1cf9a8a67} +0 -0
  60. data/test/dummy/tmp/cache/assets/test/sprockets/0f4e288e1e01cda64059f8f521519f5a +0 -0
  61. data/test/dummy/tmp/cache/assets/test/sprockets/{492d1909e24832f58ebca96dade2a876 → 1318d49b0a8b80264cc6d140438953bf} +0 -0
  62. data/test/dummy/tmp/cache/assets/test/sprockets/13fe41fee1fe35b49d145bcc06610705 +0 -0
  63. data/test/dummy/tmp/cache/assets/test/sprockets/357970feca3ac29060c1e3861e2c0953 +0 -0
  64. data/test/dummy/tmp/cache/assets/test/sprockets/39492898b23538577ff8db562a35fb7c +0 -0
  65. data/test/dummy/tmp/cache/assets/test/sprockets/3f9cb5a26b08b9e25de91fe142228ad2 +0 -0
  66. data/test/dummy/tmp/cache/assets/test/sprockets/4a1d4e32cd7b9fd1c62bfd553ae56051 +0 -0
  67. data/test/dummy/tmp/cache/assets/test/sprockets/4d3cadf0ab91b4a77adf81282a5550a1 +0 -0
  68. data/test/dummy/tmp/cache/assets/test/sprockets/{1f15c49a05b13c3a7ee50d2ac3900f38 → 571f65ff5db500e9ad70fc11060270a8} +0 -0
  69. data/test/dummy/tmp/cache/assets/test/sprockets/660bc633c8899c6c1b20514637fa0169 +0 -0
  70. data/test/dummy/tmp/cache/assets/test/sprockets/67afcba9807cd5e57b80b5fdf9f26758 +0 -0
  71. data/test/dummy/tmp/cache/assets/test/sprockets/{47fb03bce147145961cb3deeafca54d7 → 7190c4707840ff0d7c60920ae9739c79} +0 -0
  72. data/test/dummy/tmp/cache/assets/test/sprockets/7ca4966e0a480430a858a7ab74518c75 +0 -0
  73. data/test/dummy/tmp/cache/assets/test/sprockets/83030d43d9bff738a1a01366d61d7691 +0 -0
  74. data/test/dummy/tmp/cache/assets/test/sprockets/83af35bb6b852de883a26a9458fd4e3a +0 -0
  75. data/test/dummy/tmp/cache/assets/test/sprockets/8adfb5e646dca2c629e5d3dc88e2c2e9 +0 -0
  76. data/test/dummy/tmp/cache/assets/test/sprockets/9160f792acb62d1f7721c714681fcfe6 +0 -0
  77. data/test/dummy/tmp/cache/assets/test/sprockets/a6a0d79927cb0ec286aa0afb9812685c +0 -0
  78. data/test/dummy/tmp/cache/assets/test/sprockets/bb4a2293175928af3e23c47488077098 +0 -0
  79. data/test/dummy/tmp/cache/assets/test/sprockets/bf689240392e7355c0de5cfd47272146 +0 -0
  80. data/test/dummy/tmp/cache/assets/test/sprockets/{66c0ce49a71def0f29dcf0bcaf8fb28d → c4eca8931f39b747ea9f916a3b42d8da} +0 -0
  81. data/test/dummy/tmp/cache/assets/test/sprockets/cdbe9110f011148cc7a1f172dc18a883 +0 -0
  82. data/test/dummy/tmp/cache/assets/test/sprockets/d5a48c6656341c56cac8a8e42bb925a5 +0 -0
  83. data/test/dummy/tmp/cache/assets/test/sprockets/{d4cb455bee790d041fb3111fb1636531 → d5b1e7219e29c039a8ebb0a4e5b19a2b} +0 -0
  84. data/test/dummy/tmp/cache/assets/test/sprockets/{ce7582379ff02bb25cee3ac0486fe1f2 → d5ce5243d4ca4a3739a15e60e3c685ba} +0 -0
  85. data/test/dummy/tmp/cache/assets/test/sprockets/d771ace226fc8215a3572e0aa35bb0d6 +0 -0
  86. data/test/dummy/tmp/cache/assets/test/sprockets/de0932670a6c856bc6eda1586fd29061 +0 -0
  87. data/test/dummy/tmp/cache/assets/test/sprockets/e9abb671d48f6ff2be6ffb463ea652bf +0 -0
  88. data/test/dummy/tmp/cache/assets/test/sprockets/{e36a853a1349d7f33f6c0083c05f897b → fb43f1b92235ac87bedc9ac12be00188} +0 -0
  89. data/test/dummy/tmp/generator_test_output/app/views/{post.js.es6 → post.es6} +0 -0
  90. data/test/fixtures/vcr_cassettes/fetch_ember_beta.yml +39609 -0
  91. data/test/fixtures/vcr_cassettes/fetch_ember_canary.yml +41381 -0
  92. data/test/fixtures/vcr_cassettes/fetch_ember_data_tagged.yml +4283 -0
  93. data/test/fixtures/vcr_cassettes/fetch_ember_release.yml +38824 -0
  94. data/test/fixtures/vcr_cassettes/fetch_ember_tagged.yml +29518 -0
  95. data/test/generators/bootstrap_generator_test.rb +12 -4
  96. data/test/generators/component_generator_test.rb +6 -6
  97. data/test/generators/controller_generator_test.rb +5 -5
  98. data/test/generators/install_generator_test.rb +163 -0
  99. data/test/generators/model_generator_test.rb +29 -7
  100. data/test/generators/resource_generator_test.rb +6 -6
  101. data/test/generators/route_generator_test.rb +1 -1
  102. data/test/generators/scaffold_generator_test.rb +59 -10
  103. data/test/generators/serializer_override_test.rb +19 -0
  104. data/test/generators/view_generator_test.rb +6 -6
  105. data/test/integration/engine_test.rb +4 -0
  106. data/test/support/generator_test_support.rb +2 -2
  107. data/vendor/assets/javascripts/{app.js.es6.erb → app.es6.erb} +3 -1
  108. data/vendor/assets/javascripts/ember-appkit/index.js +0 -1
  109. data/vendor/assets/javascripts/ember-appkit/resolver.js +235 -32
  110. data/vendor/assets/javascripts/fake_xml_http_request.js +473 -0
  111. data/vendor/assets/javascripts/fakehr.js +52 -0
  112. data/vendor/assets/javascripts/httpRespond.js +24 -0
  113. metadata +126 -55
  114. data/lib/generators/templates/adapter.js.erb +0 -3
  115. data/test/dummy/tmp/cache/assets/test/sprockets/10fe949cc641775f5630b5dad6deb5fc +0 -0
  116. data/test/dummy/tmp/cache/assets/test/sprockets/129b422236f443119233cdb0a4525a06 +0 -0
  117. data/test/dummy/tmp/cache/assets/test/sprockets/25b8b60341168a02f48dabd2b0aa82ad +0 -0
  118. data/test/dummy/tmp/cache/assets/test/sprockets/827fafc13575b345cc572fd041ef1fba +0 -0
  119. data/test/dummy/tmp/cache/assets/test/sprockets/83a9a7d15d681a382363d2bccb9528bb +0 -0
  120. data/test/dummy/tmp/cache/assets/test/sprockets/de94a60b438eb5bf57653f3a220acd80 +0 -0
  121. data/vendor/assets/javascripts/ember-appkit/resolver_ext.js +0 -40
@@ -0,0 +1,19 @@
1
+ require 'test_helper'
2
+
3
+ class SerializerOverrideTest < Rails::Generators::TestCase
4
+ include GeneratorTestSupport
5
+
6
+ tests Rails::Generators::SerializerGenerator
7
+ destination File.join(Rails.root, "tmp")
8
+ setup :prepare_destination
9
+
10
+ test "create serializer under config/serializers" do
11
+ run_generator ["post"]
12
+ assert_file "#{config_path}/serializers/post_serializer.rb"
13
+ end
14
+
15
+ test "does not create serializer under app/serializers" do
16
+ run_generator ["post"]
17
+ assert_no_file "#{app_path}/serializers/post_serializer.rb"
18
+ end
19
+ end
@@ -11,30 +11,30 @@ class ViewGeneratorTest < Rails::Generators::TestCase
11
11
 
12
12
  test "create view with template by default" do
13
13
  run_generator ["post"]
14
- assert_file "#{app_path}/views/post.js.es6"
14
+ assert_file "#{app_path}/views/post.es6"
15
15
  assert_file "#{app_path}/templates/post.hbs"
16
16
  end
17
17
 
18
18
  test "create view without a template" do
19
19
  run_generator ["post", "--without-template"]
20
- assert_file "#{app_path}/views/post.js.es6"
20
+ assert_file "#{app_path}/views/post.es6"
21
21
  assert_no_file "#{app_path}/templates/post.hbs"
22
22
  end
23
23
 
24
24
  test "create view and template (using ember-rails flags)" do
25
25
  run_generator ["post", "--with-template"]
26
- assert_file "#{app_path}/views/post.js.es6"
26
+ assert_file "#{app_path}/views/post.es6"
27
27
  assert_file "#{app_path}/templates/post.hbs"
28
28
  end
29
29
 
30
30
  test "create namespaced view" do
31
31
  run_generator ["post/index"]
32
- assert_file "#{app_path}/views/post/index.js.es6"
32
+ assert_file "#{app_path}/views/post/index.es6"
33
33
  end
34
34
 
35
35
  test "Assert files are properly created" do
36
36
  run_generator %w(ember)
37
- assert_file "#{app_path}/views/ember.js.es6"
37
+ assert_file "#{app_path}/views/ember.es6"
38
38
  end
39
39
 
40
40
  test "Uses config.ember.appkit.paths.app" do
@@ -42,7 +42,7 @@ class ViewGeneratorTest < Rails::Generators::TestCase
42
42
 
43
43
  with_config paths: {app: custom_path} do
44
44
  run_generator [ "ember"]
45
- assert_file "#{custom_path}/views/ember.js.es6"
45
+ assert_file "#{custom_path}/views/ember.es6"
46
46
  end
47
47
  end
48
48
  end
@@ -5,6 +5,10 @@ class EngineTest < ActionDispatch::IntegrationTest
5
5
  refute Rails.application.config.assets.paths.include?(File.join(Rails.root, 'app/assets/javascripts'))
6
6
  end
7
7
 
8
+ test 'config/serializers is added to autoload_path' do
9
+ assert Rails.application.config.paths.eager_load.include?(File.join(Rails.root, 'config/serializers'))
10
+ end
11
+
8
12
  test 'app is in the asset load path' do
9
13
  assert Rails.application.config.assets.paths.include?(File.join(Rails.root, 'app'))
10
14
  end
@@ -71,10 +71,10 @@ module GeneratorTestSupport
71
71
  end
72
72
 
73
73
  def copy_router(path = config_path)
74
- source = File.expand_path("../../../lib/generators/templates/router.js.es6", __FILE__)
74
+ source = File.expand_path("../../../lib/generators/templates/router.es6", __FILE__)
75
75
  destination = File.join(destination_root, path)
76
76
  FileUtils.mkdir_p(destination)
77
- FileUtils.cp source, File.join(destination, 'router.js.es6')
77
+ FileUtils.cp source, File.join(destination, 'router.es6')
78
78
  end
79
79
 
80
80
  def copy_application(path = config_path)
@@ -1,10 +1,12 @@
1
1
  <% config = Rails.application.config.ember %>
2
- import Resolver from 'resolver';
2
+ import Resolver from 'ember/resolver';
3
3
 
4
4
  if (typeof Turbolinks !== 'undefined') {
5
5
  throw new Error("Turbolinks has been detected. Ember Appkit Rails will not function properly alongside Turbolinks.");
6
6
  }
7
7
 
8
+ if (window.config === undefined) { window.config = {}; }
9
+
8
10
  var App = Ember.Application.extend({
9
11
  Resolver: Resolver
10
12
  }, window.config);
@@ -1,5 +1,4 @@
1
1
  //= require ./loader
2
2
  //= require ./resolver
3
- //= require ./resolver_ext
4
3
  //= require app
5
4
  //= require templates/application
@@ -1,5 +1,5 @@
1
1
  // Fetched from: https://raw.github.com/stefanpenner/ember-jj-abrams-resolver/master/dist/ember-resolver.js
2
- // Fetched on: 2014-01-11T18:12:01
2
+ // Fetched on: 2014-03-07T00:18:39
3
3
  // ==========================================================================
4
4
  // Project: Ember - JavaScript Application Framework
5
5
  // Copyright: Copyright 2013 Stefan Penner and Ember App Kit Contributors
@@ -13,16 +13,21 @@
13
13
  (function() {
14
14
  /*globals define registry requirejs */
15
15
 
16
- define("resolver",
16
+ define("ember/resolver",
17
17
  [],
18
18
  function() {
19
19
  "use strict";
20
+
21
+ if (typeof requirejs.entries === 'undefined') {
22
+ requirejs.entries = requirejs._eak_seen;
23
+ }
24
+
20
25
  /*
21
26
  * This module defines a subclass of Ember.DefaultResolver that adds two
22
27
  * important features:
23
28
  *
24
29
  * 1) The resolver makes the container aware of es6 modules via the AMD
25
- * output. The loader's _seen is consulted so that classes can be
30
+ * output. The loader's _moduleEntries is consulted so that classes can be
26
31
  * resolved directly via the module loader, without needing a manual
27
32
  * `import`.
28
33
  * 2) is able provide injections to classes that implement `extend`
@@ -64,55 +69,88 @@ define("resolver",
64
69
  };
65
70
  }
66
71
 
67
- function chooseModuleName(seen, moduleName) {
72
+ function chooseModuleName(moduleEntries, moduleName) {
68
73
  var underscoredModuleName = Ember.String.underscore(moduleName);
69
74
 
70
- if (moduleName !== underscoredModuleName && seen[moduleName] && seen[underscoredModuleName]) {
75
+ if (moduleName !== underscoredModuleName && moduleEntries[moduleName] && moduleEntries[underscoredModuleName]) {
71
76
  throw new TypeError("Ambiguous module names: `" + moduleName + "` and `" + underscoredModuleName + "`");
72
77
  }
73
78
 
74
- if (seen[moduleName]) {
79
+ if (moduleEntries[moduleName]) {
75
80
  return moduleName;
76
- } else if (seen[underscoredModuleName]) {
81
+ } else if (moduleEntries[underscoredModuleName]) {
77
82
  return underscoredModuleName;
78
83
  } else {
79
- return moduleName;
84
+ var parts = moduleName.split('/'),
85
+ lastPart = parts[parts.length - 1],
86
+ partializedModuleName;
87
+
88
+ parts[parts.length - 1] = lastPart.replace(/^-/, '_');
89
+ partializedModuleName = parts.join('/');
90
+
91
+ if (moduleEntries[partializedModuleName]) {
92
+ Ember.deprecate('Modules should not contain underscores. ' +
93
+ 'Attempted to lookup "'+moduleName+'" which ' +
94
+ 'was not found. Please rename "'+partializedModuleName+'" '+
95
+ 'to "'+moduleName+'" instead.', false);
96
+
97
+ return partializedModuleName;
98
+ } else {
99
+ return moduleName;
100
+ }
80
101
  }
81
102
  }
82
103
 
83
- function resolveRouter(parsedName) {
84
- /*jshint validthis:true */
85
-
86
- var prefix = this.namespace.modulePrefix,
87
- routerModule;
104
+ function logLookup(found, parsedName, moduleName) {
105
+ if (Ember.ENV.LOG_MODULE_RESOLVER) {
106
+ var symbol;
88
107
 
89
- if (parsedName.fullName === 'router:main') {
90
- // for now, lets keep the router at app/router.js
91
- if (requirejs._eak_seen[prefix + '/router']) {
92
- routerModule = require(prefix + '/router');
93
- if (routerModule['default']) { routerModule = routerModule['default']; }
108
+ if (found) { symbol = '[✓]'; }
109
+ else { symbol = '[ ]'; }
94
110
 
95
- return routerModule;
96
- }
111
+ Ember.Logger.info(symbol, parsedName.fullName, new Array(40 - parsedName.fullName.length).join('.'), moduleName);
97
112
  }
98
113
  }
99
114
 
100
115
  function resolveOther(parsedName) {
101
116
  /*jshint validthis:true */
102
117
 
103
- var prefix = this.namespace.modulePrefix;
118
+ var moduleName, tmpModuleName, prefix, podPrefix, moduleEntries;
119
+
120
+ prefix = this.namespace.modulePrefix;
121
+ podPrefix = this.namespace.podModulePrefix || prefix;
122
+ moduleEntries = requirejs.entries;
123
+
104
124
  Ember.assert('module prefix must be defined', prefix);
105
125
 
106
126
  var pluralizedType = parsedName.type + 's';
107
127
  var name = parsedName.fullNameWithoutType;
108
128
 
109
- var moduleName = prefix + '/' + pluralizedType + '/' + name;
129
+ // lookup using POD formatting first
130
+ tmpModuleName = podPrefix + '/' + name + '/' + parsedName.type;
131
+ if (moduleEntries[tmpModuleName]) {
132
+ moduleName = tmpModuleName;
133
+ }
134
+
135
+ // if not using POD format, use the custom prefix
136
+ if (this.namespace[parsedName.type + 'Prefix']) {
137
+ prefix = this.namespace[parsedName.type + 'Prefix'];
138
+ }
139
+
140
+ // if router:main or adapter:main look for a module with just the type first
141
+ tmpModuleName = prefix + '/' + parsedName.type;
142
+ if (!moduleName && name === 'main' && moduleEntries[tmpModuleName]) {
143
+ moduleName = prefix + '/' + parsedName.type;
144
+ }
145
+
146
+ // fallback if not type:main or POD format
147
+ if (!moduleName) { moduleName = prefix + '/' + pluralizedType + '/' + name; }
110
148
 
111
149
  // allow treat all dashed and all underscored as the same thing
112
150
  // supports components with dashes and other stuff with underscores.
113
- var normalizedModuleName = chooseModuleName(requirejs._eak_seen, moduleName);
151
+ var normalizedModuleName = chooseModuleName(moduleEntries, moduleName);
114
152
 
115
- if (requirejs._eak_seen[normalizedModuleName]) {
153
+ if (moduleEntries[normalizedModuleName]) {
116
154
  var module = require(normalizedModuleName, null, null, true /* force sync */);
117
155
 
118
156
  if (module && module['default']) { module = module['default']; }
@@ -125,24 +163,66 @@ define("resolver",
125
163
  module = classFactory(module);
126
164
  }
127
165
 
128
- if (Ember.ENV.LOG_MODULE_RESOLVER) {
129
- Ember.Logger.info('[✓]', parsedName.fullName, new Array(40 - parsedName.fullName.length).join('.'), moduleName);
130
- }
166
+ logLookup(true, parsedName, moduleName);
131
167
 
132
168
  return module;
133
169
  } else {
134
- if (Ember.ENV.LOG_MODULE_RESOLVER) {
135
- Ember.Logger.info('[ ]', parsedName.fullName, new Array(40 - parsedName.fullName.length).join('.'), moduleName);
136
- }
170
+ logLookup(false, parsedName, moduleName);
171
+
137
172
  return this._super(parsedName);
138
173
  }
139
174
  }
140
175
  // Ember.DefaultResolver docs:
141
176
  // https://github.com/emberjs/ember.js/blob/master/packages/ember-application/lib/system/resolver.js
142
177
  var Resolver = Ember.DefaultResolver.extend({
143
- resolveTemplate: resolveOther,
144
178
  resolveOther: resolveOther,
145
- resolveRouter: resolveRouter,
179
+ resolveTemplate: resolveOther,
180
+ /**
181
+ This method is called via the container's resolver method.
182
+ It parses the provided `fullName` and then looks up and
183
+ returns the appropriate template or class.
184
+
185
+ @method resolve
186
+ @param {String} fullName the lookup string
187
+ @return {Object} the resolved factory
188
+ */
189
+ resolve: function(fullName) {
190
+ var parsedName = this.parseName(fullName),
191
+ resolveMethodName = parsedName.resolveMethodName;
192
+
193
+ if (!(parsedName.name && parsedName.type)) {
194
+ throw new TypeError("Invalid fullName: `" + fullName + "`, must be of the form `type:name` ");
195
+ }
196
+
197
+ if (this[resolveMethodName]) {
198
+ var resolved = this[resolveMethodName](parsedName);
199
+ if (resolved) { return resolved; }
200
+ }
201
+ return this.resolveOther(parsedName);
202
+ },
203
+ /**
204
+ Returns a human-readable description for a fullName. Used by the
205
+ Application namespace in assertions to describe the
206
+ precise name of the class that Ember is looking for, rather than
207
+ container keys.
208
+
209
+ @protected
210
+ @param {String} fullName the lookup string
211
+ @method lookupDescription
212
+ */
213
+ lookupDescription: function(fullName) {
214
+ var parsedName = this.parseName(fullName);
215
+
216
+ if (parsedName.type === 'template') {
217
+ return "template at " + parsedName.fullNameWithoutType.replace(/\./g, '/');
218
+ }
219
+
220
+ var description = parsedName.root + "." + classify(parsedName.name);
221
+ if (parsedName.type !== 'model') { description += classify(parsedName.type); }
222
+
223
+ return description;
224
+ },
225
+
146
226
  makeToString: function(factory, fullName) {
147
227
  return '' + this.namespace.modulePrefix + '@' + fullName + ':';
148
228
  },
@@ -168,6 +248,129 @@ define("resolver",
168
248
  return Resolver;
169
249
  });
170
250
 
251
+ define("resolver",
252
+ ["ember/resolver"],
253
+ function (Resolver) {
254
+ Ember.deprecate('Importing/requiring Ember Resolver as "resolver" is deprecated, please use "ember/resolver" instead');
255
+ return Resolver;
256
+ });
257
+
258
+ })();
259
+
260
+
261
+
262
+ (function() {
263
+ /*globals define registry requirejs */
264
+
265
+ define("ember/container-debug-adapter",
266
+ [],
267
+ function() {
268
+ "use strict";
269
+
270
+ // Support Ember < 1.5-beta.4
271
+ // TODO: Remove this after 1.5.0 is released
272
+ if (typeof Ember.ContainerDebugAdapter === 'undefined') {
273
+ return null;
274
+ }
275
+ /*
276
+ * This module defines a subclass of Ember.ContainerDebugAdapter that adds two
277
+ * important features:
278
+ *
279
+ * 1) is able provide injections to classes that implement `extend`
280
+ * (as is typical with Ember).
281
+ */
282
+
283
+ var ContainerDebugAdapter = Ember.ContainerDebugAdapter.extend({
284
+ /**
285
+ The container of the application being debugged.
286
+ This property will be injected
287
+ on creation.
288
+
289
+ @property container
290
+ @default null
291
+ */
292
+ // container: null, LIVES IN PARENT
293
+
294
+ /**
295
+ The resolver instance of the application
296
+ being debugged. This property will be injected
297
+ on creation.
298
+
299
+ @property resolver
300
+ @default null
301
+ */
302
+ // resolver: null, LIVES IN PARENT
303
+ /**
304
+ Returns true if it is possible to catalog a list of available
305
+ classes in the resolver for a given type.
306
+
307
+ @method canCatalogEntriesByType
308
+ @param {string} type The type. e.g. "model", "controller", "route"
309
+ @return {boolean} whether a list is available for this type.
310
+ */
311
+ canCatalogEntriesByType: function(type) {
312
+ return true;
313
+ },
314
+
315
+ /**
316
+ Returns the available classes a given type.
317
+
318
+ @method catalogEntriesByType
319
+ @param {string} type The type. e.g. "model", "controller", "route"
320
+ @return {Array} An array of classes.
321
+ */
322
+ catalogEntriesByType: function(type) {
323
+ var entries = requirejs.entries,
324
+ module,
325
+ types = Ember.A();
326
+
327
+ var makeToString = function(){
328
+ return this.shortname;
329
+ };
330
+
331
+ for(var key in entries) {
332
+ if(entries.hasOwnProperty(key) && key.indexOf(type) !== -1)
333
+ {
334
+ // // TODO return the name instead of the module itself
335
+ // module = require(key, null, null, true);
336
+
337
+ // if (module && module['default']) { module = module['default']; }
338
+ // module.shortname = key.split(type +'s/').pop();
339
+ // module.toString = makeToString;
340
+
341
+ // types.push(module);
342
+ types.push(key.split(type +'s/').pop());
343
+ }
344
+ }
345
+
346
+ return types;
347
+ }
348
+ });
349
+
350
+ ContainerDebugAdapter['default'] = ContainerDebugAdapter;
351
+ return ContainerDebugAdapter;
352
+ });
353
+
354
+ })();
355
+
356
+
357
+
358
+ (function() {
359
+ (function() {
360
+ "use strict";
361
+
362
+ Ember.Application.initializer({
363
+ name: 'container-debug-adapter',
364
+
365
+ initialize: function(container) {
366
+ var ContainerDebugAdapter = require('ember/container-debug-adapter');
367
+ var Resolver = require('ember/resolver');
368
+
369
+ container.register('container-debug-adapter:main', ContainerDebugAdapter);
370
+ }
371
+ });
372
+ }());
373
+
171
374
  })();
172
375
 
173
376