teabag 0.4.6 → 0.5.0
Sign up to get free protection for your applications and to get access to all the features.
- data/README.md +83 -92
- data/app/assets/javascripts/teabag-jasmine.js +5 -2
- data/app/assets/javascripts/teabag-mocha.js +5 -2
- data/app/assets/javascripts/teabag-qunit.js +5 -2
- data/app/assets/javascripts/teabag/base/reporters/console.coffee +2 -1
- data/app/assets/javascripts/teabag/base/reporters/html/progress_view.coffee +1 -1
- data/app/controllers/teabag/spec_controller.rb +2 -2
- data/app/helpers/teabag/spec_helper.rb +11 -2
- data/app/views/teabag/spec/index.html.erb +1 -1
- data/bin/teabag +6 -0
- data/config/routes.rb +2 -2
- data/lib/generators/teabag/install/POST_INSTALL +0 -2
- data/lib/generators/teabag/install/install_generator.rb +46 -5
- data/lib/generators/teabag/install/templates/env.rb +28 -0
- data/lib/generators/teabag/install/templates/{initializer.rb → jasmine/initializer.rb} +5 -13
- data/lib/generators/teabag/install/templates/jasmine/spec_helper.coffee +25 -0
- data/lib/generators/teabag/install/templates/jasmine/spec_helper.js +25 -0
- data/lib/generators/teabag/install/templates/mocha/initializer.rb +58 -0
- data/lib/generators/teabag/install/templates/mocha/spec_helper.coffee +25 -0
- data/lib/generators/teabag/install/templates/mocha/spec_helper.js +25 -0
- data/lib/generators/teabag/install/templates/qunit/initializer.rb +58 -0
- data/lib/generators/teabag/install/templates/qunit/test_helper.coffee +24 -0
- data/lib/generators/teabag/install/templates/qunit/test_helper.js +24 -0
- data/lib/tasks/teabag.rake +1 -1
- data/lib/teabag/command_line.rb +96 -0
- data/lib/teabag/configuration.rb +25 -35
- data/lib/teabag/console.rb +19 -7
- data/lib/teabag/drivers/phantomjs/runner.coffee +2 -2
- data/lib/teabag/drivers/selenium_driver.rb +2 -2
- data/lib/teabag/environment.rb +46 -0
- data/lib/teabag/exceptions.rb +1 -0
- data/lib/teabag/formatters/base_formatter.rb +5 -0
- data/lib/teabag/formatters/dot_formatter.rb +3 -2
- data/lib/teabag/formatters/junit_formatter.rb +19 -0
- data/lib/teabag/formatters/swayze_or_oprah_formatter.rb +7 -2
- data/lib/teabag/formatters/tap_y_formatter.rb +1 -0
- data/lib/teabag/runner.rb +1 -1
- data/lib/teabag/suite.rb +15 -6
- data/lib/teabag/version.rb +1 -1
- data/spec/dummy/log/development.log +62925 -0
- data/spec/dummy/log/test.log +614 -0
- data/spec/dummy/tmp/cache/assets/C35/A30/sprockets%2F29906bf540f7d2e081088494b2554989 +0 -0
- data/spec/dummy/tmp/cache/assets/C4E/9B0/sprockets%2Fa807397434c9262c3d62da3e91152184 +0 -0
- data/spec/dummy/tmp/cache/assets/C59/250/sprockets%2Fa80d3fe493d2476e58c4323996064512 +0 -0
- data/spec/dummy/tmp/cache/assets/C72/150/sprockets%2F4194031b4b51b6422c14ac697e3455e5 +0 -0
- data/spec/dummy/tmp/cache/assets/C75/D50/sprockets%2F5302968a40e08d2c011aa38666d273f6 +0 -0
- data/spec/dummy/tmp/cache/assets/C78/F80/sprockets%2F9161622ddd251097a4ab816b8220984c +0 -0
- data/spec/dummy/tmp/cache/assets/C7A/EC0/sprockets%2F5c16e4214f5662e1b27932a57c43491b +0 -0
- data/spec/dummy/tmp/cache/assets/C89/700/sprockets%2F259935a7704fef0069303ea63fa89408 +0 -0
- data/spec/dummy/tmp/cache/assets/C8A/460/sprockets%2F77bffd9959420103906722b404ae8d59 +0 -0
- data/spec/dummy/tmp/cache/assets/C91/FA0/sprockets%2F2eb81283f5789ae91a69344552db3856 +0 -0
- data/spec/dummy/tmp/cache/assets/C9D/E90/sprockets%2F3045c9533f179d3e1c805d163ed002a0 +0 -0
- data/spec/dummy/tmp/cache/assets/CA6/DF0/sprockets%2F7da83747ce56e49393b6b8726587f846 +0 -0
- data/spec/dummy/tmp/cache/assets/CA9/C40/sprockets%2F932b7e2cd1e067289ab51190800814df +0 -0
- data/spec/dummy/tmp/cache/assets/CAA/0C0/sprockets%2F057b0ce384f16d9202ae84473436cc35 +0 -0
- data/spec/dummy/tmp/cache/assets/CAD/410/sprockets%2F651414e5c7e86f05c5108dc71626b25c +0 -0
- data/spec/dummy/tmp/cache/assets/CAF/0F0/sprockets%2F6000e67cf3f2377f860c24da7c819701 +0 -0
- data/spec/dummy/tmp/cache/assets/CB7/2B0/sprockets%2Fdf3d317564a780186148134f2ddd59a9 +0 -0
- data/spec/dummy/tmp/cache/assets/CBB/FA0/sprockets%2F74922109263bdc965b2e9567eec6d154 +0 -0
- data/spec/dummy/tmp/cache/assets/CBD/AF0/sprockets%2Fd687ec33822256e9444e8cd04f1b4873 +0 -0
- data/spec/dummy/tmp/cache/assets/CBF/630/sprockets%2F707d2db81468088470d476abff35388d +0 -0
- data/spec/dummy/tmp/cache/assets/CC1/DB0/sprockets%2F95e6273223502af230a0dbaa25410de8 +0 -0
- data/spec/dummy/tmp/cache/assets/CC2/EC0/sprockets%2F76bf80cb571ca530357f78db78167866 +0 -0
- data/spec/dummy/tmp/cache/assets/CCE/C50/sprockets%2Fe12774c2fea852112414bb379a71f31a +0 -0
- data/spec/dummy/tmp/cache/assets/CD1/620/sprockets%2F06a3eb05fcb4175a679d6084a06026a6 +0 -0
- data/spec/dummy/tmp/cache/assets/CD3/460/sprockets%2F7f3f6802b0b309ed142d0b671c9640c4 +0 -0
- data/spec/dummy/tmp/cache/assets/CD9/DD0/sprockets%2Fe5774759168a731da1c1149ecf0e1b03 +0 -0
- data/spec/dummy/tmp/cache/assets/CE0/090/sprockets%2F48d5d35ae87d0723318b8bc257fa2237 +0 -0
- data/spec/dummy/tmp/cache/assets/CE3/1F0/sprockets%2Fe69a515d3a9d14c669be8871012a7d07 +0 -0
- data/spec/dummy/tmp/cache/assets/CE6/270/sprockets%2F2c98152560d18470fec8cf4c6829b4d0 +0 -0
- data/spec/dummy/tmp/cache/assets/CE6/7C0/sprockets%2Fa03a2c86ce6724be8542295e1cf24798 +0 -0
- data/spec/dummy/tmp/cache/assets/CE7/A60/sprockets%2Ff58eee249aa167d23f8220087bb46684 +0 -0
- data/spec/dummy/tmp/cache/assets/CE9/9E0/sprockets%2F135480d497ed7e4884462dc0ef0b80d7 +0 -0
- data/spec/dummy/tmp/cache/assets/CEB/680/sprockets%2F67f0794ef8c0576d5c7da34f4437305a +0 -0
- data/spec/dummy/tmp/cache/assets/CEB/B40/sprockets%2F1150bf8d912aa100a132251eefaf6045 +0 -0
- data/spec/dummy/tmp/cache/assets/CF4/6F0/sprockets%2Fed96f92571224b862b84d7078b86ded3 +0 -0
- data/spec/dummy/tmp/cache/assets/CF8/780/sprockets%2F8845b81ff27cdb57c835836c9f91a265 +0 -0
- data/spec/dummy/tmp/cache/assets/CFA/D20/sprockets%2Fb26796b39b3c5d6ed70be7989637a493 +0 -0
- data/spec/dummy/tmp/cache/assets/CFB/210/sprockets%2F9104695bfbf9a9d4b94382e6e90487a9 +0 -0
- data/spec/dummy/tmp/cache/assets/CFC/380/sprockets%2Fa7443cbd671446a589867dd5f4a4f989 +0 -0
- data/spec/dummy/tmp/cache/assets/D00/110/sprockets%2F6a6353b7723a8b21708e0fbfe04bd422 +0 -0
- data/spec/dummy/tmp/cache/assets/D00/F60/sprockets%2F42e279b52511c47d26c0adb125fd04e8 +0 -0
- data/spec/dummy/tmp/cache/assets/D03/630/sprockets%2F5d8da32dba6a7be70426a1d554773701 +0 -0
- data/spec/dummy/tmp/cache/assets/D04/170/sprockets%2F76ab1dc02e6c7618852708a1e05a2df3 +0 -0
- data/spec/dummy/tmp/cache/assets/D04/480/sprockets%2F8bd8f10500b21d2f9d94e4cd1401c936 +0 -0
- data/spec/dummy/tmp/cache/assets/D05/8D0/sprockets%2F319f8f235f452343f1ebf03cb262d23d +0 -0
- data/spec/dummy/tmp/cache/assets/D09/BF0/sprockets%2F9e6bca5d26f50d9484385d51ba04312c +0 -0
- data/spec/dummy/tmp/cache/assets/D0E/570/sprockets%2F90fe371bf8091e88a712124d9cdae260 +0 -0
- data/spec/dummy/tmp/cache/assets/D15/750/sprockets%2F8effdd3e668a4036260a3e370f3b6657 +0 -0
- data/spec/dummy/tmp/cache/assets/D17/710/sprockets%2Ffa49fb6823d466e79a195e0cd71340c5 +0 -0
- data/spec/dummy/tmp/cache/assets/D1A/D30/sprockets%2F815a5177e9edba0c5c996182ef1b3675 +0 -0
- data/spec/dummy/tmp/cache/assets/D1D/560/sprockets%2F1ca784ee7ba1922465147e7f8963eae5 +0 -0
- data/spec/dummy/tmp/cache/assets/D1E/AA0/sprockets%2F5c8741a556bc955cd36e61c88582b6dc +0 -0
- data/spec/dummy/tmp/cache/assets/D31/9C0/sprockets%2Fbd102a4f5a4985c3519dd6ab0295a1c6 +0 -0
- data/spec/dummy/tmp/cache/assets/D35/7C0/sprockets%2Ff536a2606eaf7d542c0985104cb62baf +0 -0
- data/spec/dummy/tmp/cache/assets/D37/FF0/sprockets%2F96841ca4cfae32c515077f3f5fc303b2 +0 -0
- data/spec/dummy/tmp/cache/assets/D3C/840/sprockets%2Fc6202ec91d567a85bd3d46dc43ea9108 +0 -0
- data/spec/dummy/tmp/cache/assets/D44/E90/sprockets%2F05cfc0bf7c9938963d1d1c63248db80d +0 -0
- data/spec/dummy/tmp/cache/assets/D45/C30/sprockets%2Fcc744877558178a3adb77c441cadce70 +0 -0
- data/spec/dummy/tmp/cache/assets/D47/A90/sprockets%2Fe7ca382b607c595ea6505853f7fb63da +0 -0
- data/spec/dummy/tmp/cache/assets/D49/1F0/sprockets%2F773b56f87127c6605e7d1d3faf2b6af6 +0 -0
- data/spec/dummy/tmp/cache/assets/D49/A10/sprockets%2Fc4656bd995a6f297c26d19b13aadb963 +0 -0
- data/spec/dummy/tmp/cache/assets/D50/D70/sprockets%2Fe2a3e6c95b11e0801a4eebae3a026026 +0 -0
- data/spec/dummy/tmp/cache/assets/D51/400/sprockets%2Ff5e433d8a31e80985b75ce598de236be +0 -0
- data/spec/dummy/tmp/cache/assets/D5C/710/sprockets%2F9427d05cee2caa721241a25a9af1d08f +0 -0
- data/spec/dummy/tmp/cache/assets/D5C/CC0/sprockets%2Faa8bf6de211f2765b0a26f112b971f0c +0 -0
- data/spec/dummy/tmp/cache/assets/D5E/FA0/sprockets%2Fc81c371ae2d61a6aa1708262fba79e0d +0 -0
- data/spec/dummy/tmp/cache/assets/D61/1F0/sprockets%2F0c7a6176d2fc4db00bb9a74d36380fe1 +0 -0
- data/spec/dummy/tmp/cache/assets/D67/BC0/sprockets%2F35d2c2b45981ade5a2db2a9c7f37a615 +0 -0
- data/spec/dummy/tmp/cache/assets/D69/F90/sprockets%2F6a0795b7b38bd7e6142cd1b88211dade +0 -0
- data/spec/dummy/tmp/cache/assets/D6A/950/sprockets%2F429b1806cb7580ebf29f9a12c33cbea6 +0 -0
- data/spec/dummy/tmp/cache/assets/D6B/6E0/sprockets%2F266d99da1afe084cac250a6ba864c565 +0 -0
- data/spec/dummy/tmp/cache/assets/D6D/DA0/sprockets%2Fac936bf40b42227a2bf9d474ae9ec149 +0 -0
- data/spec/dummy/tmp/cache/assets/D6F/5B0/sprockets%2F5dcc801a7a6c340c5baf525839f9b8b6 +0 -0
- data/spec/dummy/tmp/cache/assets/D77/B30/sprockets%2F946cf2f17c7eb41037f9ee08ad67ec40 +0 -0
- data/spec/dummy/tmp/cache/assets/D78/2F0/sprockets%2F3c61f8915b8f717b1de788e6ecad122c +0 -0
- data/spec/dummy/tmp/cache/assets/D7E/C10/sprockets%2F747c98c3cc7494a62dd882752adffb2b +0 -0
- data/spec/dummy/tmp/cache/assets/D8C/520/sprockets%2F221cd58a042baac534d27e4cfedc1188 +0 -0
- data/spec/dummy/tmp/cache/assets/D93/BD0/sprockets%2Ff5e1b60201e08e3ddf8d3de5211f3d5e +0 -0
- data/spec/dummy/tmp/cache/assets/DA0/330/sprockets%2Fcbbb4de706387d50f48a72ee6c9c1b80 +0 -0
- data/spec/dummy/tmp/cache/assets/DA5/0A0/sprockets%2F7a4b5928cec69ab65afff309a04d6b47 +0 -0
- data/spec/dummy/tmp/cache/assets/DA9/BF0/sprockets%2Fc59f8f7bf494fe030610bc86bb7cc5e5 +0 -0
- data/spec/dummy/tmp/cache/assets/DAC/9B0/sprockets%2F5e58701704fefbc8f88ae24c549fab6b +0 -0
- data/spec/dummy/tmp/cache/assets/DAE/6C0/sprockets%2F77c7a8676aeefa73156c55dfcf51cc46 +0 -0
- data/spec/dummy/tmp/cache/assets/DB3/5D0/sprockets%2Fce1d4d75832c9bdeafd869f6f7b61725 +0 -0
- data/spec/dummy/tmp/cache/assets/DB4/1F0/sprockets%2F69ad2749d7bfe831c0e74e7d7fc4dc57 +0 -0
- data/spec/dummy/tmp/cache/assets/DB5/040/sprockets%2F9a9da5df88713663b9fbc945facca891 +0 -0
- data/spec/dummy/tmp/cache/assets/DC3/230/sprockets%2Fdf52e72eb73be91eccc60182191aed0b +0 -0
- data/spec/dummy/tmp/cache/assets/DC7/A10/sprockets%2F84a8af0fcbf401864e1ae5bf092cba94 +0 -0
- data/spec/dummy/tmp/cache/assets/DCD/EB0/sprockets%2F4f77f509126ecbced7ea2a5ab290c8d4 +0 -0
- data/spec/dummy/tmp/cache/assets/DE4/140/sprockets%2F139e4ab85d1aacb22c115fa136afdc8a +0 -0
- data/spec/dummy/tmp/cache/assets/DEB/110/sprockets%2F2dbdab0ce5babca645cdb5780004f875 +0 -0
- data/spec/dummy/tmp/cache/assets/DF6/0E0/sprockets%2F85b10db6e1afe643aba6d396abdd77f0 +0 -0
- data/spec/dummy/tmp/cache/assets/DF7/E10/sprockets%2F25e4253aba9a9adcefb72552fb1ff0c8 +0 -0
- data/spec/dummy/tmp/cache/assets/DFC/C20/sprockets%2Fd9178ad7e3b401c9fceafd64ea2b50d6 +0 -0
- data/spec/dummy/tmp/cache/assets/DFC/C30/sprockets%2Fb50a07cb30b0bd0eec8e98e5de79d65d +0 -0
- data/spec/dummy/tmp/cache/assets/E02/6E0/sprockets%2F63d6a5cdb8cefa64ef76b5c6e0fd3720 +0 -0
- data/spec/dummy/tmp/cache/assets/E08/BB0/sprockets%2Fefac99af1af28543aef6fb607faa4973 +0 -0
- data/spec/dummy/tmp/cache/assets/E08/F20/sprockets%2F4fc5cdcd6974efe7adfe809b30bd6513 +0 -0
- data/spec/dummy/tmp/cache/assets/E16/D30/sprockets%2Fd69469e6e7439baacd8df989c0fdacc2 +0 -0
- data/spec/dummy/tmp/cache/assets/E17/EF0/sprockets%2Fa291ad64a26afd055dfadabbdf03f154 +0 -0
- data/spec/dummy/tmp/cache/assets/E2F/790/sprockets%2F7fac280deaa7ef20a77d5c9b5b9cfc34 +0 -0
- data/spec/dummy/tmp/cache/assets/E41/250/sprockets%2F97cf8fe3d7ffaff076f655aefb36da03 +0 -0
- data/spec/dummy/tmp/cache/assets/E64/1E0/sprockets%2F81ab4c863fbbdec8dd66afc97ebf034d +0 -0
- data/spec/dummy/tmp/cache/assets/E6E/260/sprockets%2Fd9f8ab8b91ef582cc6c99a3ba0dedfe6 +0 -0
- data/spec/dummy/tmp/cache/assets/F79/360/sprockets%2F0ce035fefee5ebdabc8efabfbdbd6ee4 +0 -0
- data/spec/javascripts/spec_helper.coffee +2 -0
- data/spec/javascripts/support/json2.js +486 -0
- data/spec/javascripts/teabag/base/reporters/console_spec.coffee +14 -2
- data/spec/javascripts/teabag/base/teabag_spec.coffee +1 -0
- data/spec/javascripts/teabag/mocha/mocha_mspec.coffee +1 -1
- data/spec/javascripts/teabag/phantomjs/runner_spec.coffee +1 -0
- data/spec/teabag/command_line_spec.rb +50 -0
- data/spec/teabag/console_spec.rb +32 -3
- data/spec/teabag/drivers/selenium_driver_spec.rb +2 -2
- data/spec/teabag/environment_spec.rb +88 -0
- data/spec/teabag/formatters/dot_formatter_spec.rb +2 -2
- data/spec/teabag/runner_spec.rb +4 -0
- data/spec/teabag/suite_spec.rb +8 -2
- data/spec/teabag_env.rb +27 -0
- metadata +40 -8
- data/app/assets/images/teabag/photo-white.jpg +0 -0
- data/lib/generators/teabag/install/templates/spec_helper.js +0 -31
@@ -1,10 +1,19 @@
|
|
1
1
|
module Teabag::SpecHelper
|
2
2
|
|
3
|
+
def stylesheet_link_tag_for_teabag(*sources)
|
4
|
+
sources.collect do |source|
|
5
|
+
asset = defined?(lookup_asset_for_path) ? lookup_asset_for_path(source, type: :stylesheet) : asset_paths.asset_for(source, "css")
|
6
|
+
asset.to_a.map do |dep|
|
7
|
+
stylesheet_link_tag(dep.pathname.to_s, href: "/assets/#{dep.logical_path}?body=1", type: "text/css").split("\n")
|
8
|
+
end
|
9
|
+
end.flatten.uniq.join("\n").html_safe
|
10
|
+
end
|
11
|
+
|
3
12
|
def javascript_include_tag_for_teabag(*sources)
|
4
13
|
sources.collect do |source|
|
5
|
-
asset = asset_paths.asset_for(source, "js")
|
14
|
+
asset = defined?(lookup_asset_for_path) ? lookup_asset_for_path(source, type: :javascript) : asset_paths.asset_for(source, "js")
|
6
15
|
asset.to_a.map do |dep|
|
7
|
-
javascript_include_tag(dep.pathname.to_s, src:
|
16
|
+
javascript_include_tag(dep.pathname.to_s, src: "/assets/#{dep.logical_path}?body=1", type: "text/javascript").split("\n")
|
8
17
|
end
|
9
18
|
end.flatten.uniq.join("\n").html_safe
|
10
19
|
end
|
@@ -2,7 +2,7 @@
|
|
2
2
|
<html>
|
3
3
|
<head>
|
4
4
|
<title>Teabag :: Javascript Test Runner</title>
|
5
|
-
<%=
|
5
|
+
<%= stylesheet_link_tag_for_teabag *@suite.stylesheets %>
|
6
6
|
<%= csrf_meta_tags %>
|
7
7
|
<meta name="viewport" content="width=device-width, user-scalable=no">
|
8
8
|
<%= javascript_include_tag_for_teabag *@suite.core_javascripts %>
|
data/bin/teabag
ADDED
data/config/routes.rb
CHANGED
@@ -1,4 +1,4 @@
|
|
1
1
|
Teabag::Engine.routes.draw do
|
2
|
-
|
3
|
-
|
2
|
+
get "/fixtures/*filename", to: "spec#fixtures", via: :get
|
3
|
+
get "/(:suite)", to: "spec#index", via: :get, defaults: { suite: "default" }
|
4
4
|
end
|
@@ -4,21 +4,62 @@ module Teabag::Generators
|
|
4
4
|
|
5
5
|
desc "Installs the Teabag initializer into your application."
|
6
6
|
|
7
|
-
|
8
|
-
|
7
|
+
class_option :framework, type: :string,
|
8
|
+
aliases: "-t",
|
9
|
+
default: "jasmine",
|
10
|
+
desc: "Specify which test framework to use (Available: jasmine, mocha, or qunit)"
|
11
|
+
|
12
|
+
class_option :coffee, type: :boolean,
|
13
|
+
aliases: "-c",
|
14
|
+
default: false,
|
15
|
+
desc: "Generate a CoffeeScript spec helper (instead of Javascript)"
|
16
|
+
|
17
|
+
class_option :env, type: :boolean,
|
18
|
+
aliases: "-e",
|
19
|
+
default: true,
|
20
|
+
desc: "Create the teabag_env.rb file used by the command line interface"
|
21
|
+
|
22
|
+
def validate_framework
|
23
|
+
return if frameworks.include?(options[:framework])
|
24
|
+
puts "Unknown framework -- Known: #{frameworks.join(', ')}"
|
25
|
+
exit
|
26
|
+
end
|
27
|
+
|
28
|
+
def copy_initializers
|
29
|
+
copy_file "templates/#{framework}/initializer.rb", "config/initializers/teabag.rb"
|
30
|
+
copy_file "templates/env.rb", "#{framework_type}/teabag_env.rb" if options[:env]
|
9
31
|
end
|
10
32
|
|
11
33
|
def create_structure
|
12
|
-
empty_directory "
|
13
|
-
empty_directory "
|
34
|
+
empty_directory "#{framework_type}/javascripts/support"
|
35
|
+
empty_directory "#{framework_type}/javascripts/fixtures"
|
14
36
|
end
|
15
37
|
|
16
38
|
def copy_spec_helper
|
17
|
-
copy_file "templates
|
39
|
+
copy_file "templates/#{framework}/#{framework_type}_helper.#{helper_ext}", "#{framework_type}/javascripts/#{framework_type}_helper.#{helper_ext}"
|
18
40
|
end
|
19
41
|
|
20
42
|
def display_readme
|
21
43
|
readme "POST_INSTALL" if behavior == :invoke
|
22
44
|
end
|
45
|
+
|
46
|
+
private
|
47
|
+
|
48
|
+
def framework
|
49
|
+
options[:framework]
|
50
|
+
end
|
51
|
+
|
52
|
+
def frameworks
|
53
|
+
%w{jasmine mocha qunit}
|
54
|
+
end
|
55
|
+
|
56
|
+
def helper_ext
|
57
|
+
(options[:coffee]) ? "coffee" : "js"
|
58
|
+
end
|
59
|
+
|
60
|
+
def framework_type
|
61
|
+
(options[:framework] == "qunit") ? "test" : "spec"
|
62
|
+
end
|
63
|
+
|
23
64
|
end
|
24
65
|
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
# This file allows you to override various Teabag configuration directives when running from the command line. It is not
|
2
|
+
# required from within the Rails environment, so overriding directives that have been defined within the initializer
|
3
|
+
# is not possible.
|
4
|
+
#
|
5
|
+
# Set RAILS_ROOT and load the environment.
|
6
|
+
ENV["RAILS_ROOT"] = File.expand_path("../../", __FILE__)
|
7
|
+
require File.expand_path("../../config/environment", __FILE__)
|
8
|
+
|
9
|
+
# Provide default configuration.
|
10
|
+
#
|
11
|
+
# You can override various configuration directives defined here by using arguments with the teabag command.
|
12
|
+
#
|
13
|
+
# teabag --driver=selenium --suppress-log
|
14
|
+
# rake teabag DRIVER=selenium SUPPRESS_LOG=false
|
15
|
+
Teabag.setup do |config|
|
16
|
+
# Driver
|
17
|
+
#config.driver = "phantomjs" # available: phantomjs, selenium
|
18
|
+
#config.phantomjs_bin = nil
|
19
|
+
|
20
|
+
# Behaviors
|
21
|
+
#config.server_timeout = 20 # timeout for starting the server
|
22
|
+
#config.fail_fast = true # abort after the first failing suite
|
23
|
+
|
24
|
+
# Output
|
25
|
+
#config.formatters = "dot" # available: dot, tap_y, swayze_or_oprah
|
26
|
+
#config.suppress_log = false # suppress logs coming from console[log/error/debug]
|
27
|
+
#config.color = true
|
28
|
+
end
|
@@ -10,7 +10,7 @@ Teabag.setup do |config|
|
|
10
10
|
|
11
11
|
# These paths are appended to the Rails assets paths (relative to config.root), and by default is an array that you
|
12
12
|
# can replace or add to.
|
13
|
-
config.asset_paths = ["spec/javascripts", "spec/javascripts/stylesheets"
|
13
|
+
config.asset_paths = ["spec/javascripts", "spec/javascripts/stylesheets"]
|
14
14
|
|
15
15
|
# Fixtures are rendered through a standard controller. This means you can use things like HAML or RABL/JBuilder, etc.
|
16
16
|
# to generate fixtures within this path.
|
@@ -31,8 +31,8 @@ Teabag.setup do |config|
|
|
31
31
|
# Note: Can also be set to nil.
|
32
32
|
suite.matcher = "{spec/javascripts,app/assets}/**/*_spec.{js,js.coffee,coffee}"
|
33
33
|
|
34
|
-
# Each suite can load a different
|
35
|
-
#
|
34
|
+
# Each suite can load a different helper, which can in turn require additional files. This file is loaded before
|
35
|
+
# your specs are loaded, and can be used as a manifest.
|
36
36
|
suite.helper = "spec_helper"
|
37
37
|
|
38
38
|
# These are the core Teabag javascripts. It's strongly encouraged to include only the base files here. You can
|
@@ -49,18 +49,10 @@ Teabag.setup do |config|
|
|
49
49
|
suite.stylesheets = ["teabag"]
|
50
50
|
end
|
51
51
|
|
52
|
-
# Example suite. Since we're
|
53
|
-
#
|
52
|
+
# Example suite. Since we're just filtering to files already within the root spec/javascripts, these files will also
|
53
|
+
# be run in the default suite -- but can be focused into a more specific suite.
|
54
54
|
#config.suite :targeted do |suite|
|
55
55
|
# suite.matcher = "spec/javascripts/targeted/*_spec.{js,js.coffee,coffee}"
|
56
56
|
#end
|
57
57
|
|
58
|
-
# When Teabag is run via the rake task these configuration directives apply.
|
59
|
-
#
|
60
|
-
#config.server_timeout = 20 # timeout for starting the server
|
61
|
-
#config.driver = "phantomjs" # available: phantomjs, selenium
|
62
|
-
#config.formatters = "dot" # available: dot, tap_y, swayze_or_oprah
|
63
|
-
#config.fail_fast = true # stop running suites after one has failures
|
64
|
-
#config.suppress_log = false # suppress logs coming from console[log/error/debug]
|
65
|
-
|
66
58
|
end if defined?(Teabag) && Teabag.respond_to?(:setup) # let Teabag be undefined outside of development/test/asset groups
|
@@ -0,0 +1,25 @@
|
|
1
|
+
# You can require javascript files here. A good place to start is by requiring your application.js.
|
2
|
+
# require application
|
3
|
+
#
|
4
|
+
# Teabag includes some support files, but you can use anything from your own support path too.
|
5
|
+
# require support/jasmine-jquery
|
6
|
+
# require support/sinon
|
7
|
+
# require support/your-support-file
|
8
|
+
#
|
9
|
+
# Deferring execution
|
10
|
+
# If you're using CommonJS, RequireJS or some other asynchronous library you can defer execution. Call Teabag.execute()
|
11
|
+
# after everything has been loaded. Simple example of a timeout:
|
12
|
+
#
|
13
|
+
# Teabag.defer = true
|
14
|
+
# setTimeout(Teabag.execute, 1000)
|
15
|
+
#
|
16
|
+
# Matching files
|
17
|
+
# By default Teabag will look for files that match _spec.{js,js.coffee,.coffee}. Add a filename_spec.js file in your
|
18
|
+
# spec path and it'll be included in the default suite automatically. If you want to customize suites, check out the
|
19
|
+
# configuration in config/initializers/teabag.rb
|
20
|
+
#
|
21
|
+
# Manifest
|
22
|
+
# If you'd rather require your spec files manually (to control order for instance) you can disable the suite matcher in
|
23
|
+
# the configuration and use this file as a manifest.
|
24
|
+
#
|
25
|
+
# For more information: http://github.com/modeset/teabag
|
@@ -0,0 +1,25 @@
|
|
1
|
+
// You can require javascript files here. A good place to start is by requiring your application.js.
|
2
|
+
// require application
|
3
|
+
//
|
4
|
+
// Teabag includes some support files, but you can use anything from your own support path too.
|
5
|
+
// require support/jasmine-jquery
|
6
|
+
// require support/sinon
|
7
|
+
// require support/your-support-file
|
8
|
+
//
|
9
|
+
// Deferring execution
|
10
|
+
// If you're using CommonJS, RequireJS or some other asynchronous library you can defer execution. Call Teabag.execute()
|
11
|
+
// after everything has been loaded. Simple example of a timeout:
|
12
|
+
//
|
13
|
+
// Teabag.defer = true
|
14
|
+
// setTimeout(Teabag.execute, 1000)
|
15
|
+
//
|
16
|
+
// Matching files
|
17
|
+
// By default Teabag will look for files that match _spec.{js,js.coffee,.coffee}. Add a filename_spec.js file in your
|
18
|
+
// spec path and it'll be included in the default suite automatically. If you want to customize suites, check out the
|
19
|
+
// configuration in config/initializers/teabag.rb
|
20
|
+
//
|
21
|
+
// Manifest
|
22
|
+
// If you'd rather require your spec files manually (to control order for instance) you can disable the suite matcher in
|
23
|
+
// the configuration and use this file as a manifest.
|
24
|
+
//
|
25
|
+
// For more information: http://github.com/modeset/teabag
|
@@ -0,0 +1,58 @@
|
|
1
|
+
Teabag.setup do |config|
|
2
|
+
|
3
|
+
# This determines where the Teabag routes will be mounted. Changing this to "/jasmine" would allow you to browse to
|
4
|
+
# http://localhost:3000/jasmine to run your specs.
|
5
|
+
config.mount_at = "/teabag"
|
6
|
+
|
7
|
+
# This defaults to Rails.root if left nil. If you're testing an engine using a dummy application it can be useful to
|
8
|
+
# set this to your engines root.. E.g. `Teabag::Engine.root`
|
9
|
+
config.root = nil
|
10
|
+
|
11
|
+
# These paths are appended to the Rails assets paths (relative to config.root), and by default is an array that you
|
12
|
+
# can replace or add to.
|
13
|
+
config.asset_paths = ["spec/javascripts", "spec/javascripts/stylesheets"]
|
14
|
+
|
15
|
+
# Fixtures are rendered through a standard controller. This means you can use things like HAML or RABL/JBuilder, etc.
|
16
|
+
# to generate fixtures within this path.
|
17
|
+
config.fixture_path = "spec/javascripts/fixtures"
|
18
|
+
|
19
|
+
# You can modify the default suite configuration and create new suites here. Suites can be isolated from one another.
|
20
|
+
# When defining a suite you can provide a name and a block. If the name is left blank, :default is assumed. You can
|
21
|
+
# omit various directives and the defaults will be used.
|
22
|
+
#
|
23
|
+
# To run a specific suite
|
24
|
+
# - in the browser: http://localhost/teabag/[suite_name]
|
25
|
+
# - from the command line: rake teabag suite=[suite_name]
|
26
|
+
config.suite do |suite|
|
27
|
+
|
28
|
+
# You can specify a file matcher and all matching files will be loaded when the suite is run. It's important that
|
29
|
+
# these files are serve-able from sprockets.
|
30
|
+
#
|
31
|
+
# Note: Can also be set to nil.
|
32
|
+
suite.matcher = "{spec/javascripts,app/assets}/**/*_spec.{js,js.coffee,coffee}"
|
33
|
+
|
34
|
+
# Each suite can load a different helper, which can in turn require additional files. This file is loaded before
|
35
|
+
# your specs are loaded, and can be used as a manifest.
|
36
|
+
suite.helper = "spec_helper"
|
37
|
+
|
38
|
+
# These are the core Teabag javascripts. It's strongly encouraged to include only the base files here. You can
|
39
|
+
# require other support libraries in your spec helper, which allows you to change them without having to restart the
|
40
|
+
# server.
|
41
|
+
#
|
42
|
+
# Available frameworks: teabag-jasmine, teabag-mocha, teabag-qunit
|
43
|
+
#
|
44
|
+
# Note: To use the CoffeeScript source files use `"teabag/mocha"` etc.
|
45
|
+
suite.javascripts = ["teabag-mocha"]
|
46
|
+
|
47
|
+
# If you want to change how Teabag looks, or include your own stylesheets you can do that here. The default is the
|
48
|
+
# stylesheet for the HTML reporter.
|
49
|
+
suite.stylesheets = ["teabag"]
|
50
|
+
end
|
51
|
+
|
52
|
+
# Example suite. Since we're just filtering to files already within the root spec/javascripts, these files will also
|
53
|
+
# be run in the default suite -- but can be focused into a more specific suite.
|
54
|
+
#config.suite :targeted do |suite|
|
55
|
+
# suite.matcher = "spec/javascripts/targeted/*_spec.{js,js.coffee,coffee}"
|
56
|
+
#end
|
57
|
+
|
58
|
+
end if defined?(Teabag) && Teabag.respond_to?(:setup) # let Teabag be undefined outside of development/test/asset groups
|
@@ -0,0 +1,25 @@
|
|
1
|
+
# You can require javascript files here. A good place to start is by requiring your application.js.
|
2
|
+
# require application
|
3
|
+
#
|
4
|
+
# Teabag includes some support files, but you can use anything from your own support path too.
|
5
|
+
# require support/expect
|
6
|
+
# require support/sinon
|
7
|
+
# require support/your-support-file
|
8
|
+
#
|
9
|
+
# Deferring execution
|
10
|
+
# If you're using CommonJS, RequireJS or some other asynchronous library you can defer execution. Call Teabag.execute()
|
11
|
+
# after everything has been loaded. Simple example of a timeout:
|
12
|
+
#
|
13
|
+
# Teabag.defer = true
|
14
|
+
# setTimeout(Teabag.execute, 1000)
|
15
|
+
#
|
16
|
+
# Matching files
|
17
|
+
# By default Teabag will look for files that match _spec.{js,js.coffee,.coffee}. Add a filename_spec.js file in your
|
18
|
+
# spec path and it'll be included in the default suite automatically. If you want to customize suites, check out the
|
19
|
+
# configuration in config/initializers/teabag.rb
|
20
|
+
#
|
21
|
+
# Manifest
|
22
|
+
# If you'd rather require your spec files manually (to control order for instance) you can disable the suite matcher in
|
23
|
+
# the configuration and use this file as a manifest.
|
24
|
+
#
|
25
|
+
# For more information: http://github.com/modeset/teabag
|
@@ -0,0 +1,25 @@
|
|
1
|
+
// You can require javascript files here. A good place to start is by requiring your application.js.
|
2
|
+
// require application
|
3
|
+
//
|
4
|
+
// Teabag includes some support files, but you can use anything from your own support path too.
|
5
|
+
// require support/expect
|
6
|
+
// require support/sinon
|
7
|
+
// require support/your-support-file
|
8
|
+
//
|
9
|
+
// Deferring execution
|
10
|
+
// If you're using CommonJS, RequireJS or some other asynchronous library you can defer execution. Call Teabag.execute()
|
11
|
+
// after everything has been loaded. Simple example of a timeout:
|
12
|
+
//
|
13
|
+
// Teabag.defer = true
|
14
|
+
// setTimeout(Teabag.execute, 1000)
|
15
|
+
//
|
16
|
+
// Matching files
|
17
|
+
// By default Teabag will look for files that match _spec.{js,js.coffee,.coffee}. Add a filename_spec.js file in your
|
18
|
+
// spec path and it'll be included in the default suite automatically. If you want to customize suites, check out the
|
19
|
+
// configuration in config/initializers/teabag.rb
|
20
|
+
//
|
21
|
+
// Manifest
|
22
|
+
// If you'd rather require your spec files manually (to control order for instance) you can disable the suite matcher in
|
23
|
+
// the configuration and use this file as a manifest.
|
24
|
+
//
|
25
|
+
// For more information: http://github.com/modeset/teabag
|
@@ -0,0 +1,58 @@
|
|
1
|
+
Teabag.setup do |config|
|
2
|
+
|
3
|
+
# This determines where the Teabag routes will be mounted. Changing this to "/jasmine" would allow you to browse to
|
4
|
+
# http://localhost:3000/jasmine to run your tests.
|
5
|
+
config.mount_at = "/teabag"
|
6
|
+
|
7
|
+
# This defaults to Rails.root if left nil. If you're testing an engine using a dummy application it can be useful to
|
8
|
+
# set this to your engines root.. E.g. `Teabag::Engine.root`
|
9
|
+
config.root = nil
|
10
|
+
|
11
|
+
# These paths are appended to the Rails assets paths (relative to config.root), and by default is an array that you
|
12
|
+
# can replace or add to.
|
13
|
+
config.asset_paths = ["test/javascripts", "test/javascripts/stylesheets"]
|
14
|
+
|
15
|
+
# Fixtures are rendered through a standard controller. This means you can use things like HAML or RABL/JBuilder, etc.
|
16
|
+
# to generate fixtures within this path.
|
17
|
+
config.fixture_path = "test/javascripts/fixtures"
|
18
|
+
|
19
|
+
# You can modify the default suite configuration and create new suites here. Suites can be isolated from one another.
|
20
|
+
# When defining a suite you can provide a name and a block. If the name is left blank, :default is assumed. You can
|
21
|
+
# omit various directives and the defaults will be used.
|
22
|
+
#
|
23
|
+
# To run a specific suite
|
24
|
+
# - in the browser: http://localhost/teabag/[suite_name]
|
25
|
+
# - from the command line: rake teabag suite=[suite_name]
|
26
|
+
config.suite do |suite|
|
27
|
+
|
28
|
+
# You can specify a file matcher and all matching files will be loaded when the suite is run. It's important that
|
29
|
+
# these files are serve-able from sprockets.
|
30
|
+
#
|
31
|
+
# Note: Can also be set to nil.
|
32
|
+
suite.matcher = "{test/javascripts,app/assets}/**/*_test.{js,js.coffee,coffee}"
|
33
|
+
|
34
|
+
# Each suite can load a different helper, which can in turn require additional files. This file is loaded before
|
35
|
+
# your tests are loaded, and can be used as a manifest.
|
36
|
+
suite.helper = "spec_helper"
|
37
|
+
|
38
|
+
# These are the core Teabag javascripts. It's strongly encouraged to include only the base files here. You can
|
39
|
+
# require other support libraries in your test helper, which allows you to change them without having to restart the
|
40
|
+
# server.
|
41
|
+
#
|
42
|
+
# Available frameworks: teabag-jasmine, teabag-mocha, teabag-qunit
|
43
|
+
#
|
44
|
+
# Note: To use the CoffeeScript source files use `"teabag/qunit"` etc.
|
45
|
+
suite.javascripts = ["teabag-qunit"]
|
46
|
+
|
47
|
+
# If you want to change how Teabag looks, or include your own stylesheets you can do that here. The default is the
|
48
|
+
# stylesheet for the HTML reporter.
|
49
|
+
suite.stylesheets = ["teabag"]
|
50
|
+
end
|
51
|
+
|
52
|
+
# Example suite. Since we're just filtering to files already within the root test/javascripts, these files will also
|
53
|
+
# be run in the default suite -- but can be focused into a more specific suite.
|
54
|
+
#config.suite :targeted do |suite|
|
55
|
+
# suite.matcher = "test/javascripts/targeted/*_test.{js,js.coffee,coffee}"
|
56
|
+
#end
|
57
|
+
|
58
|
+
end if defined?(Teabag) && Teabag.respond_to?(:setup) # let Teabag be undefined outside of development/test/asset groups
|
@@ -0,0 +1,24 @@
|
|
1
|
+
# You can require javascript files here. A good place to start is by requiring your application.js.
|
2
|
+
# require application
|
3
|
+
#
|
4
|
+
# Teabag includes some support files, but you can use anything from your own support path too.
|
5
|
+
# require support/sinon
|
6
|
+
# require support/your-support-file
|
7
|
+
#
|
8
|
+
# Deferring execution
|
9
|
+
# If you're using CommonJS, RequireJS or some other asynchronous library you can defer execution. Call Teabag.execute()
|
10
|
+
# after everything has been loaded. Simple example of a timeout:
|
11
|
+
#
|
12
|
+
# Teabag.defer = true
|
13
|
+
# setTimeout(Teabag.execute, 1000)
|
14
|
+
#
|
15
|
+
# Matching files
|
16
|
+
# By default Teabag will look for files that match _test.{js,js.coffee,.coffee}. Add a filename_test.js file in your
|
17
|
+
# test path and it'll be included in the default suite automatically. If you want to customize suites, check out the
|
18
|
+
# configuration in config/initializers/teabag.rb
|
19
|
+
#
|
20
|
+
# Manifest
|
21
|
+
# If you'd rather require your test files manually (to control order for instance) you can disable the suite matcher in
|
22
|
+
# the configuration and use this file as a manifest.
|
23
|
+
#
|
24
|
+
# For more information: http://github.com/modeset/teabag
|