teaspoon 0.9.1 → 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (214) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +141 -0
  3. data/README.md +9 -19
  4. data/{vendor → app}/assets/javascripts/support/bind-poly.js +0 -0
  5. data/{vendor → app}/assets/javascripts/support/sinon.js +0 -0
  6. data/app/assets/javascripts/teaspoon-filterer.js +55 -0
  7. data/app/assets/javascripts/teaspoon/error.coffee +5 -0
  8. data/app/assets/javascripts/teaspoon/{base/fixture.coffee → fixture.coffee} +15 -15
  9. data/app/assets/javascripts/teaspoon/{base/hook.coffee → hook.coffee} +0 -0
  10. data/app/assets/javascripts/teaspoon/{base/reporters → reporters}/console.coffee +18 -10
  11. data/app/assets/javascripts/teaspoon/{base/reporters → reporters}/html.coffee +43 -40
  12. data/app/assets/javascripts/teaspoon/{base/reporters → reporters}/html/base_view.coffee +0 -0
  13. data/app/assets/javascripts/teaspoon/{base/reporters → reporters}/html/failure_view.coffee +2 -0
  14. data/app/assets/javascripts/teaspoon/reporters/html/progress_view.coffee +18 -0
  15. data/app/assets/javascripts/teaspoon/{base/reporters/html/progress_view.coffee → reporters/html/radial_progress_view.coffee} +1 -34
  16. data/app/assets/javascripts/teaspoon/reporters/html/simple_progress_view.coffee +15 -0
  17. data/app/assets/javascripts/teaspoon/{base/reporters → reporters}/html/spec_view.coffee +5 -3
  18. data/app/assets/javascripts/teaspoon/{base/reporters → reporters}/html/suite_view.coffee +4 -2
  19. data/app/assets/javascripts/teaspoon/{base/reporters → reporters}/html/template.coffee +0 -0
  20. data/app/assets/javascripts/teaspoon/{base/runner.coffee → runner.coffee} +7 -3
  21. data/app/assets/javascripts/teaspoon/teaspoon.coffee +90 -32
  22. data/app/controllers/teaspoon/suite_controller.rb +5 -0
  23. data/app/views/teaspoon/suite/index.html.erb +1 -1
  24. data/lib/generators/teaspoon/install/install_generator.rb +67 -37
  25. data/lib/generators/teaspoon/install/templates/MISSING_FRAMEWORK +14 -0
  26. data/lib/generators/teaspoon/install/{POST_INSTALL → templates/POST_INSTALL} +0 -0
  27. data/lib/generators/teaspoon/install/templates/env.rb.tt +14 -0
  28. data/lib/generators/teaspoon/install/templates/{jasmine/env_comments.rb.tt → env_comments.rb.tt} +34 -43
  29. data/lib/tasks/teaspoon/info.rake +17 -0
  30. data/lib/teaspoon-devkit.rb +61 -0
  31. data/lib/teaspoon.rb +2 -0
  32. data/lib/teaspoon/command_line.rb +19 -14
  33. data/lib/teaspoon/configuration.rb +24 -35
  34. data/lib/teaspoon/console.rb +11 -21
  35. data/lib/teaspoon/coverage.rb +14 -7
  36. data/lib/teaspoon/deprecated.rb +22 -4
  37. data/lib/teaspoon/driver.rb +15 -0
  38. data/lib/teaspoon/driver/base.rb +7 -0
  39. data/lib/teaspoon/{drivers/capybara_webkit_driver.rb → driver/capybara_webkit.rb} +8 -5
  40. data/lib/teaspoon/{drivers/phantomjs_driver.rb → driver/phantomjs.rb} +8 -4
  41. data/lib/teaspoon/{drivers → driver}/phantomjs/runner.js +0 -0
  42. data/lib/teaspoon/{drivers/selenium_driver.rb → driver/selenium.rb} +11 -9
  43. data/lib/teaspoon/engine.rb +38 -25
  44. data/lib/teaspoon/environment.rb +24 -15
  45. data/lib/teaspoon/exceptions.rb +154 -41
  46. data/lib/teaspoon/exporter.rb +2 -2
  47. data/lib/teaspoon/formatter.rb +30 -0
  48. data/lib/teaspoon/{formatters → formatter}/base.rb +2 -36
  49. data/lib/teaspoon/{formatters/clean_formatter.rb → formatter/clean.rb} +4 -2
  50. data/lib/teaspoon/{formatters/documentation_formatter.rb → formatter/documentation.rb} +4 -3
  51. data/lib/teaspoon/{formatters/dot_formatter.rb → formatter/dot.rb} +4 -3
  52. data/lib/teaspoon/{formatters/json_formatter.rb → formatter/json.rb} +4 -2
  53. data/lib/teaspoon/{formatters/junit_formatter.rb → formatter/junit.rb} +3 -2
  54. data/lib/teaspoon/{formatters → formatter}/modules/report_module.rb +1 -1
  55. data/lib/teaspoon/{formatters/pride_formatter.rb → formatter/pride.rb} +4 -2
  56. data/lib/teaspoon/{formatters/rspec_html_formatter.rb → formatter/rspec_html.rb} +3 -2
  57. data/lib/teaspoon/{formatters/snowday_formatter.rb → formatter/snowday.rb} +3 -2
  58. data/lib/teaspoon/formatter/swayze_or_oprah.rb +111 -0
  59. data/lib/teaspoon/{formatters/tap_formatter.rb → formatter/tap.rb} +4 -2
  60. data/lib/teaspoon/{formatters/tap_y_formatter.rb → formatter/tap_y.rb} +3 -2
  61. data/lib/teaspoon/{formatters/teamcity_formatter.rb → formatter/teamcity.rb} +4 -2
  62. data/lib/teaspoon/framework.rb +17 -0
  63. data/lib/teaspoon/framework/base.rb +88 -0
  64. data/lib/teaspoon/instrumentation.rb +12 -2
  65. data/lib/teaspoon/registry.rb +47 -0
  66. data/lib/teaspoon/registry/has_default.rb +11 -0
  67. data/lib/teaspoon/runner.rb +6 -7
  68. data/lib/teaspoon/server.rb +2 -2
  69. data/lib/teaspoon/suite.rb +28 -30
  70. data/lib/teaspoon/utility.rb +5 -0
  71. data/lib/teaspoon/version.rb +1 -1
  72. metadata +52 -276
  73. data/app/assets/javascripts/teaspoon-jasmine.js +0 -1344
  74. data/app/assets/javascripts/teaspoon-mocha.js +0 -1350
  75. data/app/assets/javascripts/teaspoon-qunit.js +0 -1415
  76. data/app/assets/javascripts/teaspoon-teaspoon.js +0 -51
  77. data/app/assets/javascripts/teaspoon/base/teaspoon.coffee +0 -69
  78. data/app/assets/javascripts/teaspoon/jasmine.coffee +0 -119
  79. data/app/assets/javascripts/teaspoon/jasmine/reporters/html.coffee +0 -11
  80. data/app/assets/javascripts/teaspoon/mocha.coffee +0 -90
  81. data/app/assets/javascripts/teaspoon/mocha/reporters/console.coffee +0 -16
  82. data/app/assets/javascripts/teaspoon/mocha/reporters/html.coffee +0 -27
  83. data/app/assets/javascripts/teaspoon/qunit.coffee +0 -81
  84. data/app/assets/javascripts/teaspoon/qunit/reporters/console.coffee +0 -25
  85. data/app/assets/javascripts/teaspoon/qunit/reporters/html.coffee +0 -80
  86. data/lib/generators/teaspoon/install/templates/jasmine/env.rb +0 -11
  87. data/lib/generators/teaspoon/install/templates/jasmine/spec_helper.coffee +0 -31
  88. data/lib/generators/teaspoon/install/templates/jasmine/spec_helper.js +0 -31
  89. data/lib/generators/teaspoon/install/templates/mocha/env.rb +0 -11
  90. data/lib/generators/teaspoon/install/templates/mocha/env_comments.rb.tt +0 -187
  91. data/lib/generators/teaspoon/install/templates/mocha/spec_helper.coffee +0 -40
  92. data/lib/generators/teaspoon/install/templates/mocha/spec_helper.js +0 -40
  93. data/lib/generators/teaspoon/install/templates/qunit/env.rb +0 -11
  94. data/lib/generators/teaspoon/install/templates/qunit/env_comments.rb.tt +0 -187
  95. data/lib/generators/teaspoon/install/templates/qunit/test_helper.coffee +0 -29
  96. data/lib/generators/teaspoon/install/templates/qunit/test_helper.js +0 -30
  97. data/lib/teaspoon/drivers/base.rb +0 -10
  98. data/lib/teaspoon/formatters/description.rb +0 -36
  99. data/lib/teaspoon/formatters/swayze_or_oprah_formatter.rb +0 -101
  100. data/spec/dummy/Rakefile +0 -7
  101. data/spec/dummy/app/assets/javascripts/instrumented1.coffee +0 -1
  102. data/spec/dummy/app/assets/javascripts/instrumented2.coffee +0 -1
  103. data/spec/dummy/app/assets/javascripts/integration/integration.coffee +0 -1
  104. data/spec/dummy/app/assets/javascripts/integration/integration_spec.coffee +0 -32
  105. data/spec/dummy/app/assets/javascripts/integration/spec_helper.coffee +0 -7
  106. data/spec/dummy/app/assets/javascripts/specs/asset_spec.js +0 -11
  107. data/spec/dummy/config.ru +0 -15
  108. data/spec/dummy/config/application.rb +0 -29
  109. data/spec/dummy/config/boot.rb +0 -3
  110. data/spec/dummy/config/environment.rb +0 -5
  111. data/spec/dummy/config/environments/development.rb +0 -41
  112. data/spec/dummy/config/environments/production.rb +0 -79
  113. data/spec/dummy/config/environments/test.rb +0 -42
  114. data/spec/dummy/config/routes.rb +0 -2
  115. data/spec/dummy/config/secrets.yml +0 -22
  116. data/spec/dummy/log/.gitkeep +0 -0
  117. data/spec/dummy/public/favicon.ico +0 -0
  118. data/spec/dummy/script/rails +0 -6
  119. data/spec/features/console_reporter_spec.rb +0 -62
  120. data/spec/features/hooks_spec.rb +0 -60
  121. data/spec/features/html_reporter_spec.rb +0 -81
  122. data/spec/features/install_generator_spec.rb +0 -54
  123. data/spec/features/instrumentation_spec.rb +0 -21
  124. data/spec/fixtures/coverage.json +0 -243
  125. data/spec/javascripts/fixtures/_body.html.erb +0 -1
  126. data/spec/javascripts/fixtures/fixture.html.haml +0 -4
  127. data/spec/javascripts/fixtures/fixture.json +0 -4
  128. data/spec/javascripts/jasmine_helper.coffee +0 -3
  129. data/spec/javascripts/mocha_helper.coffee +0 -4
  130. data/spec/javascripts/spec_helper.coffee +0 -7
  131. data/spec/javascripts/stylesheets/stylesheet.css.scss +0 -0
  132. data/spec/javascripts/support/json2.js +0 -486
  133. data/spec/javascripts/support/support.js.coffee +0 -0
  134. data/spec/javascripts/teaspoon/base/fixture_spec.coffee +0 -93
  135. data/spec/javascripts/teaspoon/base/reporters/console_spec.coffee +0 -162
  136. data/spec/javascripts/teaspoon/base/reporters/html/base_view_spec.coffee +0 -88
  137. data/spec/javascripts/teaspoon/base/reporters/html/failure_view_spec.coffee +0 -28
  138. data/spec/javascripts/teaspoon/base/reporters/html/progress_view_spec.coffee +0 -1
  139. data/spec/javascripts/teaspoon/base/reporters/html/spec_view_spec.coffee +0 -1
  140. data/spec/javascripts/teaspoon/base/reporters/html/suite_view_spec.coffee +0 -1
  141. data/spec/javascripts/teaspoon/base/reporters/html_spec.coffee +0 -372
  142. data/spec/javascripts/teaspoon/base/runner_spec.coffee +0 -58
  143. data/spec/javascripts/teaspoon/base/teaspoon_spec.coffee +0 -47
  144. data/spec/javascripts/teaspoon/jasmine/fixture_jspec.coffee +0 -13
  145. data/spec/javascripts/teaspoon/jasmine/models_jspec.coffee +0 -101
  146. data/spec/javascripts/teaspoon/jasmine/reporters/html_jspec.coffee +0 -17
  147. data/spec/javascripts/teaspoon/jasmine/runner_jspec.coffee +0 -59
  148. data/spec/javascripts/teaspoon/jasmine/spec_jspec.coffee +0 -3
  149. data/spec/javascripts/teaspoon/mocha/fixture_mspec.coffee +0 -12
  150. data/spec/javascripts/teaspoon/mocha/models_mspec.coffee +0 -93
  151. data/spec/javascripts/teaspoon/mocha/reporters/console_mspec.coffee +0 -24
  152. data/spec/javascripts/teaspoon/mocha/reporters/html_mspec.coffee +0 -41
  153. data/spec/javascripts/teaspoon/mocha/runner_mspec.coffee +0 -23
  154. data/spec/javascripts/teaspoon/mocha/spec_mspec.coffee +0 -9
  155. data/spec/javascripts/teaspoon/other/erb_spec.js.coffee.erb +0 -4
  156. data/spec/javascripts/teaspoon/phantomjs/runner_spec.coffee +0 -161
  157. data/spec/javascripts/turbolinks_helper.coffee +0 -2
  158. data/spec/spec_helper.rb +0 -25
  159. data/spec/support/aruba.rb +0 -15
  160. data/spec/teaspoon/command_line_spec.rb +0 -157
  161. data/spec/teaspoon/configuration_spec.rb +0 -236
  162. data/spec/teaspoon/console_spec.rb +0 -224
  163. data/spec/teaspoon/coverage_spec.rb +0 -118
  164. data/spec/teaspoon/drivers/base_spec.rb +0 -5
  165. data/spec/teaspoon/drivers/capybara_webkit_driver_spec.rb +0 -39
  166. data/spec/teaspoon/drivers/phantomjs_driver_spec.rb +0 -66
  167. data/spec/teaspoon/drivers/selenium_driver_spec.rb +0 -68
  168. data/spec/teaspoon/engine_spec.rb +0 -22
  169. data/spec/teaspoon/environment_spec.rb +0 -109
  170. data/spec/teaspoon/exceptions_spec.rb +0 -57
  171. data/spec/teaspoon/exporter_spec.rb +0 -96
  172. data/spec/teaspoon/formatters/base_spec.rb +0 -259
  173. data/spec/teaspoon/formatters/clean_formatter_spec.rb +0 -37
  174. data/spec/teaspoon/formatters/documentation_formatter_spec.rb +0 -127
  175. data/spec/teaspoon/formatters/dot_formatter_spec.rb +0 -116
  176. data/spec/teaspoon/formatters/json_formatter_spec.rb +0 -77
  177. data/spec/teaspoon/formatters/junit_formatter_spec.rb +0 -114
  178. data/spec/teaspoon/formatters/pride_formatter_spec.rb +0 -37
  179. data/spec/teaspoon/formatters/rspec_html_formatter_spec.rb +0 -107
  180. data/spec/teaspoon/formatters/snowday_formatter_spec.rb +0 -35
  181. data/spec/teaspoon/formatters/tap_formatter_spec.rb +0 -72
  182. data/spec/teaspoon/formatters/tap_y_formatter_spec.rb +0 -80
  183. data/spec/teaspoon/formatters/teamcity_formatter_spec.rb +0 -148
  184. data/spec/teaspoon/instrumentation_spec.rb +0 -113
  185. data/spec/teaspoon/result_spec.rb +0 -98
  186. data/spec/teaspoon/runner_spec.rb +0 -116
  187. data/spec/teaspoon/server_spec.rb +0 -105
  188. data/spec/teaspoon/suite_spec.rb +0 -138
  189. data/spec/teaspoon_env.rb +0 -39
  190. data/test/javascripts/qunit_helper.coffee +0 -3
  191. data/test/javascripts/teaspoon/qunit/fixture_test.coffee +0 -10
  192. data/test/javascripts/teaspoon/qunit/models_test.coffee +0 -66
  193. data/test/javascripts/teaspoon/qunit/reporters/console_test.coffee +0 -3
  194. data/test/javascripts/teaspoon/qunit/reporters/html/failure_view_test.coffee +0 -3
  195. data/test/javascripts/teaspoon/qunit/reporters/html/spec_view_test.coffee +0 -3
  196. data/test/javascripts/teaspoon/qunit/reporters/html/suite_view_test.coffee +0 -3
  197. data/test/javascripts/teaspoon/qunit/reporters/html_test.coffee +0 -3
  198. data/test/javascripts/teaspoon/qunit/runner_test.coffee +0 -18
  199. data/vendor/assets/javascripts/jasmine/1.3.1.js +0 -2602
  200. data/vendor/assets/javascripts/jasmine/2.0.0.js +0 -2412
  201. data/vendor/assets/javascripts/jasmine/MIT.LICENSE +0 -20
  202. data/vendor/assets/javascripts/mocha/1.10.0.js +0 -5374
  203. data/vendor/assets/javascripts/mocha/1.17.1.js +0 -5813
  204. data/vendor/assets/javascripts/mocha/MIT.LICENSE +0 -22
  205. data/vendor/assets/javascripts/qunit/1.12.0.js +0 -2212
  206. data/vendor/assets/javascripts/qunit/1.14.0.js +0 -2288
  207. data/vendor/assets/javascripts/qunit/MIT.LICENSE +0 -21
  208. data/vendor/assets/javascripts/support/chai-1.10.0.js +0 -4800
  209. data/vendor/assets/javascripts/support/chai-jq-0.0.7.js +0 -524
  210. data/vendor/assets/javascripts/support/chai.js +0 -4782
  211. data/vendor/assets/javascripts/support/expect.js +0 -1284
  212. data/vendor/assets/javascripts/support/jasmine-jquery-1.7.0.js +0 -720
  213. data/vendor/assets/javascripts/support/jasmine-jquery-2.0.0.js +0 -812
  214. data/vendor/assets/javascripts/support/sinon-chai.js +0 -126
@@ -1,812 +0,0 @@
1
- /*!
2
- Jasmine-jQuery: a set of jQuery helpers for Jasmine tests.
3
-
4
- Version 2.0.2
5
-
6
- https://github.com/velesin/jasmine-jquery
7
-
8
- Copyright (c) 2010-2014 Wojciech Zawistowski, Travis Jeffery
9
-
10
- Permission is hereby granted, free of charge, to any person obtaining
11
- a copy of this software and associated documentation files (the
12
- "Software"), to deal in the Software without restriction, including
13
- without limitation the rights to use, copy, modify, merge, publish,
14
- distribute, sublicense, and/or sell copies of the Software, and to
15
- permit persons to whom the Software is furnished to do so, subject to
16
- the following conditions:
17
-
18
- The above copyright notice and this permission notice shall be
19
- included in all copies or substantial portions of the Software.
20
-
21
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
22
- EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
23
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
24
- NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
25
- LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26
- OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
27
- WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28
- */
29
-
30
- +function (window, jasmine, $) { "use strict";
31
-
32
- jasmine.spiedEventsKey = function (selector, eventName) {
33
- return [$(selector).selector, eventName].toString()
34
- }
35
-
36
- jasmine.getFixtures = function () {
37
- return jasmine.currentFixtures_ = jasmine.currentFixtures_ || new jasmine.Fixtures()
38
- }
39
-
40
- jasmine.getStyleFixtures = function () {
41
- return jasmine.currentStyleFixtures_ = jasmine.currentStyleFixtures_ || new jasmine.StyleFixtures()
42
- }
43
-
44
- jasmine.Fixtures = function () {
45
- this.containerId = 'jasmine-fixtures'
46
- this.fixturesCache_ = {}
47
- this.fixturesPath = 'spec/javascripts/fixtures'
48
- }
49
-
50
- jasmine.Fixtures.prototype.set = function (html) {
51
- this.cleanUp()
52
- return this.createContainer_(html)
53
- }
54
-
55
- jasmine.Fixtures.prototype.appendSet= function (html) {
56
- this.addToContainer_(html)
57
- }
58
-
59
- jasmine.Fixtures.prototype.preload = function () {
60
- this.read.apply(this, arguments)
61
- }
62
-
63
- jasmine.Fixtures.prototype.load = function () {
64
- this.cleanUp()
65
- this.createContainer_(this.read.apply(this, arguments))
66
- }
67
-
68
- jasmine.Fixtures.prototype.appendLoad = function () {
69
- this.addToContainer_(this.read.apply(this, arguments))
70
- }
71
-
72
- jasmine.Fixtures.prototype.read = function () {
73
- var htmlChunks = []
74
- , fixtureUrls = arguments
75
-
76
- for(var urlCount = fixtureUrls.length, urlIndex = 0; urlIndex < urlCount; urlIndex++) {
77
- htmlChunks.push(this.getFixtureHtml_(fixtureUrls[urlIndex]))
78
- }
79
-
80
- return htmlChunks.join('')
81
- }
82
-
83
- jasmine.Fixtures.prototype.clearCache = function () {
84
- this.fixturesCache_ = {}
85
- }
86
-
87
- jasmine.Fixtures.prototype.cleanUp = function () {
88
- $('#' + this.containerId).remove()
89
- }
90
-
91
- jasmine.Fixtures.prototype.sandbox = function (attributes) {
92
- var attributesToSet = attributes || {}
93
- return $('<div id="sandbox" />').attr(attributesToSet)
94
- }
95
-
96
- jasmine.Fixtures.prototype.createContainer_ = function (html) {
97
- var container = $('<div>')
98
- .attr('id', this.containerId)
99
- .html(html)
100
-
101
- $(document.body).append(container)
102
- return container
103
- }
104
-
105
- jasmine.Fixtures.prototype.addToContainer_ = function (html){
106
- var container = $(document.body).find('#'+this.containerId).append(html)
107
-
108
- if (!container.length) {
109
- this.createContainer_(html)
110
- }
111
- }
112
-
113
- jasmine.Fixtures.prototype.getFixtureHtml_ = function (url) {
114
- if (typeof this.fixturesCache_[url] === 'undefined') {
115
- this.loadFixtureIntoCache_(url)
116
- }
117
- return this.fixturesCache_[url]
118
- }
119
-
120
- jasmine.Fixtures.prototype.loadFixtureIntoCache_ = function (relativeUrl) {
121
- var self = this
122
- , url = this.makeFixtureUrl_(relativeUrl)
123
- , htmlText = ''
124
- , request = $.ajax({
125
- async: false, // must be synchronous to guarantee that no tests are run before fixture is loaded
126
- cache: false,
127
- url: url,
128
- success: function (data, status, $xhr) {
129
- htmlText = $xhr.responseText
130
- }
131
- }).fail(function () {
132
- throw new Error('Fixture could not be loaded: ' + url + ' (status: ' + status + ', message: ' + errorThrown.message + ')')
133
- })
134
-
135
- var scripts = $($.parseHTML(htmlText, true)).find('script[src]') || [];
136
-
137
- scripts.each(function(){
138
- $.ajax({
139
- async: false, // must be synchronous to guarantee that no tests are run before fixture is loaded
140
- cache: false,
141
- dataType: 'script',
142
- url: $(this).attr('src'),
143
- success: function (data, status, $xhr) {
144
- htmlText += '<script>' + $xhr.responseText + '</script>'
145
- },
146
- error: function (jqXHR, status, errorThrown) {
147
- throw new Error('Script could not be loaded: ' + scriptSrc + ' (status: ' + status + ', message: ' + errorThrown.message + ')')
148
- }
149
- });
150
- })
151
-
152
- self.fixturesCache_[relativeUrl] = htmlText;
153
- }
154
-
155
- jasmine.Fixtures.prototype.makeFixtureUrl_ = function (relativeUrl){
156
- return this.fixturesPath.match('/$') ? this.fixturesPath + relativeUrl : this.fixturesPath + '/' + relativeUrl
157
- }
158
-
159
- jasmine.Fixtures.prototype.proxyCallTo_ = function (methodName, passedArguments) {
160
- return this[methodName].apply(this, passedArguments)
161
- }
162
-
163
-
164
- jasmine.StyleFixtures = function () {
165
- this.fixturesCache_ = {}
166
- this.fixturesNodes_ = []
167
- this.fixturesPath = 'spec/javascripts/fixtures'
168
- }
169
-
170
- jasmine.StyleFixtures.prototype.set = function (css) {
171
- this.cleanUp()
172
- this.createStyle_(css)
173
- }
174
-
175
- jasmine.StyleFixtures.prototype.appendSet = function (css) {
176
- this.createStyle_(css)
177
- }
178
-
179
- jasmine.StyleFixtures.prototype.preload = function () {
180
- this.read_.apply(this, arguments)
181
- }
182
-
183
- jasmine.StyleFixtures.prototype.load = function () {
184
- this.cleanUp()
185
- this.createStyle_(this.read_.apply(this, arguments))
186
- }
187
-
188
- jasmine.StyleFixtures.prototype.appendLoad = function () {
189
- this.createStyle_(this.read_.apply(this, arguments))
190
- }
191
-
192
- jasmine.StyleFixtures.prototype.cleanUp = function () {
193
- while(this.fixturesNodes_.length) {
194
- this.fixturesNodes_.pop().remove()
195
- }
196
- }
197
-
198
- jasmine.StyleFixtures.prototype.createStyle_ = function (html) {
199
- var styleText = $('<div></div>').html(html).text()
200
- , style = $('<style>' + styleText + '</style>')
201
-
202
- this.fixturesNodes_.push(style)
203
- $('head').append(style)
204
- }
205
-
206
- jasmine.StyleFixtures.prototype.clearCache = jasmine.Fixtures.prototype.clearCache
207
- jasmine.StyleFixtures.prototype.read_ = jasmine.Fixtures.prototype.read
208
- jasmine.StyleFixtures.prototype.getFixtureHtml_ = jasmine.Fixtures.prototype.getFixtureHtml_
209
- jasmine.StyleFixtures.prototype.loadFixtureIntoCache_ = jasmine.Fixtures.prototype.loadFixtureIntoCache_
210
- jasmine.StyleFixtures.prototype.makeFixtureUrl_ = jasmine.Fixtures.prototype.makeFixtureUrl_
211
- jasmine.StyleFixtures.prototype.proxyCallTo_ = jasmine.Fixtures.prototype.proxyCallTo_
212
-
213
- jasmine.getJSONFixtures = function () {
214
- return jasmine.currentJSONFixtures_ = jasmine.currentJSONFixtures_ || new jasmine.JSONFixtures()
215
- }
216
-
217
- jasmine.JSONFixtures = function () {
218
- this.fixturesCache_ = {}
219
- this.fixturesPath = 'spec/javascripts/fixtures/json'
220
- }
221
-
222
- jasmine.JSONFixtures.prototype.load = function () {
223
- this.read.apply(this, arguments)
224
- return this.fixturesCache_
225
- }
226
-
227
- jasmine.JSONFixtures.prototype.read = function () {
228
- var fixtureUrls = arguments
229
-
230
- for(var urlCount = fixtureUrls.length, urlIndex = 0; urlIndex < urlCount; urlIndex++) {
231
- this.getFixtureData_(fixtureUrls[urlIndex])
232
- }
233
-
234
- return this.fixturesCache_
235
- }
236
-
237
- jasmine.JSONFixtures.prototype.clearCache = function () {
238
- this.fixturesCache_ = {}
239
- }
240
-
241
- jasmine.JSONFixtures.prototype.getFixtureData_ = function (url) {
242
- if (!this.fixturesCache_[url]) this.loadFixtureIntoCache_(url)
243
- return this.fixturesCache_[url]
244
- }
245
-
246
- jasmine.JSONFixtures.prototype.loadFixtureIntoCache_ = function (relativeUrl) {
247
- var self = this
248
- , url = this.fixturesPath.match('/$') ? this.fixturesPath + relativeUrl : this.fixturesPath + '/' + relativeUrl
249
-
250
- $.ajax({
251
- async: false, // must be synchronous to guarantee that no tests are run before fixture is loaded
252
- cache: false,
253
- dataType: 'json',
254
- url: url,
255
- success: function (data) {
256
- self.fixturesCache_[relativeUrl] = data
257
- },
258
- error: function (jqXHR, status, errorThrown) {
259
- throw new Error('JSONFixture could not be loaded: ' + url + ' (status: ' + status + ', message: ' + errorThrown.message + ')')
260
- }
261
- })
262
- }
263
-
264
- jasmine.JSONFixtures.prototype.proxyCallTo_ = function (methodName, passedArguments) {
265
- return this[methodName].apply(this, passedArguments)
266
- }
267
-
268
- jasmine.jQuery = function () {}
269
-
270
- jasmine.jQuery.browserTagCaseIndependentHtml = function (html) {
271
- return $('<div/>').append(html).html()
272
- }
273
-
274
- jasmine.jQuery.elementToString = function (element) {
275
- return $(element).map(function () { return this.outerHTML; }).toArray().join(', ')
276
- }
277
-
278
- var data = {
279
- spiedEvents: {}
280
- , handlers: []
281
- }
282
-
283
- jasmine.jQuery.events = {
284
- spyOn: function (selector, eventName) {
285
- var handler = function (e) {
286
- data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)] = jasmine.util.argsToArray(arguments)
287
- }
288
-
289
- $(selector).on(eventName, handler)
290
- data.handlers.push(handler)
291
-
292
- return {
293
- selector: selector,
294
- eventName: eventName,
295
- handler: handler,
296
- reset: function (){
297
- delete data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
298
- }
299
- }
300
- },
301
-
302
- args: function (selector, eventName) {
303
- var actualArgs = data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
304
-
305
- if (!actualArgs) {
306
- throw "There is no spy for " + eventName + " on " + selector.toString() + ". Make sure to create a spy using spyOnEvent."
307
- }
308
-
309
- return actualArgs
310
- },
311
-
312
- wasTriggered: function (selector, eventName) {
313
- return !!(data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)])
314
- },
315
-
316
- wasTriggeredWith: function (selector, eventName, expectedArgs, util, customEqualityTesters) {
317
- var actualArgs = jasmine.jQuery.events.args(selector, eventName).slice(1)
318
-
319
- if (Object.prototype.toString.call(expectedArgs) !== '[object Array]')
320
- actualArgs = actualArgs[0]
321
-
322
- return util.equals(expectedArgs, actualArgs, customEqualityTesters)
323
- },
324
-
325
- wasPrevented: function (selector, eventName) {
326
- var args = data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
327
- , e = args ? args[0] : undefined
328
-
329
- return e && e.isDefaultPrevented()
330
- },
331
-
332
- wasStopped: function (selector, eventName) {
333
- var args = data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
334
- , e = args ? args[0] : undefined
335
- return e && e.isPropagationStopped()
336
- },
337
-
338
- cleanUp: function () {
339
- data.spiedEvents = {}
340
- data.handlers = []
341
- }
342
- }
343
-
344
- var hasProperty = function (actualValue, expectedValue) {
345
- if (expectedValue === undefined)
346
- return actualValue !== undefined
347
-
348
- return actualValue === expectedValue
349
- }
350
-
351
- beforeEach(function () {
352
- jasmine.addMatchers({
353
- toHaveClass: function () {
354
- return {
355
- compare: function (actual, className) {
356
- return { pass: $(actual).hasClass(className) }
357
- }
358
- }
359
- },
360
-
361
- toHaveCss: function () {
362
- return {
363
- compare: function (actual, css) {
364
- for (var prop in css){
365
- var value = css[prop]
366
- // see issue #147 on gh
367
- ;if (value === 'auto' && $(actual).get(0).style[prop] === 'auto') continue
368
- if ($(actual).css(prop) !== value) return { pass: false }
369
- }
370
- return { pass: true }
371
- }
372
- }
373
- },
374
-
375
- toBeVisible: function () {
376
- return {
377
- compare: function (actual) {
378
- return { pass: $(actual).is(':visible') }
379
- }
380
- }
381
- },
382
-
383
- toBeHidden: function () {
384
- return {
385
- compare: function (actual) {
386
- return { pass: $(actual).is(':hidden') }
387
- }
388
- }
389
- },
390
-
391
- toBeSelected: function () {
392
- return {
393
- compare: function (actual) {
394
- return { pass: $(actual).is(':selected') }
395
- }
396
- }
397
- },
398
-
399
- toBeChecked: function () {
400
- return {
401
- compare: function (actual) {
402
- return { pass: $(actual).is(':checked') }
403
- }
404
- }
405
- },
406
-
407
- toBeEmpty: function () {
408
- return {
409
- compare: function (actual) {
410
- return { pass: $(actual).is(':empty') }
411
- }
412
- }
413
- },
414
-
415
- toBeInDOM: function () {
416
- return {
417
- compare: function (actual) {
418
- return { pass: $.contains(document.documentElement, $(actual)[0]) }
419
- }
420
- }
421
- },
422
-
423
- toExist: function () {
424
- return {
425
- compare: function (actual) {
426
- return { pass: $(actual).length }
427
- }
428
- }
429
- },
430
-
431
- toHaveLength: function () {
432
- return {
433
- compare: function (actual, length) {
434
- return { pass: $(actual).length === length }
435
- }
436
- }
437
- },
438
-
439
- toHaveAttr: function () {
440
- return {
441
- compare: function (actual, attributeName, expectedAttributeValue) {
442
- return { pass: hasProperty($(actual).attr(attributeName), expectedAttributeValue) }
443
- }
444
- }
445
- },
446
-
447
- toHaveProp: function () {
448
- return {
449
- compare: function (actual, propertyName, expectedPropertyValue) {
450
- return { pass: hasProperty($(actual).prop(propertyName), expectedPropertyValue) }
451
- }
452
- }
453
- },
454
-
455
- toHaveId: function () {
456
- return {
457
- compare: function (actual, id) {
458
- return { pass: $(actual).attr('id') == id }
459
- }
460
- }
461
- },
462
-
463
- toHaveHtml: function () {
464
- return {
465
- compare: function (actual, html) {
466
- return { pass: $(actual).html() == jasmine.jQuery.browserTagCaseIndependentHtml(html) }
467
- }
468
- }
469
- },
470
-
471
- toContainHtml: function () {
472
- return {
473
- compare: function (actual, html) {
474
- var actualHtml = $(actual).html()
475
- , expectedHtml = jasmine.jQuery.browserTagCaseIndependentHtml(html)
476
-
477
- return { pass: (actualHtml.indexOf(expectedHtml) >= 0) }
478
- }
479
- }
480
- },
481
-
482
- toHaveText: function () {
483
- return {
484
- compare: function (actual, text) {
485
- var trimmedText = $.trim($(actual).text())
486
-
487
- if (text && $.isFunction(text.test)) {
488
- return { pass: text.test(trimmedText) }
489
- } else {
490
- return { pass: trimmedText == text }
491
- }
492
- }
493
- }
494
- },
495
-
496
- toContainText: function () {
497
- return {
498
- compare: function (actual, text) {
499
- var trimmedText = $.trim($(actual).text())
500
-
501
- if (text && $.isFunction(text.test)) {
502
- return { pass: text.test(trimmedText) }
503
- } else {
504
- return { pass: trimmedText.indexOf(text) != -1 }
505
- }
506
- }
507
- }
508
- },
509
-
510
- toHaveValue: function () {
511
- return {
512
- compare: function (actual, value) {
513
- return { pass: $(actual).val() === value }
514
- }
515
- }
516
- },
517
-
518
- toHaveData: function () {
519
- return {
520
- compare: function (actual, key, expectedValue) {
521
- return { pass: hasProperty($(actual).data(key), expectedValue) }
522
- }
523
- }
524
- },
525
-
526
- toContainElement: function () {
527
- return {
528
- compare: function (actual, selector) {
529
- if (window.debug) debugger
530
- return { pass: $(actual).find(selector).length }
531
- }
532
- }
533
- },
534
-
535
- toBeMatchedBy: function () {
536
- return {
537
- compare: function (actual, selector) {
538
- return { pass: $(actual).filter(selector).length }
539
- }
540
- }
541
- },
542
-
543
- toBeDisabled: function () {
544
- return {
545
- compare: function (actual, selector) {
546
- return { pass: $(actual).is(':disabled') }
547
- }
548
- }
549
- },
550
-
551
- toBeFocused: function (selector) {
552
- return {
553
- compare: function (actual, selector) {
554
- return { pass: $(actual)[0] === $(actual)[0].ownerDocument.activeElement }
555
- }
556
- }
557
- },
558
-
559
- toHandle: function () {
560
- return {
561
- compare: function (actual, event) {
562
- var events = $._data($(actual).get(0), "events")
563
-
564
- if (!events || !event || typeof event !== "string") {
565
- return { pass: false }
566
- }
567
-
568
- var namespaces = event.split(".")
569
- , eventType = namespaces.shift()
570
- , sortedNamespaces = namespaces.slice(0).sort()
571
- , namespaceRegExp = new RegExp("(^|\\.)" + sortedNamespaces.join("\\.(?:.*\\.)?") + "(\\.|$)")
572
-
573
- if (events[eventType] && namespaces.length) {
574
- for (var i = 0; i < events[eventType].length; i++) {
575
- var namespace = events[eventType][i].namespace
576
-
577
- if (namespaceRegExp.test(namespace))
578
- return { pass: true }
579
- }
580
- } else {
581
- return { pass: (events[eventType] && events[eventType].length > 0) }
582
- }
583
-
584
- return { pass: false }
585
- }
586
- }
587
- },
588
-
589
- toHandleWith: function () {
590
- return {
591
- compare: function (actual, eventName, eventHandler) {
592
- var normalizedEventName = eventName.split('.')[0]
593
- , stack = $._data($(actual).get(0), "events")[normalizedEventName]
594
-
595
- for (var i = 0; i < stack.length; i++) {
596
- if (stack[i].handler == eventHandler) return { pass: true }
597
- }
598
-
599
- return { pass: false }
600
- }
601
- }
602
- },
603
-
604
- toHaveBeenTriggeredOn: function () {
605
- return {
606
- compare: function (actual, selector) {
607
- var result = { pass: jasmine.jQuery.events.wasTriggered(selector, actual) }
608
-
609
- result.message = result.pass ?
610
- "Expected event " + $(actual) + " not to have been triggered on " + selector :
611
- "Expected event " + $(actual) + " to have been triggered on " + selector
612
-
613
- return result;
614
- }
615
- }
616
- },
617
-
618
- toHaveBeenTriggered: function (){
619
- return {
620
- compare: function (actual) {
621
- var eventName = actual.eventName
622
- , selector = actual.selector
623
- , result = { pass: jasmine.jQuery.events.wasTriggered(selector, eventName) }
624
-
625
- result.message = result.pass ?
626
- "Expected event " + eventName + " not to have been triggered on " + selector :
627
- "Expected event " + eventName + " to have been triggered on " + selector
628
-
629
- return result
630
- }
631
- }
632
- },
633
-
634
- toHaveBeenTriggeredOnAndWith: function (j$, customEqualityTesters) {
635
- return {
636
- compare: function (actual, selector, expectedArgs) {
637
- var wasTriggered = jasmine.jQuery.events.wasTriggered(selector, actual)
638
- , result = { pass: wasTriggered && jasmine.jQuery.events.wasTriggeredWith(selector, actual, expectedArgs, j$, customEqualityTesters) }
639
-
640
- if (wasTriggered) {
641
- var actualArgs = jasmine.jQuery.events.args(selector, actual, expectedArgs)[1]
642
- result.message = result.pass ?
643
- "Expected event " + actual + " not to have been triggered with " + jasmine.pp(expectedArgs) + " but it was triggered with " + jasmine.pp(actualArgs) :
644
- "Expected event " + actual + " to have been triggered with " + jasmine.pp(expectedArgs) + " but it was triggered with " + jasmine.pp(actualArgs)
645
-
646
- } else {
647
- // todo check on this
648
- result.message = result.pass ?
649
- "Expected event " + actual + " not to have been triggered on " + selector :
650
- "Expected event " + actual + " to have been triggered on " + selector
651
- }
652
-
653
- return result
654
- }
655
- }
656
- },
657
-
658
- toHaveBeenPreventedOn: function () {
659
- return {
660
- compare: function (actual, selector) {
661
- var result = { pass: jasmine.jQuery.events.wasPrevented(selector, actual) }
662
-
663
- result.message = result.pass ?
664
- "Expected event " + actual + " not to have been prevented on " + selector :
665
- "Expected event " + actual + " to have been prevented on " + selector
666
-
667
- return result
668
- }
669
- }
670
- },
671
-
672
- toHaveBeenPrevented: function () {
673
- return {
674
- compare: function (actual) {
675
- var eventName = actual.eventName
676
- , selector = actual.selector
677
- , result = { pass: jasmine.jQuery.events.wasPrevented(selector, eventName) }
678
-
679
- result.message = result.pass ?
680
- "Expected event " + eventName + " not to have been prevented on " + selector :
681
- "Expected event " + eventName + " to have been prevented on " + selector
682
-
683
- return result
684
- }
685
- }
686
- },
687
-
688
- toHaveBeenStoppedOn: function () {
689
- return {
690
- compare: function (actual, selector) {
691
- var result = { pass: jasmine.jQuery.events.wasStopped(selector, actual) }
692
-
693
- result.message = result.pass ?
694
- "Expected event " + actual + " not to have been stopped on " + selector :
695
- "Expected event " + actual + " to have been stopped on " + selector
696
-
697
- return result;
698
- }
699
- }
700
- },
701
-
702
- toHaveBeenStopped: function () {
703
- return {
704
- compare: function (actual) {
705
- var eventName = actual.eventName
706
- , selector = actual.selector
707
- , result = { pass: jasmine.jQuery.events.wasStopped(selector, eventName) }
708
-
709
- result.message = result.pass ?
710
- "Expected event " + eventName + " not to have been stopped on " + selector :
711
- "Expected event " + eventName + " to have been stopped on " + selector
712
-
713
- return result
714
- }
715
- }
716
- }
717
- })
718
-
719
- jasmine.getEnv().addCustomEqualityTester(function(a, b) {
720
- if (a && b) {
721
- if (a instanceof $ || jasmine.isDomNode(a)) {
722
- var $a = $(a)
723
-
724
- if (b instanceof $)
725
- return $a.length == b.length && a.is(b)
726
-
727
- return $a.is(b);
728
- }
729
-
730
- if (b instanceof $ || jasmine.isDomNode(b)) {
731
- var $b = $(b)
732
-
733
- if (a instanceof jQuery)
734
- return a.length == $b.length && $b.is(a)
735
-
736
- return $(b).is(a);
737
- }
738
- }
739
- })
740
-
741
- jasmine.getEnv().addCustomEqualityTester(function (a, b) {
742
- if (a instanceof jQuery && b instanceof jQuery && a.size() == b.size())
743
- return a.is(b)
744
- })
745
- })
746
-
747
- afterEach(function () {
748
- jasmine.getFixtures().cleanUp()
749
- jasmine.getStyleFixtures().cleanUp()
750
- jasmine.jQuery.events.cleanUp()
751
- })
752
-
753
- window.readFixtures = function () {
754
- return jasmine.getFixtures().proxyCallTo_('read', arguments)
755
- }
756
-
757
- window.preloadFixtures = function () {
758
- jasmine.getFixtures().proxyCallTo_('preload', arguments)
759
- }
760
-
761
- window.loadFixtures = function () {
762
- jasmine.getFixtures().proxyCallTo_('load', arguments)
763
- }
764
-
765
- window.appendLoadFixtures = function () {
766
- jasmine.getFixtures().proxyCallTo_('appendLoad', arguments)
767
- }
768
-
769
- window.setFixtures = function (html) {
770
- return jasmine.getFixtures().proxyCallTo_('set', arguments)
771
- }
772
-
773
- window.appendSetFixtures = function () {
774
- jasmine.getFixtures().proxyCallTo_('appendSet', arguments)
775
- }
776
-
777
- window.sandbox = function (attributes) {
778
- return jasmine.getFixtures().sandbox(attributes)
779
- }
780
-
781
- window.spyOnEvent = function (selector, eventName) {
782
- return jasmine.jQuery.events.spyOn(selector, eventName)
783
- }
784
-
785
- window.preloadStyleFixtures = function () {
786
- jasmine.getStyleFixtures().proxyCallTo_('preload', arguments)
787
- }
788
-
789
- window.loadStyleFixtures = function () {
790
- jasmine.getStyleFixtures().proxyCallTo_('load', arguments)
791
- }
792
-
793
- window.appendLoadStyleFixtures = function () {
794
- jasmine.getStyleFixtures().proxyCallTo_('appendLoad', arguments)
795
- }
796
-
797
- window.setStyleFixtures = function (html) {
798
- jasmine.getStyleFixtures().proxyCallTo_('set', arguments)
799
- }
800
-
801
- window.appendSetStyleFixtures = function (html) {
802
- jasmine.getStyleFixtures().proxyCallTo_('appendSet', arguments)
803
- }
804
-
805
- window.loadJSONFixtures = function () {
806
- return jasmine.getJSONFixtures().proxyCallTo_('load', arguments)
807
- }
808
-
809
- window.getJSONFixture = function (url) {
810
- return jasmine.getJSONFixtures().proxyCallTo_('read', arguments)[url]
811
- }
812
- }(window, window.jasmine, window.jQuery);