traceur-rb 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (255) hide show
  1. checksums.yaml +15 -0
  2. data/.gitignore +22 -0
  3. data/.rspec +1 -0
  4. data/.ruby-gemset +1 -0
  5. data/.ruby-version +1 -0
  6. data/Gemfile +4 -0
  7. data/Guardfile +8 -0
  8. data/LICENSE.txt +22 -0
  9. data/README.md +87 -0
  10. data/Rakefile +2 -0
  11. data/lib/js/compile.js +31 -0
  12. data/lib/traceur-rb.rb +1 -0
  13. data/lib/traceur.rb +43 -0
  14. data/lib/traceur/compilation_options.rb +65 -0
  15. data/lib/traceur/compiler.rb +33 -0
  16. data/lib/traceur/configuration.rb +47 -0
  17. data/lib/traceur/node.rb +26 -0
  18. data/lib/traceur/node/command_result.rb +28 -0
  19. data/lib/traceur/node/runner.rb +40 -0
  20. data/lib/traceur/version.rb +3 -0
  21. data/spec/examples/classes.js +12 -0
  22. data/spec/integration/examples_spec.rb +28 -0
  23. data/spec/spec_helper.rb +1 -0
  24. data/spec/traceur/compilation_options_spec.rb +31 -0
  25. data/spec/traceur/configuration_spec.rb +54 -0
  26. data/spec/traceur/node_spec.rb +15 -0
  27. data/traceur-rb.gemspec +25 -0
  28. data/vendor/node_modules/.bin/traceur +3 -0
  29. data/vendor/node_modules/traceur/README.md +40 -0
  30. data/vendor/node_modules/traceur/bin/traceur-runtime.js +2101 -0
  31. data/vendor/node_modules/traceur/bin/traceur.js +23034 -0
  32. data/vendor/node_modules/traceur/node_modules/.bin/semver +125 -0
  33. data/vendor/node_modules/traceur/node_modules/commander/Readme.md +208 -0
  34. data/vendor/node_modules/traceur/node_modules/commander/index.js +852 -0
  35. data/vendor/node_modules/traceur/node_modules/commander/package.json +40 -0
  36. data/vendor/node_modules/traceur/node_modules/q-io/.npmignore +1 -0
  37. data/vendor/node_modules/traceur/node_modules/q-io/.travis.yml +3 -0
  38. data/vendor/node_modules/traceur/node_modules/q-io/CHANGES.md +122 -0
  39. data/vendor/node_modules/traceur/node_modules/q-io/LICENSE +19 -0
  40. data/vendor/node_modules/traceur/node_modules/q-io/README.md +928 -0
  41. data/vendor/node_modules/traceur/node_modules/q-io/buffer-stream.js +59 -0
  42. data/vendor/node_modules/traceur/node_modules/q-io/coverage-report.js +44 -0
  43. data/vendor/node_modules/traceur/node_modules/q-io/deprecate.js +51 -0
  44. data/vendor/node_modules/traceur/node_modules/q-io/fs-boot.js +307 -0
  45. data/vendor/node_modules/traceur/node_modules/q-io/fs-common.js +499 -0
  46. data/vendor/node_modules/traceur/node_modules/q-io/fs-mock.js +547 -0
  47. data/vendor/node_modules/traceur/node_modules/q-io/fs-root.js +105 -0
  48. data/vendor/node_modules/traceur/node_modules/q-io/fs.js +355 -0
  49. data/vendor/node_modules/traceur/node_modules/q-io/fs2http.js +65 -0
  50. data/vendor/node_modules/traceur/node_modules/q-io/http-apps.js +152 -0
  51. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/chain.js +24 -0
  52. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/content.js +93 -0
  53. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/cookie.js +154 -0
  54. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/decorators.js +178 -0
  55. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/fs.js +417 -0
  56. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/html.js +58 -0
  57. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/json.js +78 -0
  58. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/negotiate.js +120 -0
  59. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/proxy.js +27 -0
  60. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/redirect.js +209 -0
  61. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/route.js +125 -0
  62. data/vendor/node_modules/traceur/node_modules/q-io/http-apps/status.js +175 -0
  63. data/vendor/node_modules/traceur/node_modules/q-io/http-cookie.js +75 -0
  64. data/vendor/node_modules/traceur/node_modules/q-io/http.js +378 -0
  65. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/.npmignore +11 -0
  66. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/.travis.yml +4 -0
  67. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/CHANGES.md +78 -0
  68. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/LICENSE.md +21 -0
  69. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/README.md +1285 -0
  70. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/collections.js +22 -0
  71. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/dict.js +142 -0
  72. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/fast-map.js +57 -0
  73. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/fast-set.js +183 -0
  74. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/generic-collection.js +261 -0
  75. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/generic-map.js +186 -0
  76. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/generic-order.js +55 -0
  77. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/generic-set.js +59 -0
  78. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/heap.js +236 -0
  79. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/iterator.js +371 -0
  80. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/list.js +435 -0
  81. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/listen/array-changes.js +247 -0
  82. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/listen/map-changes.js +147 -0
  83. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/listen/property-changes.js +448 -0
  84. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/listen/range-changes.js +139 -0
  85. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/lru-map.js +79 -0
  86. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/lru-set.js +142 -0
  87. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/map.js +60 -0
  88. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/multi-map.js +41 -0
  89. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/node_modules/weak-map/package.json +12 -0
  90. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/node_modules/weak-map/sync +7 -0
  91. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/node_modules/weak-map/sync.patch +48 -0
  92. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/node_modules/weak-map/weak-map.js +590 -0
  93. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/package.json +49 -0
  94. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/set.js +173 -0
  95. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/shim-array.js +274 -0
  96. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/shim-function.js +59 -0
  97. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/shim-object.js +538 -0
  98. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/shim-regexp.js +14 -0
  99. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/shim.js +6 -0
  100. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/sorted-array-map.js +49 -0
  101. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/sorted-array-set.js +51 -0
  102. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/sorted-array.js +269 -0
  103. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/sorted-map.js +61 -0
  104. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/sorted-set.js +736 -0
  105. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/tree-log.js +40 -0
  106. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/collections/weak-map.js +1 -0
  107. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mime/LICENSE +19 -0
  108. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mime/README.md +66 -0
  109. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mime/mime.js +114 -0
  110. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mime/package.json +35 -0
  111. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mime/test.js +84 -0
  112. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mime/types/mime.types +1588 -0
  113. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mime/types/node.types +77 -0
  114. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mimeparse/CHANGES +15 -0
  115. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mimeparse/LICENSE +19 -0
  116. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mimeparse/README +96 -0
  117. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mimeparse/lib/mimeparse.js +166 -0
  118. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/mimeparse/package.json +43 -0
  119. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/q/CONTRIBUTING.md +40 -0
  120. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/q/LICENSE +19 -0
  121. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/q/README.md +813 -0
  122. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/q/benchmark/compare-with-callbacks.js +71 -0
  123. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/q/benchmark/scenarios.js +36 -0
  124. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/q/package.json +93 -0
  125. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/q/q.js +1937 -0
  126. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/q/queue.js +35 -0
  127. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/.gitmodules +6 -0
  128. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/History.md +36 -0
  129. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/Makefile +7 -0
  130. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/Readme.md +38 -0
  131. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/benchmark.js +32 -0
  132. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/examples.js +39 -0
  133. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/index.js +2 -0
  134. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/lib/querystring.js +123 -0
  135. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/package.json +19 -0
  136. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/.gitmodules +3 -0
  137. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/.npmignore +3 -0
  138. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/History.md +128 -0
  139. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/Makefile +53 -0
  140. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/Readme.md +61 -0
  141. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/bin/expresso +856 -0
  142. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/docs/api.html +1080 -0
  143. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/docs/index.html +377 -0
  144. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/docs/index.md +290 -0
  145. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/docs/layout/foot.html +3 -0
  146. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/docs/layout/head.html +42 -0
  147. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/lib/bar.js +4 -0
  148. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/lib/foo.js +16 -0
  149. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/package.json +12 -0
  150. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/test/assert.test.js +91 -0
  151. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/test/async.test.js +12 -0
  152. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/test/bar.test.js +13 -0
  153. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/test/foo.test.js +14 -0
  154. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/test/http.test.js +146 -0
  155. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/test/serial/async.test.js +39 -0
  156. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/expresso/test/serial/http.test.js +48 -0
  157. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/should/.gitmodules +3 -0
  158. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/should/History.md +22 -0
  159. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/should/Makefile +6 -0
  160. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/should/Readme.md +248 -0
  161. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/should/examples/runner.js +53 -0
  162. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/should/index.js +2 -0
  163. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/should/lib/eql.js +91 -0
  164. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/should/lib/should.js +548 -0
  165. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/should/package.json +8 -0
  166. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/support/should/test/should.test.js +358 -0
  167. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/qs/test/querystring.test.js +133 -0
  168. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/url2/.npmignore +3 -0
  169. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/url2/.travis.yml +4 -0
  170. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/url2/LICENSE.md +20 -0
  171. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/url2/README.md +33 -0
  172. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/url2/package.json +37 -0
  173. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/url2/test/url2-spec.js +125 -0
  174. data/vendor/node_modules/traceur/node_modules/q-io/node_modules/url2/url2.js +151 -0
  175. data/vendor/node_modules/traceur/node_modules/q-io/package.json +51 -0
  176. data/vendor/node_modules/traceur/node_modules/q-io/reader.js +133 -0
  177. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/boot-directory-spec.js +47 -0
  178. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/contains-spec.js +11 -0
  179. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/fixtures/hello.txt +1 -0
  180. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/issues/1-spec.js +33 -0
  181. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/make-tree-spec.js +92 -0
  182. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/append-spec.js +41 -0
  183. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/copy-tree-spec.js +57 -0
  184. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/fixture/hello.txt +1 -0
  185. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/link-spec.js +70 -0
  186. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/make-tree-spec.js +109 -0
  187. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/merge-spec.js +67 -0
  188. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/move-spec.js +219 -0
  189. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/object-spec.js +20 -0
  190. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/range-spec.js +26 -0
  191. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/read-spec.js +40 -0
  192. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/remove-directory-spec.js +37 -0
  193. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/remove-tree-spec.js +39 -0
  194. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/root-spec.js +32 -0
  195. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/stat-spec.js +26 -0
  196. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/symbolic-link-spec.js +86 -0
  197. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/working-directory-spec.js +31 -0
  198. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/mock/write-spec.js +73 -0
  199. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/range-spec.js +23 -0
  200. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/range-spec.txt +1 -0
  201. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/read-spec.js +22 -0
  202. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/relative-spec.js +25 -0
  203. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/reroot-spec.js +45 -0
  204. data/vendor/node_modules/traceur/node_modules/q-io/spec/fs/write-spec.js +38 -0
  205. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/cookie-spec.js +52 -0
  206. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/directory-list-spec.js +86 -0
  207. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/fixtures/01234.txt +1 -0
  208. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/fixtures/1234.txt +1 -0
  209. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/fixtures/5678.txt +0 -0
  210. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/fixtures/9012/3456.txt +0 -0
  211. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/hosts-spec.js +49 -0
  212. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/interpret-range-spec.js +47 -0
  213. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/partial-range-spec.js +186 -0
  214. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/proxy-spec.js +82 -0
  215. data/vendor/node_modules/traceur/node_modules/q-io/spec/http-apps/symbolic-link-spec.js +110 -0
  216. data/vendor/node_modules/traceur/node_modules/q-io/spec/http/agent-spec.js +96 -0
  217. data/vendor/node_modules/traceur/node_modules/q-io/spec/http/basic-spec.js +96 -0
  218. data/vendor/node_modules/traceur/node_modules/q-io/spec/lib/jasmine-promise.js +42 -0
  219. data/vendor/node_modules/traceur/node_modules/q-io/writer.js +111 -0
  220. data/vendor/node_modules/traceur/node_modules/semver/.npmignore +1 -0
  221. data/vendor/node_modules/traceur/node_modules/semver/LICENSE +27 -0
  222. data/vendor/node_modules/traceur/node_modules/semver/Makefile +24 -0
  223. data/vendor/node_modules/traceur/node_modules/semver/README.md +158 -0
  224. data/vendor/node_modules/traceur/node_modules/semver/bin/semver +125 -0
  225. data/vendor/node_modules/traceur/node_modules/semver/foot.js +6 -0
  226. data/vendor/node_modules/traceur/node_modules/semver/head.js +2 -0
  227. data/vendor/node_modules/traceur/node_modules/semver/package.json +31 -0
  228. data/vendor/node_modules/traceur/node_modules/semver/semver.browser.js +1039 -0
  229. data/vendor/node_modules/traceur/node_modules/semver/semver.browser.js.gz +0 -0
  230. data/vendor/node_modules/traceur/node_modules/semver/semver.js +1043 -0
  231. data/vendor/node_modules/traceur/node_modules/semver/semver.min.js +1 -0
  232. data/vendor/node_modules/traceur/node_modules/semver/semver.min.js.gz +0 -0
  233. data/vendor/node_modules/traceur/node_modules/semver/test/amd.js +15 -0
  234. data/vendor/node_modules/traceur/node_modules/semver/test/gtr.js +173 -0
  235. data/vendor/node_modules/traceur/node_modules/semver/test/index.js +584 -0
  236. data/vendor/node_modules/traceur/node_modules/semver/test/ltr.js +174 -0
  237. data/vendor/node_modules/traceur/node_modules/semver/test/no-module.js +19 -0
  238. data/vendor/node_modules/traceur/package.json +64 -0
  239. data/vendor/node_modules/traceur/src/node/System.js +31 -0
  240. data/vendor/node_modules/traceur/src/node/api.js +124 -0
  241. data/vendor/node_modules/traceur/src/node/command.js +141 -0
  242. data/vendor/node_modules/traceur/src/node/compile-single-file.js +69 -0
  243. data/vendor/node_modules/traceur/src/node/compiler.js +116 -0
  244. data/vendor/node_modules/traceur/src/node/deferred.js +110 -0
  245. data/vendor/node_modules/traceur/src/node/file-util.js +73 -0
  246. data/vendor/node_modules/traceur/src/node/getopt.js +147 -0
  247. data/vendor/node_modules/traceur/src/node/inline-module.js +149 -0
  248. data/vendor/node_modules/traceur/src/node/interpreter.js +33 -0
  249. data/vendor/node_modules/traceur/src/node/nodeLoader.js +41 -0
  250. data/vendor/node_modules/traceur/src/node/require.js +85 -0
  251. data/vendor/node_modules/traceur/src/node/to-amd-compiler.js +33 -0
  252. data/vendor/node_modules/traceur/src/node/to-commonjs-compiler.js +33 -0
  253. data/vendor/node_modules/traceur/src/node/traceur.js +32 -0
  254. data/vendor/node_modules/traceur/traceur +3 -0
  255. metadata +359 -0
@@ -0,0 +1,53 @@
1
+
2
+ PREFIX ?= /usr/local
3
+ BIN = bin/expresso
4
+ JSCOV = deps/jscoverage/node-jscoverage
5
+ DOCS = docs/index.md
6
+ HTMLDOCS = $(DOCS:.md=.html)
7
+
8
+ test: $(BIN)
9
+ @./$(BIN) -I lib --growl $(TEST_FLAGS) test/*.test.js
10
+
11
+ test-cov:
12
+ @./$(BIN) -I lib --cov $(TEST_FLAGS) test/*.test.js
13
+
14
+ test-serial:
15
+ @./$(BIN) --serial -I lib $(TEST_FLAGS) test/serial/*.test.js
16
+
17
+ install: install-jscov install-expresso
18
+
19
+ uninstall:
20
+ rm -f $(PREFIX)/bin/expresso
21
+ rm -f $(PREFIX)/bin/node-jscoverage
22
+
23
+ install-jscov: $(JSCOV)
24
+ install $(JSCOV) $(PREFIX)/bin
25
+
26
+ install-expresso:
27
+ install $(BIN) $(PREFIX)/bin
28
+
29
+ $(JSCOV):
30
+ cd deps/jscoverage && ./configure && make && mv jscoverage node-jscoverage
31
+
32
+ clean:
33
+ @cd deps/jscoverage && git clean -fd
34
+
35
+ docs: docs/api.html $(HTMLDOCS)
36
+
37
+ %.html: %.md
38
+ @echo "... $< > $@"
39
+ @ronn -5 --pipe --fragment $< \
40
+ | cat docs/layout/head.html - docs/layout/foot.html \
41
+ > $@
42
+
43
+ docs/api.html: bin/expresso
44
+ dox \
45
+ --title "Expresso" \
46
+ --ribbon "http://github.com/visionmedia/expresso" \
47
+ --desc "Insanely fast TDD framework for [node](http://nodejs.org) featuring code coverage reporting." \
48
+ $< > $@
49
+
50
+ docclean:
51
+ rm -f docs/*.html
52
+
53
+ .PHONY: test test-cov install uninstall install-expresso install-jscov clean docs docclean
@@ -0,0 +1,61 @@
1
+
2
+ # Expresso
3
+
4
+ TDD framework for [nodejs](http://nodejs.org).
5
+
6
+ ## Features
7
+
8
+ - light-weight
9
+ - intuitive async support
10
+ - intuitive test runner executable
11
+ - test coverage support and reporting
12
+ - uses the _assert_ module
13
+ - `assert.eql()` alias of `assert.deepEqual()`
14
+ - `assert.response()` http response utility
15
+ - `assert.includes()`
16
+ - `assert.type()`
17
+ - `assert.isNull()`
18
+ - `assert.isUndefined()`
19
+ - `assert.isNotNull()`
20
+ - `assert.isDefined()`
21
+ - `assert.match()`
22
+ - `assert.length()`
23
+
24
+ ## Installation
25
+
26
+ To install both expresso _and_ node-jscoverage run:
27
+
28
+ $ make install
29
+
30
+ To install expresso alone (no build required) run:
31
+
32
+ $ make install-expresso
33
+
34
+ Install via npm:
35
+
36
+ $ npm install expresso
37
+
38
+ ## License
39
+
40
+ (The MIT License)
41
+
42
+ Copyright (c) 2010 TJ Holowaychuk &lt;tj@vision-media.ca&gt;
43
+
44
+ Permission is hereby granted, free of charge, to any person obtaining
45
+ a copy of this software and associated documentation files (the
46
+ 'Software'), to deal in the Software without restriction, including
47
+ without limitation the rights to use, copy, modify, merge, publish,
48
+ distribute, sublicense, and/or sell copies of the Software, and to
49
+ permit persons to whom the Software is furnished to do so, subject to
50
+ the following conditions:
51
+
52
+ The above copyright notice and this permission notice shall be
53
+ included in all copies or substantial portions of the Software.
54
+
55
+ THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
56
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
57
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
58
+ IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
59
+ CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
60
+ TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
61
+ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,856 @@
1
+ #!/usr/bin/env node
2
+
3
+ /*
4
+ * Expresso
5
+ * Copyright(c) TJ Holowaychuk <tj@vision-media.ca>
6
+ * (MIT Licensed)
7
+ */
8
+
9
+ /**
10
+ * Module dependencies.
11
+ */
12
+
13
+ var assert = require('assert'),
14
+ childProcess = require('child_process'),
15
+ http = require('http'),
16
+ path = require('path'),
17
+ sys = require('sys'),
18
+ cwd = process.cwd(),
19
+ fs = require('fs'),
20
+ defer;
21
+
22
+ /**
23
+ * Expresso version.
24
+ */
25
+
26
+ var version = '0.7.2';
27
+
28
+ /**
29
+ * Failure count.
30
+ */
31
+
32
+ var failures = 0;
33
+
34
+
35
+ /**
36
+ * Number of tests executed.
37
+ */
38
+
39
+ var testcount = 0;
40
+
41
+ /**
42
+ * Whitelist of tests to run.
43
+ */
44
+
45
+ var only = [];
46
+
47
+ /**
48
+ * Boring output.
49
+ */
50
+
51
+ var boring = false;
52
+
53
+ /**
54
+ * Growl notifications.
55
+ */
56
+
57
+ var growl = false;
58
+
59
+ /**
60
+ * Server port.
61
+ */
62
+
63
+ var port = 5555;
64
+
65
+ /**
66
+ * Execute serially.
67
+ */
68
+
69
+ var serial = false;
70
+
71
+ /**
72
+ * Default timeout.
73
+ */
74
+
75
+ var timeout = 2000;
76
+
77
+ /**
78
+ * Quiet output.
79
+ */
80
+
81
+ var quiet = false;
82
+
83
+ /**
84
+ * Usage documentation.
85
+ */
86
+
87
+ var usage = ''
88
+ + '[bold]{Usage}: expresso [options] <file ...>'
89
+ + '\n'
90
+ + '\n[bold]{Options}:'
91
+ + '\n -g, --growl Enable growl notifications'
92
+ + '\n -c, --coverage Generate and report test coverage'
93
+ + '\n -q, --quiet Suppress coverage report if 100%'
94
+ + '\n -t, --timeout MS Timeout in milliseconds, defaults to 2000'
95
+ + '\n -r, --require PATH Require the given module path'
96
+ + '\n -o, --only TESTS Execute only the comma sperated TESTS (can be set several times)'
97
+ + '\n -I, --include PATH Unshift the given path to require.paths'
98
+ + '\n -p, --port NUM Port number for test servers, starts at 5555'
99
+ + '\n -s, --serial Execute tests serially'
100
+ + '\n -b, --boring Suppress ansi-escape colors'
101
+ + '\n -v, --version Output version number'
102
+ + '\n -h, --help Display help information'
103
+ + '\n';
104
+
105
+ // Parse arguments
106
+
107
+ var files = [],
108
+ args = process.argv.slice(2);
109
+
110
+ while (args.length) {
111
+ var arg = args.shift();
112
+ switch (arg) {
113
+ case '-h':
114
+ case '--help':
115
+ print(usage + '\n');
116
+ process.exit(1);
117
+ break;
118
+ case '-v':
119
+ case '--version':
120
+ sys.puts(version);
121
+ process.exit(1);
122
+ break;
123
+ case '-i':
124
+ case '-I':
125
+ case '--include':
126
+ if (arg = args.shift()) {
127
+ require.paths.unshift(arg);
128
+ } else {
129
+ throw new Error('--include requires a path');
130
+ }
131
+ break;
132
+ case '-o':
133
+ case '--only':
134
+ if (arg = args.shift()) {
135
+ only = only.concat(arg.split(/ *, */));
136
+ } else {
137
+ throw new Error('--only requires comma-separated test names');
138
+ }
139
+ break;
140
+ case '-p':
141
+ case '--port':
142
+ if (arg = args.shift()) {
143
+ port = parseInt(arg, 10);
144
+ } else {
145
+ throw new Error('--port requires a number');
146
+ }
147
+ break;
148
+ case '-r':
149
+ case '--require':
150
+ if (arg = args.shift()) {
151
+ require(arg);
152
+ } else {
153
+ throw new Error('--require requires a path');
154
+ }
155
+ break;
156
+ case '-t':
157
+ case '--timeout':
158
+ if (arg = args.shift()) {
159
+ timeout = parseInt(arg, 10);
160
+ } else {
161
+ throw new Error('--timeout requires an argument');
162
+ }
163
+ break;
164
+ case '-c':
165
+ case '--cov':
166
+ case '--coverage':
167
+ defer = true;
168
+ childProcess.exec('rm -fr lib-cov && node-jscoverage lib lib-cov', function(err){
169
+ if (err) throw err;
170
+ require.paths.unshift('lib-cov');
171
+ run(files);
172
+ })
173
+ break;
174
+ case '-q':
175
+ case '--quiet':
176
+ quiet = true;
177
+ break;
178
+ case '-b':
179
+ case '--boring':
180
+ boring = true;
181
+ break;
182
+ case '-g':
183
+ case '--growl':
184
+ growl = true;
185
+ break;
186
+ case '-s':
187
+ case '--serial':
188
+ serial = true;
189
+ break;
190
+ default:
191
+ if (/\.js$/.test(arg)) {
192
+ files.push(arg);
193
+ }
194
+ break;
195
+ }
196
+ }
197
+
198
+ /**
199
+ * Colorized sys.error().
200
+ *
201
+ * @param {String} str
202
+ */
203
+
204
+ function print(str){
205
+ sys.error(colorize(str));
206
+ }
207
+
208
+ /**
209
+ * Colorize the given string using ansi-escape sequences.
210
+ * Disabled when --boring is set.
211
+ *
212
+ * @param {String} str
213
+ * @return {String}
214
+ */
215
+
216
+ function colorize(str){
217
+ var colors = { bold: 1, red: 31, green: 32, yellow: 33 };
218
+ return str.replace(/\[(\w+)\]\{([^]*?)\}/g, function(_, color, str){
219
+ return boring
220
+ ? str
221
+ : '\x1B[' + colors[color] + 'm' + str + '\x1B[0m';
222
+ });
223
+ }
224
+
225
+ // Alias deepEqual as eql for complex equality
226
+
227
+ assert.eql = assert.deepEqual;
228
+
229
+ /**
230
+ * Assert that `val` is null.
231
+ *
232
+ * @param {Mixed} val
233
+ * @param {String} msg
234
+ */
235
+
236
+ assert.isNull = function(val, msg) {
237
+ assert.strictEqual(null, val, msg);
238
+ };
239
+
240
+ /**
241
+ * Assert that `val` is not null.
242
+ *
243
+ * @param {Mixed} val
244
+ * @param {String} msg
245
+ */
246
+
247
+ assert.isNotNull = function(val, msg) {
248
+ assert.notStrictEqual(null, val, msg);
249
+ };
250
+
251
+ /**
252
+ * Assert that `val` is undefined.
253
+ *
254
+ * @param {Mixed} val
255
+ * @param {String} msg
256
+ */
257
+
258
+ assert.isUndefined = function(val, msg) {
259
+ assert.strictEqual(undefined, val, msg);
260
+ };
261
+
262
+ /**
263
+ * Assert that `val` is not undefined.
264
+ *
265
+ * @param {Mixed} val
266
+ * @param {String} msg
267
+ */
268
+
269
+ assert.isDefined = function(val, msg) {
270
+ assert.notStrictEqual(undefined, val, msg);
271
+ };
272
+
273
+ /**
274
+ * Assert that `obj` is `type`.
275
+ *
276
+ * @param {Mixed} obj
277
+ * @param {String} type
278
+ * @api public
279
+ */
280
+
281
+ assert.type = function(obj, type, msg){
282
+ var real = typeof obj;
283
+ msg = msg || 'typeof ' + sys.inspect(obj) + ' is ' + real + ', expected ' + type;
284
+ assert.ok(type === real, msg);
285
+ };
286
+
287
+ /**
288
+ * Assert that `str` matches `regexp`.
289
+ *
290
+ * @param {String} str
291
+ * @param {RegExp} regexp
292
+ * @param {String} msg
293
+ */
294
+
295
+ assert.match = function(str, regexp, msg) {
296
+ msg = msg || sys.inspect(str) + ' does not match ' + sys.inspect(regexp);
297
+ assert.ok(regexp.test(str), msg);
298
+ };
299
+
300
+ /**
301
+ * Assert that `val` is within `obj`.
302
+ *
303
+ * Examples:
304
+ *
305
+ * assert.includes('foobar', 'bar');
306
+ * assert.includes(['foo', 'bar'], 'foo');
307
+ *
308
+ * @param {String|Array} obj
309
+ * @param {Mixed} val
310
+ * @param {String} msg
311
+ */
312
+
313
+ assert.includes = function(obj, val, msg) {
314
+ msg = msg || sys.inspect(obj) + ' does not include ' + sys.inspect(val);
315
+ assert.ok(obj.indexOf(val) >= 0, msg);
316
+ };
317
+
318
+ /**
319
+ * Assert length of `val` is `n`.
320
+ *
321
+ * @param {Mixed} val
322
+ * @param {Number} n
323
+ * @param {String} msg
324
+ */
325
+
326
+ assert.length = function(val, n, msg) {
327
+ msg = msg || sys.inspect(val) + ' has length of ' + val.length + ', expected ' + n;
328
+ assert.equal(n, val.length, msg);
329
+ };
330
+
331
+ /**
332
+ * Assert response from `server` with
333
+ * the given `req` object and `res` assertions object.
334
+ *
335
+ * @param {Server} server
336
+ * @param {Object} req
337
+ * @param {Object|Function} res
338
+ * @param {String} msg
339
+ */
340
+
341
+ assert.response = function(server, req, res, msg){
342
+ // Check that the server is ready or defer
343
+ if (!server.fd) {
344
+ if (!('__deferred' in server)) {
345
+ server.__deferred = [];
346
+ }
347
+ server.__deferred.push(arguments);
348
+ if (!server.__started) {
349
+ server.listen(server.__port = port++, '127.0.0.1', function(){
350
+ if (server.__deferred) {
351
+ process.nextTick(function(){
352
+ server.__deferred.forEach(function(args){
353
+ assert.response.apply(assert, args);
354
+ });
355
+ });
356
+ }
357
+ });
358
+ server.__started = true;
359
+ }
360
+ return;
361
+ }
362
+
363
+ // Callback as third or fourth arg
364
+ var callback = typeof res === 'function'
365
+ ? res
366
+ : typeof msg === 'function'
367
+ ? msg
368
+ : function(){};
369
+
370
+ // Default messate to test title
371
+ if (typeof msg === 'function') msg = null;
372
+ msg = msg || assert.testTitle;
373
+ msg += '. ';
374
+
375
+ // Pending responses
376
+ server.__pending = server.__pending || 0;
377
+ server.__pending++;
378
+
379
+ // Create client
380
+ if (!server.fd) {
381
+ server.listen(server.__port = port++, '127.0.0.1', issue);
382
+ } else {
383
+ issue();
384
+ }
385
+
386
+ function issue(){
387
+ if (!server.client)
388
+ server.client = http.createClient(server.__port);
389
+
390
+ // Issue request
391
+ var timer,
392
+ client = server.client,
393
+ method = req.method || 'GET',
394
+ status = res.status || res.statusCode,
395
+ data = req.data || req.body,
396
+ requestTimeout = req.timeout || 0;
397
+
398
+ var request = client.request(method, req.url, req.headers);
399
+
400
+ // Timeout
401
+ if (requestTimeout) {
402
+ timer = setTimeout(function(){
403
+ --server.__pending || server.close();
404
+ delete req.timeout;
405
+ assert.fail(msg + 'Request timed out after ' + requestTimeout + 'ms.');
406
+ }, requestTimeout);
407
+ }
408
+
409
+ if (data) request.write(data);
410
+ request.on('response', function(response){
411
+ response.body = '';
412
+ response.setEncoding('utf8');
413
+ response.on('data', function(chunk){ response.body += chunk; });
414
+ response.on('end', function(){
415
+ --server.__pending || server.close();
416
+ if (timer) clearTimeout(timer);
417
+
418
+ // Assert response body
419
+ if (res.body !== undefined) {
420
+ var eql = res.body instanceof RegExp
421
+ ? res.body.test(response.body)
422
+ : res.body === response.body;
423
+ assert.ok(
424
+ eql,
425
+ msg + 'Invalid response body.\n'
426
+ + ' Expected: ' + sys.inspect(res.body) + '\n'
427
+ + ' Got: ' + sys.inspect(response.body)
428
+ );
429
+ }
430
+
431
+ // Assert response status
432
+ if (typeof status === 'number') {
433
+ assert.equal(
434
+ response.statusCode,
435
+ status,
436
+ msg + colorize('Invalid response status code.\n'
437
+ + ' Expected: [green]{' + status + '}\n'
438
+ + ' Got: [red]{' + response.statusCode + '}')
439
+ );
440
+ }
441
+
442
+ // Assert response headers
443
+ if (res.headers) {
444
+ var keys = Object.keys(res.headers);
445
+ for (var i = 0, len = keys.length; i < len; ++i) {
446
+ var name = keys[i],
447
+ actual = response.headers[name.toLowerCase()],
448
+ expected = res.headers[name],
449
+ eql = expected instanceof RegExp
450
+ ? expected.test(actual)
451
+ : expected == actual;
452
+ assert.ok(
453
+ eql,
454
+ msg + colorize('Invalid response header [bold]{' + name + '}.\n'
455
+ + ' Expected: [green]{' + expected + '}\n'
456
+ + ' Got: [red]{' + actual + '}')
457
+ );
458
+ }
459
+ }
460
+
461
+ // Callback
462
+ callback(response);
463
+ });
464
+ });
465
+ request.end();
466
+ }
467
+ };
468
+
469
+ /**
470
+ * Pad the given string to the maximum width provided.
471
+ *
472
+ * @param {String} str
473
+ * @param {Number} width
474
+ * @return {String}
475
+ */
476
+
477
+ function lpad(str, width) {
478
+ str = String(str);
479
+ var n = width - str.length;
480
+ if (n < 1) return str;
481
+ while (n--) str = ' ' + str;
482
+ return str;
483
+ }
484
+
485
+ /**
486
+ * Pad the given string to the maximum width provided.
487
+ *
488
+ * @param {String} str
489
+ * @param {Number} width
490
+ * @return {String}
491
+ */
492
+
493
+ function rpad(str, width) {
494
+ str = String(str);
495
+ var n = width - str.length;
496
+ if (n < 1) return str;
497
+ while (n--) str = str + ' ';
498
+ return str;
499
+ }
500
+
501
+ /**
502
+ * Report test coverage.
503
+ *
504
+ * @param {Object} cov
505
+ */
506
+
507
+ function reportCoverage(cov) {
508
+ // Stats
509
+ print('\n [bold]{Test Coverage}\n');
510
+ var sep = ' +------------------------------------------+----------+------+------+--------+',
511
+ lastSep = ' +----------+------+------+--------+';
512
+ sys.puts(sep);
513
+ sys.puts(' | filename | coverage | LOC | SLOC | missed |');
514
+ sys.puts(sep);
515
+ for (var name in cov) {
516
+ var file = cov[name];
517
+ if (Array.isArray(file)) {
518
+ sys.print(' | ' + rpad(name, 40));
519
+ sys.print(' | ' + lpad(file.coverage.toFixed(2), 8));
520
+ sys.print(' | ' + lpad(file.LOC, 4));
521
+ sys.print(' | ' + lpad(file.SLOC, 4));
522
+ sys.print(' | ' + lpad(file.totalMisses, 6));
523
+ sys.print(' |\n');
524
+ }
525
+ }
526
+ sys.puts(sep);
527
+ sys.print(' ' + rpad('', 40));
528
+ sys.print(' | ' + lpad(cov.coverage.toFixed(2), 8));
529
+ sys.print(' | ' + lpad(cov.LOC, 4));
530
+ sys.print(' | ' + lpad(cov.SLOC, 4));
531
+ sys.print(' | ' + lpad(cov.totalMisses, 6));
532
+ sys.print(' |\n');
533
+ sys.puts(lastSep);
534
+ // Source
535
+ for (var name in cov) {
536
+ if (name.match(/\.js$/)) {
537
+ var file = cov[name];
538
+ if ((file.coverage < 100) || !quiet) {
539
+ print('\n [bold]{' + name + '}:');
540
+ print(file.source);
541
+ sys.print('\n');
542
+ }
543
+ }
544
+ }
545
+ }
546
+
547
+ /**
548
+ * Populate code coverage data.
549
+ *
550
+ * @param {Object} cov
551
+ */
552
+
553
+ function populateCoverage(cov) {
554
+ cov.LOC =
555
+ cov.SLOC =
556
+ cov.totalFiles =
557
+ cov.totalHits =
558
+ cov.totalMisses =
559
+ cov.coverage = 0;
560
+ for (var name in cov) {
561
+ var file = cov[name];
562
+ if (Array.isArray(file)) {
563
+ // Stats
564
+ ++cov.totalFiles;
565
+ cov.totalHits += file.totalHits = coverage(file, true);
566
+ cov.totalMisses += file.totalMisses = coverage(file, false);
567
+ file.totalLines = file.totalHits + file.totalMisses;
568
+ cov.SLOC += file.SLOC = file.totalLines;
569
+ if (!file.source) file.source = [];
570
+ cov.LOC += file.LOC = file.source.length;
571
+ file.coverage = (file.totalHits / file.totalLines) * 100;
572
+ // Source
573
+ var width = file.source.length.toString().length;
574
+ file.source = file.source.map(function(line, i){
575
+ ++i;
576
+ var hits = file[i] === 0 ? 0 : (file[i] || ' ');
577
+ if (!boring) {
578
+ if (hits === 0) {
579
+ hits = '\x1b[31m' + hits + '\x1b[0m';
580
+ line = '\x1b[41m' + line + '\x1b[0m';
581
+ } else {
582
+ hits = '\x1b[32m' + hits + '\x1b[0m';
583
+ }
584
+ }
585
+ return '\n ' + lpad(i, width) + ' | ' + hits + ' | ' + line;
586
+ }).join('');
587
+ }
588
+ }
589
+ cov.coverage = (cov.totalHits / cov.SLOC) * 100;
590
+ }
591
+
592
+ /**
593
+ * Total coverage for the given file data.
594
+ *
595
+ * @param {Array} data
596
+ * @return {Type}
597
+ */
598
+
599
+ function coverage(data, val) {
600
+ var n = 0;
601
+ for (var i = 0, len = data.length; i < len; ++i) {
602
+ if (data[i] !== undefined && data[i] == val) ++n;
603
+ }
604
+ return n;
605
+ }
606
+
607
+ /**
608
+ * Test if all files have 100% coverage
609
+ *
610
+ * @param {Object} cov
611
+ * @return {Boolean}
612
+ */
613
+
614
+ function hasFullCoverage(cov) {
615
+ for (var name in cov) {
616
+ var file = cov[name];
617
+ if (file instanceof Array) {
618
+ if (file.coverage !== 100) {
619
+ return false;
620
+ }
621
+ }
622
+ }
623
+ return true;
624
+ }
625
+
626
+ /**
627
+ * Run the given test `files`, or try _test/*_.
628
+ *
629
+ * @param {Array} files
630
+ */
631
+
632
+ function run(files) {
633
+ cursor(false);
634
+ if (!files.length) {
635
+ try {
636
+ files = fs.readdirSync('test').map(function(file){
637
+ return 'test/' + file;
638
+ });
639
+ } catch (err) {
640
+ print('\n failed to load tests in [bold]{./test}\n');
641
+ ++failures;
642
+ process.exit(1);
643
+ }
644
+ }
645
+ runFiles(files);
646
+ }
647
+
648
+ /**
649
+ * Show the cursor when `show` is true, otherwise hide it.
650
+ *
651
+ * @param {Boolean} show
652
+ */
653
+
654
+ function cursor(show) {
655
+ if (show) {
656
+ sys.print('\x1b[?25h');
657
+ } else {
658
+ sys.print('\x1b[?25l');
659
+ }
660
+ }
661
+
662
+ /**
663
+ * Run the given test `files`.
664
+ *
665
+ * @param {Array} files
666
+ */
667
+
668
+ function runFiles(files) {
669
+ if (serial) {
670
+ (function next(){
671
+ if (files.length) {
672
+ runFile(files.shift(), next);
673
+ }
674
+ })();
675
+ } else {
676
+ files.forEach(runFile);
677
+ }
678
+ }
679
+
680
+ /**
681
+ * Run tests for the given `file`, callback `fn()` when finished.
682
+ *
683
+ * @param {String} file
684
+ * @param {Function} fn
685
+ */
686
+
687
+ function runFile(file, fn) {
688
+ if (file.match(/\.js$/)) {
689
+ var title = path.basename(file),
690
+ file = path.join(cwd, file),
691
+ mod = require(file.replace(/\.js$/, ''));
692
+ (function check(){
693
+ var len = Object.keys(mod).length;
694
+ if (len) {
695
+ runSuite(title, mod, fn);
696
+ } else {
697
+ setTimeout(check, 20);
698
+ }
699
+ })();
700
+ }
701
+ }
702
+
703
+ /**
704
+ * Report `err` for the given `test` and `suite`.
705
+ *
706
+ * @param {String} suite
707
+ * @param {String} test
708
+ * @param {Error} err
709
+ */
710
+
711
+ function error(suite, test, err) {
712
+ ++failures;
713
+ var name = err.name,
714
+ stack = err.stack ? err.stack.replace(err.name, '') : '',
715
+ label = test === 'uncaught'
716
+ ? test
717
+ : suite + ' ' + test;
718
+ print('\n [bold]{' + label + '}: [red]{' + name + '}' + stack + '\n');
719
+ }
720
+
721
+ /**
722
+ * Run the given tests, callback `fn()` when finished.
723
+ *
724
+ * @param {String} title
725
+ * @param {Object} tests
726
+ * @param {Function} fn
727
+ */
728
+
729
+ var dots = 0;
730
+ function runSuite(title, tests, fn) {
731
+ // Keys
732
+ var keys = only.length
733
+ ? only.slice(0)
734
+ : Object.keys(tests);
735
+
736
+ // Setup
737
+ var setup = tests.setup || function(fn){ fn(); };
738
+
739
+ // Iterate tests
740
+ (function next(){
741
+ if (keys.length) {
742
+ var key,
743
+ test = tests[key = keys.shift()];
744
+ // Non-tests
745
+ if (key === 'setup') return next();
746
+
747
+ // Run test
748
+ if (test) {
749
+ try {
750
+ ++testcount;
751
+ assert.testTitle = key;
752
+ if (serial) {
753
+ sys.print('.');
754
+ if (++dots % 25 === 0) sys.print('\n');
755
+ setup(function(){
756
+ if (test.length < 1) {
757
+ test();
758
+ next();
759
+ } else {
760
+ var id = setTimeout(function(){
761
+ throw new Error("'" + key + "' timed out");
762
+ }, timeout);
763
+ test(function(){
764
+ clearTimeout(id);
765
+ next();
766
+ });
767
+ }
768
+ });
769
+ } else {
770
+ test(function(fn){
771
+ process.on('beforeExit', function(){
772
+ try {
773
+ fn();
774
+ } catch (err) {
775
+ error(title, key, err);
776
+ }
777
+ });
778
+ });
779
+ }
780
+ } catch (err) {
781
+ error(title, key, err);
782
+ }
783
+ }
784
+ if (!serial) next();
785
+ } else if (serial) {
786
+ fn();
787
+ }
788
+ })();
789
+ }
790
+
791
+ /**
792
+ * Report exceptions.
793
+ */
794
+
795
+ function report() {
796
+ cursor(true);
797
+ process.emit('beforeExit');
798
+ if (failures) {
799
+ print('\n [bold]{Failures}: [red]{' + failures + '}\n\n');
800
+ notify('Failures: ' + failures);
801
+ } else {
802
+ if (serial) print('');
803
+ print('\n [green]{100%} ' + testcount + ' tests\n');
804
+ notify('100% ok');
805
+ }
806
+ if (typeof _$jscoverage === 'object') {
807
+ populateCoverage(_$jscoverage);
808
+ if (!hasFullCoverage(_$jscoverage) || !quiet) {
809
+ reportCoverage(_$jscoverage);
810
+ }
811
+ }
812
+ }
813
+
814
+ /**
815
+ * Growl notify the given `msg`.
816
+ *
817
+ * @param {String} msg
818
+ */
819
+
820
+ function notify(msg) {
821
+ if (growl) {
822
+ childProcess.exec('growlnotify -name Expresso -m "' + msg + '"');
823
+ }
824
+ }
825
+
826
+ // Report uncaught exceptions
827
+
828
+ process.on('uncaughtException', function(err){
829
+ error('uncaught', 'uncaught', err);
830
+ });
831
+
832
+ // Show cursor
833
+
834
+ ['INT', 'TERM', 'QUIT'].forEach(function(sig){
835
+ process.on('SIG' + sig, function(){
836
+ cursor(true);
837
+ process.exit(1);
838
+ });
839
+ });
840
+
841
+ // Report test coverage when available
842
+ // and emit "beforeExit" event to perform
843
+ // final assertions
844
+
845
+ var orig = process.emit;
846
+ process.emit = function(event){
847
+ if (event === 'exit') {
848
+ report();
849
+ process.reallyExit(failures);
850
+ }
851
+ orig.apply(this, arguments);
852
+ };
853
+
854
+ // Run test files
855
+
856
+ if (!defer) run(files);