Skip to content
Browse files

Merge pull request #25 from phlipper/extract-rails

Extract Rails Support
  • Loading branch information...
2 parents 5b5dc3b + 443c9c5 commit 502dcafd541fea83eb1e7e61580b9ac608f78a4c @elskwid elskwid committed Jan 27, 2013
Showing with 115 additions and 1,105 deletions.
  1. +1 −2 Gemfile
  2. +1 −1 LICENSE
  3. +24 −15 README.md
  4. +8 −27 Rakefile
  5. +2 −2 bin/thincloud-testify
  6. +0 −17 lib/generators/thincloud/test/templates/Guardfile
  7. +0 −21 lib/generators/thincloud/test/templates/minitest_helper_rails.rb
  8. +0 −10 lib/generators/thincloud/test/templates/support/capybara.rb
  9. +0 −12 lib/generators/thincloud/test/templates/support/database_cleaner.rb
  10. +0 −4 lib/generators/thincloud/test/templates/support/factory_girl.rb
  11. +0 −6 lib/generators/thincloud/test/templates/support/minitest_rails.rb
  12. +0 −12 lib/generators/thincloud/test/templates/support/routing_spec.rb
  13. +0 −10 lib/generators/thincloud/test/templates/test.rake
  14. +0 −77 lib/generators/thincloud/test/test_generator.rb
  15. +0 −4 lib/tasks/thincloud-test_tasks.rake
  16. +1 −9 lib/thincloud-test.rb
  17. +2 −2 lib/thincloud/test.rb
  18. +0 −13 lib/thincloud/test/generator.rb
  19. +0 −13 lib/thincloud/test/railtie.rb
  20. 0 {test/dummy → lib/thincloud/test/templates}/Guardfile
  21. 0 lib/{generators → }/thincloud/test/templates/ci/before_script.sh
  22. 0 lib/{generators → }/thincloud/test/templates/ci/ci_runner.sh
  23. 0 lib/{generators → }/thincloud/test/templates/ci/travis.yml
  24. +1 −1 ...cloud/test/templates/minitest_helper_standalone.rb → thincloud/test/templates/minitest_helper.rb}
  25. 0 lib/{generators → }/thincloud/test/templates/support/minitest_reporters.rb
  26. +1 −0 lib/thincloud/test/templates/support/mocha.rb
  27. 0 {test/dummy/lib/tasks → lib/thincloud/test/templates}/test.rake
  28. +54 −0 lib/thincloud/test/test_generator.rb
  29. +1 −1 lib/thincloud/test/version.rb
  30. +0 −1 test/dummy/.gitignore
  31. +0 −261 test/dummy/README.rdoc
  32. +0 −7 test/dummy/Rakefile
  33. +0 −15 test/dummy/app/assets/javascripts/application.js
  34. +0 −13 test/dummy/app/assets/stylesheets/application.css
  35. +0 −3 test/dummy/app/controllers/application_controller.rb
  36. +0 −2 test/dummy/app/helpers/application_helper.rb
  37. 0 test/dummy/app/mailers/.gitkeep
  38. 0 test/dummy/app/models/.gitkeep
  39. +0 −14 test/dummy/app/views/layouts/application.html.erb
  40. +0 −4 test/dummy/config.ru
  41. +0 −59 test/dummy/config/application.rb
  42. +0 −10 test/dummy/config/boot.rb
  43. +0 −25 test/dummy/config/database.yml
  44. +0 −5 test/dummy/config/environment.rb
  45. +0 −37 test/dummy/config/environments/development.rb
  46. +0 −67 test/dummy/config/environments/production.rb
  47. +0 −37 test/dummy/config/environments/test.rb
  48. +0 −7 test/dummy/config/initializers/backtrace_silencers.rb
  49. +0 −15 test/dummy/config/initializers/inflections.rb
  50. +0 −5 test/dummy/config/initializers/mime_types.rb
  51. +0 −7 test/dummy/config/initializers/secret_token.rb
  52. +0 −8 test/dummy/config/initializers/session_store.rb
  53. +0 −14 test/dummy/config/initializers/wrap_parameters.rb
  54. +0 −5 test/dummy/config/locales/en.yml
  55. +0 −58 test/dummy/config/routes.rb
  56. 0 test/dummy/lib/assets/.gitkeep
  57. 0 test/dummy/log/.gitkeep
  58. +0 −26 test/dummy/public/404.html
  59. +0 −26 test/dummy/public/422.html
  60. +0 −25 test/dummy/public/500.html
  61. 0 test/dummy/public/favicon.ico
  62. +0 −6 test/dummy/script/rails
  63. 0 test/dummy/test/factories/.gitkeep
  64. +0 −36 test/dummy/test/minitest_helper.rb
  65. +0 −10 test/integration/navigation_test.rb
  66. +2 −15 test/test_helper.rb
  67. +3 −5 test/thincloud-test_test.rb
  68. +14 −18 thincloud-test.gemspec
View
3 Gemfile
@@ -1,4 +1,3 @@
-source :rubygems
+source "https://rubygems.org"
-# Specify your gem's dependencies in thincloud-test.gemspec
gemspec
View
2 LICENSE
@@ -1,4 +1,4 @@
-Copyright (c) 2012 New Leaders
+Copyright (c) 2012-2013 New Leaders
MIT License
View
39 README.md
@@ -1,14 +1,24 @@
-# Thincloud::Test
+# thincloud-test [![Code Climate](https://codeclimate.com/badge.png)](https://codeclimate.com/github/newleaders/thincloud-test)
## Description
-Testing framework configuration generator for Thincloud apps with support for Rails applications and Rails Engines/Railties.
+Opinionated testing framework dependencies and configuration for Ruby applications.
-## Requirements
+[New Leaders](https://newleaders.com) uses this gem to manage the following dependencies:
+
+* [cane](https://github.com/square/cane)
+* [guard](https://github.com/guard/guard)
+* [guard-minitest](https://github.com/guard/guard-minitest)
+* [minitest](https://github.com/seattlerb/minitest)
+* [minitest-reporters](https://github.com/CapnKernul/minitest-reporters)
+* [mocha](https://github.com/visionmedia/mocha)
+* [rb-fsevent](https://github.com/thibaudgg/rb-fsevent)
+* [simplecov](https://github.com/colszowka/simplecov)
+* [terminal-notifier-guard](https://github.com/Springest/terminal-notifier-guard)
+* [thor](https://github.com/wycats/thor)
-This gem requires Rails 3.2.11+ and has been tested on the following versions:
-* 3.2.11
+## Requirements
This gem has been tested against the following Ruby versions:
@@ -37,26 +47,25 @@ $ gem install thincloud-test
## Usage
-### Rails
+The gem manages the test framework dependencies for you and provides a command to bootstrap a test environment.
-This railtie manages testing dependencies and adds a generator to Rails, `thincloud:test`. Running the generator will run the `minitest-rails` generator and add application configuration files:
+The goal of `thincloud-test` is to be minimal by default but provide additional capabilities by following simple conventions.
-* Invoke the generator:
+If you just want to get started using `minitest`:
-```
-$ rails generate thincloud:test
+```ruby
+require "thincloud/test"
```
-### Rails Engine / Railtie
-
-The gem manages the test framework dependencies for you and provides a command to bootstrap a test environment. Running the command will add `minitest` support and application configuration files:
-
-* Invoke the generator:
+To enable the default New Leaders conventions, run the following command:
```
$ thincloud-testify
```
+This will bootstrap your project with a `test/` directory, a `minitest_helper.rb` with some default configuration, a `test/support/` directory with configuration for `mocha`, custom minitest formatters, a `Guardfile`, a default Travis CI configuration, and more! :tada: :balloon:
+
+
## Contributing
1. [Fork it](https://github.com/newleaders/thincloud-test/fork_select)
View
35 Rakefile
@@ -1,40 +1,21 @@
#!/usr/bin/env rake
begin
- require 'bundler/setup'
+ require "bundler/setup"
rescue LoadError
- puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
+ puts "You must `gem install bundler` and `bundle install` to run rake tasks"
end
-begin
- require 'rdoc/task'
-rescue LoadError
- require 'rdoc/rdoc'
- require 'rake/rdoctask'
- RDoc::Task = Rake::RDocTask
-end
-
-RDoc::Task.new(:rdoc) do |rdoc|
- rdoc.rdoc_dir = 'rdoc'
- rdoc.title = 'Thincloud::Test'
- rdoc.options << '--line-numbers'
- rdoc.rdoc_files.include('README.rdoc')
- rdoc.rdoc_files.include('lib/**/*.rb')
-end
-
-APP_RAKEFILE = File.expand_path("../test/dummy/Rakefile", __FILE__)
-load 'rails/tasks/engine.rake'
-
-
+require "bundler/gem_helper"
Bundler::GemHelper.install_tasks
-require 'rake/testtask'
+require "rake/testtask"
Rake::TestTask.new(:test) do |t|
- t.libs << 'lib'
- t.libs << 'test'
- t.pattern = 'test/**/*_test.rb'
+ t.libs << "lib"
+ t.libs << "test"
+ t.pattern = "test/**/*_test.rb"
t.verbose = false
end
-task :default => :test
+task default: :test
View
4 bin/thincloud-testify
@@ -1,5 +1,5 @@
#!/usr/bin/env ruby
-require "thincloud/test/generator"
+require "thincloud/test/test_generator"
-Thincloud::Test::Generator.generate
+Thincloud::Test::TestGenerator.new.testify!
View
17 lib/generators/thincloud/test/templates/Guardfile
@@ -1,17 +0,0 @@
-# A sample Guardfile
-# More info at https://github.com/guard/guard#readme
-
-guard "minitest" do
- # with Minitest::Spec
- watch(%r|^test/(.*)_test\.rb|)
- watch(%r|^lib/(.*)([^/]+)\.rb|) { |m| "test/#{m[1]}#{m[2]}_test.rb" }
- watch(%r|^test/minitest_helper\.rb|) { "test" }
- watch(%r|^test/support/|) { "test" }
-
- # Rails 3.2
- watch(%r|^app/controllers/(.*)\.rb|) { |m| "test/controllers/#{m[1]}_test.rb" }
- watch(%r|^app/mailers/(.*)\.rb|) { |m| "test/mailers/#{m[1]}_test.rb" }
- watch(%r|^app/helpers/(.*)\.rb|) { |m| "test/helpers/#{m[1]}_test.rb" }
- watch(%r|^app/models/(.*)\.rb|) { |m| "test/models/#{m[1]}_test.rb" }
-end
-
View
21 lib/generators/thincloud/test/templates/minitest_helper_rails.rb
@@ -1,21 +0,0 @@
-if RUBY_ENGINE == "ruby"
- begin
- require "simplecov"
- SimpleCov.start "rails" do
- add_filter "test"
- add_filter "config"
- command_name "MiniTest"
- end
- rescue LoadError
- warn "unable to load SimpleCov"
- end
-end
-
-ENV["RAILS_ENV"] = "test"
-require File.expand_path("../../config/environment", __FILE__)
-
-require "thincloud-test"
-
-# Requires supporting ruby files with custom matchers and macros, etc,
-# in spec/support/ and its subdirectories.
-Dir[File.join("./test/support/**/*.rb")].sort.each { |f| require f }
View
10 lib/generators/thincloud/test/templates/support/capybara.rb
@@ -1,10 +0,0 @@
-require "minitest/rails/capybara"
-
-class MiniTest::Rails::ActionDispatch::IntegrationTest
-
- # Public: Reset the Capybara session after every run.
- teardown do
- Capybara.reset_sessions!
- end
-
-end
View
12 lib/generators/thincloud/test/templates/support/database_cleaner.rb
@@ -1,12 +0,0 @@
-DatabaseCleaner.strategy = :transaction
-DatabaseCleaner.clean_with :truncation
-
-class MiniTest::Spec
- before :each do
- DatabaseCleaner.start
- end
-
- after :each do
- DatabaseCleaner.clean
- end
-end
View
4 lib/generators/thincloud/test/templates/support/factory_girl.rb
@@ -1,4 +0,0 @@
-class MiniTest::Spec
- include FactoryGirl::Syntax::Methods
-end
-FactoryGirl.find_definitions
View
6 lib/generators/thincloud/test/templates/support/minitest_rails.rb
@@ -1,6 +0,0 @@
-class MiniTest::Rails::ActiveSupport::TestCase
- # Register any classes that respond to validate to a specific test class
- Minitest::Spec.register_spec_type(self) do |desc|
- desc.respond_to?(:validate)
- end
-end
View
12 lib/generators/thincloud/test/templates/support/routing_spec.rb
@@ -1,12 +0,0 @@
-class RoutingSpec < MiniTest::Rails::ActiveSupport::TestCase
- include ::ActionDispatch::Assertions::RoutingAssertions
- include ::Rails.application.routes.url_helpers
-
- # Test subjects containing 'Routes' are treated as Routing tests
- # e.g. describe "Product Routes" do ...
- register_spec_type /Routes/, self
-
- before do
- @routes = ::Rails.application.routes
- end
-end
View
10 lib/generators/thincloud/test/templates/test.rake
@@ -1,10 +0,0 @@
-require "rake/testtask"
-
-task default: :test
-
-Rake::TestTask.new(:test) do |t|
- t.libs << "lib"
- t.libs << "test"
- t.pattern = "test/**/*_test.rb"
- t.verbose = false
-end
View
77 lib/generators/thincloud/test/test_generator.rb
@@ -1,77 +0,0 @@
-require "rails"
-
-module Thincloud
- module Generators
- class TestGenerator < ::Rails::Generators::Base
- source_root File.expand_path("../templates", __FILE__)
-
- desc "Generates thincloud test infrastructure."
- def test
- setup_minitest_rails
-
- directory "support", "test/support"
-
- copy_file "test.rake", "lib/tasks/test.rake"
-
- copy_file "Guardfile"
-
- update_gitignore
-
- say_status "", ""
- say_status "success", "thincloud-test has finished."
- end
-
- # Generates thincloud test infrastructure outside of Rails
- no_tasks do
- def standalone
- setup_minitest
-
- copy_file "support/minitest_reporters.rb",
- "test/support/minitest_reporters.rb"
-
- copy_file "test.rake", "lib/tasks/test.rake"
-
- copy_file "Guardfile"
-
- setup_ci
-
- update_gitignore
-
- say_status "", ""
- say_status "success", "thincloud-test standalone has finished."
- say_status "", "Customize .travis.yml and test/ci/* for your project."
- end
- end
-
- private
-
- def update_gitignore
- create_file ".gitignore" unless File.exist?(".gitignore")
- append_file ".gitignore", "coverage"
- end
-
- def setup_ci
- empty_directory "test/ci"
- copy_file "ci/before_script.sh", "test/ci/before_script.sh"
- copy_file "ci/ci_runner.sh", "test/ci/ci_runner.sh"
- copy_file "ci/travis.yml", ".travis.yml"
- end
-
- def setup_minitest_rails
- generate "mini_test:install"
- remove_file "test/minitest_helper.rb"
-
- copy_file "minitest_helper_rails.rb", "test/minitest_helper.rb"
-
- empty_directory "test/factories"
- create_file "test/factories/.gitkeep"
- end
-
- def setup_minitest
- remove_file "test/test_helper.rb"
- copy_file "minitest_helper_standalone.rb", "test/minitest_helper.rb"
- end
-
- end
- end
-end
View
4 lib/tasks/thincloud-test_tasks.rake
@@ -1,4 +0,0 @@
-# desc "Explaining what the task does"
-# task :thincloud-test do
-# # Task goes here
-# end
View
10 lib/thincloud-test.rb
@@ -1,12 +1,4 @@
-require "database_cleaner" # reset database on each test run
-require "minitest/autorun"
-require "minitest/rails"
-require "minitest/pride" # Provides awesome colorful output
-require "minitest-rails-shoulda"
-
-require "thincloud/test"
-require "mocha/setup"
-require "factory_girl"
+require "thincloud/test/version"
module Thincloud
module Test
View
4 lib/thincloud/test.rb
@@ -1,2 +1,2 @@
-require "thincloud/test/version"
-require "thincloud/test/railtie"
+require "minitest/autorun"
+require "minitest/pride" # Provides awesome colorful output
View
13 lib/thincloud/test/generator.rb
@@ -1,13 +0,0 @@
-require "rails/all" # Oh yeah!
-require "rails/generators"
-require "generators/thincloud/test/test_generator"
-
-module Thincloud
- module Test
- class Generator
- def self.generate
- ::Thincloud::Generators::TestGenerator.new.standalone
- end
- end
- end
-end
View
13 lib/thincloud/test/railtie.rb
@@ -1,13 +0,0 @@
-module Thincloud
- module Test
- class Railtie < ::Rails::Railtie
-
- initializer "thincloud.test.generators" do |app|
- app.config.generators do |g|
- g.test_framework :mini_test, spec: true, fixture: false
- end
- end
-
- end
- end
-end
View
0 test/dummy/Guardfile → lib/thincloud/test/templates/Guardfile
File renamed without changes.
View
0 ...ncloud/test/templates/ci/before_script.sh → ...ncloud/test/templates/ci/before_script.sh
File renamed without changes.
View
0 .../thincloud/test/templates/ci/ci_runner.sh → lib/thincloud/test/templates/ci/ci_runner.sh
File renamed without changes.
View
0 ...rs/thincloud/test/templates/ci/travis.yml → lib/thincloud/test/templates/ci/travis.yml
File renamed without changes.
View
2 ...t/templates/minitest_helper_standalone.rb → ...incloud/test/templates/minitest_helper.rb
@@ -11,7 +11,7 @@
end
end
-require "thincloud-test"
+require "thincloud/test"
# Requires supporting ruby files with custom matchers and macros, etc,
# in spec/support/ and its subdirectories.
View
0 ...t/templates/support/minitest_reporters.rb → ...t/templates/support/minitest_reporters.rb
File renamed without changes.
View
1 lib/thincloud/test/templates/support/mocha.rb
@@ -0,0 +1 @@
+require "mocha/setup"
View
0 test/dummy/lib/tasks/test.rake → lib/thincloud/test/templates/test.rake
File renamed without changes.
View
54 lib/thincloud/test/test_generator.rb
@@ -0,0 +1,54 @@
+require "thor"
+
+module Thincloud
+ module Test
+ class TestGenerator < ::Thor::Group
+ include ::Thor::Actions
+
+ source_root File.expand_path("../templates", __FILE__)
+
+ desc "Generates thincloud test infrastructure outside of Rails"
+ def testify!(opts = {})
+ setup_minitest if opts.fetch(:minitest, true)
+
+ copy_file "support/minitest_reporters.rb",
+ "test/support/minitest_reporters.rb"
+
+ copy_file "support/mocha.rb", "test/support/mocha.rb"
+
+ copy_file "test.rake", "lib/tasks/test.rake"
+
+ copy_file "Guardfile"
+
+ setup_ci
+
+ update_gitignore
+
+ say_status "", ""
+ say_status "success", "thincloud-test has finished."
+ say_status "", "Customize .travis.yml and test/ci/* for your project."
+ end
+
+
+ private
+
+ def update_gitignore
+ create_file ".gitignore" unless File.exist?(".gitignore")
+ append_file ".gitignore", "coverage"
+ end
+
+ def setup_ci
+ empty_directory "test/ci"
+ copy_file "ci/before_script.sh", "test/ci/before_script.sh"
+ copy_file "ci/ci_runner.sh", "test/ci/ci_runner.sh"
+ copy_file "ci/travis.yml", ".travis.yml"
+ end
+
+ def setup_minitest
+ remove_file "test/test_helper.rb"
+ copy_file "minitest_helper.rb", "test/minitest_helper.rb"
+ end
+
+ end
+ end
+end
View
2 lib/thincloud/test/version.rb
@@ -1,5 +1,5 @@
module Thincloud
module Test
- VERSION = "0.8.0"
+ VERSION = "1.0.0.pre"
end
end
View
1 test/dummy/.gitignore
@@ -1 +0,0 @@
-coverage
View
261 test/dummy/README.rdoc
@@ -1,261 +0,0 @@
-== Welcome to Rails
-
-Rails is a web-application framework that includes everything needed to create
-database-backed web applications according to the Model-View-Control pattern.
-
-This pattern splits the view (also called the presentation) into "dumb"
-templates that are primarily responsible for inserting pre-built data in between
-HTML tags. The model contains the "smart" domain objects (such as Account,
-Product, Person, Post) that holds all the business logic and knows how to
-persist themselves to a database. The controller handles the incoming requests
-(such as Save New Account, Update Product, Show Post) by manipulating the model
-and directing data to the view.
-
-In Rails, the model is handled by what's called an object-relational mapping
-layer entitled Active Record. This layer allows you to present the data from
-database rows as objects and embellish these data objects with business logic
-methods. You can read more about Active Record in
-link:files/vendor/rails/activerecord/README.html.
-
-The controller and view are handled by the Action Pack, which handles both
-layers by its two parts: Action View and Action Controller. These two layers
-are bundled in a single package due to their heavy interdependence. This is
-unlike the relationship between the Active Record and Action Pack that is much
-more separate. Each of these packages can be used independently outside of
-Rails. You can read more about Action Pack in
-link:files/vendor/rails/actionpack/README.html.
-
-
-== Getting Started
-
-1. At the command prompt, create a new Rails application:
- <tt>rails new myapp</tt> (where <tt>myapp</tt> is the application name)
-
-2. Change directory to <tt>myapp</tt> and start the web server:
- <tt>cd myapp; rails server</tt> (run with --help for options)
-
-3. Go to http://localhost:3000/ and you'll see:
- "Welcome aboard: You're riding Ruby on Rails!"
-
-4. Follow the guidelines to start developing your application. You can find
-the following resources handy:
-
-* The Getting Started Guide: http://guides.rubyonrails.org/getting_started.html
-* Ruby on Rails Tutorial Book: http://www.railstutorial.org/
-
-
-== Debugging Rails
-
-Sometimes your application goes wrong. Fortunately there are a lot of tools that
-will help you debug it and get it back on the rails.
-
-First area to check is the application log files. Have "tail -f" commands
-running on the server.log and development.log. Rails will automatically display
-debugging and runtime information to these files. Debugging info will also be
-shown in the browser on requests from 127.0.0.1.
-
-You can also log your own messages directly into the log file from your code
-using the Ruby logger class from inside your controllers. Example:
-
- class WeblogController < ActionController::Base
- def destroy
- @weblog = Weblog.find(params[:id])
- @weblog.destroy
- logger.info("#{Time.now} Destroyed Weblog ID ##{@weblog.id}!")
- end
- end
-
-The result will be a message in your log file along the lines of:
-
- Mon Oct 08 14:22:29 +1000 2007 Destroyed Weblog ID #1!
-
-More information on how to use the logger is at http://www.ruby-doc.org/core/
-
-Also, Ruby documentation can be found at http://www.ruby-lang.org/. There are
-several books available online as well:
-
-* Programming Ruby: http://www.ruby-doc.org/docs/ProgrammingRuby/ (Pickaxe)
-* Learn to Program: http://pine.fm/LearnToProgram/ (a beginners guide)
-
-These two books will bring you up to speed on the Ruby language and also on
-programming in general.
-
-
-== Debugger
-
-Debugger support is available through the debugger command when you start your
-Mongrel or WEBrick server with --debugger. This means that you can break out of
-execution at any point in the code, investigate and change the model, and then,
-resume execution! You need to install ruby-debug to run the server in debugging
-mode. With gems, use <tt>sudo gem install ruby-debug</tt>. Example:
-
- class WeblogController < ActionController::Base
- def index
- @posts = Post.all
- debugger
- end
- end
-
-So the controller will accept the action, run the first line, then present you
-with a IRB prompt in the server window. Here you can do things like:
-
- >> @posts.inspect
- => "[#<Post:0x14a6be8
- @attributes={"title"=>nil, "body"=>nil, "id"=>"1"}>,
- #<Post:0x14a6620
- @attributes={"title"=>"Rails", "body"=>"Only ten..", "id"=>"2"}>]"
- >> @posts.first.title = "hello from a debugger"
- => "hello from a debugger"
-
-...and even better, you can examine how your runtime objects actually work:
-
- >> f = @posts.first
- => #<Post:0x13630c4 @attributes={"title"=>nil, "body"=>nil, "id"=>"1"}>
- >> f.
- Display all 152 possibilities? (y or n)
-
-Finally, when you're ready to resume execution, you can enter "cont".
-
-
-== Console
-
-The console is a Ruby shell, which allows you to interact with your
-application's domain model. Here you'll have all parts of the application
-configured, just like it is when the application is running. You can inspect
-domain models, change values, and save to the database. Starting the script
-without arguments will launch it in the development environment.
-
-To start the console, run <tt>rails console</tt> from the application
-directory.
-
-Options:
-
-* Passing the <tt>-s, --sandbox</tt> argument will rollback any modifications
- made to the database.
-* Passing an environment name as an argument will load the corresponding
- environment. Example: <tt>rails console production</tt>.
-
-To reload your controllers and models after launching the console run
-<tt>reload!</tt>
-
-More information about irb can be found at:
-link:http://www.rubycentral.org/pickaxe/irb.html
-
-
-== dbconsole
-
-You can go to the command line of your database directly through <tt>rails
-dbconsole</tt>. You would be connected to the database with the credentials
-defined in database.yml. Starting the script without arguments will connect you
-to the development database. Passing an argument will connect you to a different
-database, like <tt>rails dbconsole production</tt>. Currently works for MySQL,
-PostgreSQL and SQLite 3.
-
-== Description of Contents
-
-The default directory structure of a generated Ruby on Rails application:
-
- |-- app
- | |-- assets
- | |-- images
- | |-- javascripts
- | `-- stylesheets
- | |-- controllers
- | |-- helpers
- | |-- mailers
- | |-- models
- | `-- views
- | `-- layouts
- |-- config
- | |-- environments
- | |-- initializers
- | `-- locales
- |-- db
- |-- doc
- |-- lib
- | `-- tasks
- |-- log
- |-- public
- |-- script
- |-- test
- | |-- fixtures
- | |-- functional
- | |-- integration
- | |-- performance
- | `-- unit
- |-- tmp
- | |-- cache
- | |-- pids
- | |-- sessions
- | `-- sockets
- `-- vendor
- |-- assets
- `-- stylesheets
- `-- plugins
-
-app
- Holds all the code that's specific to this particular application.
-
-app/assets
- Contains subdirectories for images, stylesheets, and JavaScript files.
-
-app/controllers
- Holds controllers that should be named like weblogs_controller.rb for
- automated URL mapping. All controllers should descend from
- ApplicationController which itself descends from ActionController::Base.
-
-app/models
- Holds models that should be named like post.rb. Models descend from
- ActiveRecord::Base by default.
-
-app/views
- Holds the template files for the view that should be named like
- weblogs/index.html.erb for the WeblogsController#index action. All views use
- eRuby syntax by default.
-
-app/views/layouts
- Holds the template files for layouts to be used with views. This models the
- common header/footer method of wrapping views. In your views, define a layout
- using the <tt>layout :default</tt> and create a file named default.html.erb.
- Inside default.html.erb, call <% yield %> to render the view using this
- layout.
-
-app/helpers
- Holds view helpers that should be named like weblogs_helper.rb. These are
- generated for you automatically when using generators for controllers.
- Helpers can be used to wrap functionality for your views into methods.
-
-config
- Configuration files for the Rails environment, the routing map, the database,
- and other dependencies.
-
-db
- Contains the database schema in schema.rb. db/migrate contains all the
- sequence of Migrations for your schema.
-
-doc
- This directory is where your application documentation will be stored when
- generated using <tt>rake doc:app</tt>
-
-lib
- Application specific libraries. Basically, any kind of custom code that
- doesn't belong under controllers, models, or helpers. This directory is in
- the load path.
-
-public
- The directory available for the web server. Also contains the dispatchers and the
- default HTML files. This should be set as the DOCUMENT_ROOT of your web
- server.
-
-script
- Helper scripts for automation and generation.
-
-test
- Unit and functional tests along with fixtures. When using the rails generate
- command, template test files will be generated for you and placed in this
- directory.
-
-vendor
- External libraries that the application depends on. Also includes the plugins
- subdirectory. If the app has frozen rails, those gems also go here, under
- vendor/rails/. This directory is in the load path.
View
7 test/dummy/Rakefile
@@ -1,7 +0,0 @@
-#!/usr/bin/env rake
-# Add your own tasks in files placed in lib/tasks ending in .rake,
-# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
-
-require File.expand_path('../config/application', __FILE__)
-
-Dummy::Application.load_tasks
View
15 test/dummy/app/assets/javascripts/application.js
@@ -1,15 +0,0 @@
-// This is a manifest file that'll be compiled into application.js, which will include all the files
-// listed below.
-//
-// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
-// or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path.
-//
-// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
-// the compiled file.
-//
-// WARNING: THE FIRST BLANK LINE MARKS THE END OF WHAT'S TO BE PROCESSED, ANY BLANK LINE SHOULD
-// GO AFTER THE REQUIRES BELOW.
-//
-//= require jquery
-//= require jquery_ujs
-//= require_tree .
View
13 test/dummy/app/assets/stylesheets/application.css
@@ -1,13 +0,0 @@
-/*
- * This is a manifest file that'll be compiled into application.css, which will include all the files
- * listed below.
- *
- * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
- * or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path.
- *
- * You're free to add application-wide styles to this file and they'll appear at the top of the
- * compiled file, but it's generally better to create a new file per style scope.
- *
- *= require_self
- *= require_tree .
- */
View
3 test/dummy/app/controllers/application_controller.rb
@@ -1,3 +0,0 @@
-class ApplicationController < ActionController::Base
- protect_from_forgery
-end
View
2 test/dummy/app/helpers/application_helper.rb
@@ -1,2 +0,0 @@
-module ApplicationHelper
-end
View
0 test/dummy/app/mailers/.gitkeep
No changes.
View
0 test/dummy/app/models/.gitkeep
No changes.
View
14 test/dummy/app/views/layouts/application.html.erb
@@ -1,14 +0,0 @@
-<!DOCTYPE html>
-<html>
-<head>
- <title>Dummy</title>
- <%= stylesheet_link_tag "application", :media => "all" %>
- <%= javascript_include_tag "application" %>
- <%= csrf_meta_tags %>
-</head>
-<body>
-
-<%= yield %>
-
-</body>
-</html>
View
4 test/dummy/config.ru
@@ -1,4 +0,0 @@
-# This file is used by Rack-based servers to start the application.
-
-require ::File.expand_path('../config/environment', __FILE__)
-run Dummy::Application
View
59 test/dummy/config/application.rb
@@ -1,59 +0,0 @@
-require File.expand_path('../boot', __FILE__)
-
-require 'rails/all'
-
-Bundler.require
-require "thincloud-test"
-
-module Dummy
- class Application < Rails::Application
- # Settings in config/environments/* take precedence over those specified here.
- # Application configuration should go into files in config/initializers
- # -- all .rb files in that directory are automatically loaded.
-
- # Custom directories with classes and modules you want to be autoloadable.
- # config.autoload_paths += %W(#{config.root}/extras)
-
- # Only load the plugins named here, in the order given (default is alphabetical).
- # :all can be used as a placeholder for all plugins not explicitly named.
- # config.plugins = [ :exception_notification, :ssl_requirement, :all ]
-
- # Activate observers that should always be running.
- # config.active_record.observers = :cacher, :garbage_collector, :forum_observer
-
- # Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
- # Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
- # config.time_zone = 'Central Time (US & Canada)'
-
- # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
- # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
- # config.i18n.default_locale = :de
-
- # Configure the default encoding used in templates for Ruby 1.9.
- config.encoding = "utf-8"
-
- # Configure sensitive parameters which will be filtered from the log file.
- config.filter_parameters += [:password]
-
- # Enable escaping HTML in JSON.
- config.active_support.escape_html_entities_in_json = true
-
- # Use SQL instead of Active Record's schema dumper when creating the database.
- # This is necessary if your schema can't be completely dumped by the schema dumper,
- # like if you have constraints or database-specific column types
- # config.active_record.schema_format = :sql
-
- # Enforce whitelist mode for mass assignment.
- # This will create an empty whitelist of attributes available for mass-assignment for all models
- # in your app. As such, your models will need to explicitly whitelist or blacklist accessible
- # parameters by using an attr_accessible or attr_protected declaration.
- config.active_record.whitelist_attributes = true
-
- # Enable the asset pipeline
- config.assets.enabled = true
-
- # Version of your assets, change this if you want to expire all your assets
- config.assets.version = '1.0'
- end
-end
-
View
10 test/dummy/config/boot.rb
@@ -1,10 +0,0 @@
-require 'rubygems'
-gemfile = File.expand_path('../../../../Gemfile', __FILE__)
-
-if File.exist?(gemfile)
- ENV['BUNDLE_GEMFILE'] = gemfile
- require 'bundler'
- Bundler.setup
-end
-
-$:.unshift File.expand_path('../../../../lib', __FILE__)
View
25 test/dummy/config/database.yml
@@ -1,25 +0,0 @@
-# SQLite version 3.x
-# gem install sqlite3
-#
-# Ensure the SQLite 3 gem is defined in your Gemfile
-# gem 'sqlite3'
-development:
- adapter: sqlite3
- database: db/development.sqlite3
- pool: 5
- timeout: 5000
-
-# Warning: The database defined as "test" will be erased and
-# re-generated from your development database when you run "rake".
-# Do not set this db to the same as development or production.
-test:
- adapter: sqlite3
- database: db/test.sqlite3
- pool: 5
- timeout: 5000
-
-production:
- adapter: sqlite3
- database: db/production.sqlite3
- pool: 5
- timeout: 5000
View
5 test/dummy/config/environment.rb
@@ -1,5 +0,0 @@
-# Load the rails application
-require File.expand_path('../application', __FILE__)
-
-# Initialize the rails application
-Dummy::Application.initialize!
View
37 test/dummy/config/environments/development.rb
@@ -1,37 +0,0 @@
-Dummy::Application.configure do
- # Settings specified here will take precedence over those in config/application.rb
-
- # In the development environment your application's code is reloaded on
- # every request. This slows down response time but is perfect for development
- # since you don't have to restart the web server when you make code changes.
- config.cache_classes = false
-
- # Log error messages when you accidentally call methods on nil.
- config.whiny_nils = true
-
- # Show full error reports and disable caching
- config.consider_all_requests_local = true
- config.action_controller.perform_caching = false
-
- # Don't care if the mailer can't send
- config.action_mailer.raise_delivery_errors = false
-
- # Print deprecation notices to the Rails logger
- config.active_support.deprecation = :log
-
- # Only use best-standards-support built into browsers
- config.action_dispatch.best_standards_support = :builtin
-
- # Raise exception on mass assignment protection for Active Record models
- config.active_record.mass_assignment_sanitizer = :strict
-
- # Log the query plan for queries taking more than this (works
- # with SQLite, MySQL, and PostgreSQL)
- config.active_record.auto_explain_threshold_in_seconds = 0.5
-
- # Do not compress assets
- config.assets.compress = false
-
- # Expands the lines which load the assets
- config.assets.debug = true
-end
View
67 test/dummy/config/environments/production.rb
@@ -1,67 +0,0 @@
-Dummy::Application.configure do
- # Settings specified here will take precedence over those in config/application.rb
-
- # Code is not reloaded between requests
- config.cache_classes = true
-
- # Full error reports are disabled and caching is turned on
- config.consider_all_requests_local = false
- config.action_controller.perform_caching = true
-
- # Disable Rails's static asset server (Apache or nginx will already do this)
- config.serve_static_assets = false
-
- # Compress JavaScripts and CSS
- config.assets.compress = true
-
- # Don't fallback to assets pipeline if a precompiled asset is missed
- config.assets.compile = false
-
- # Generate digests for assets URLs
- config.assets.digest = true
-
- # Defaults to nil and saved in location specified by config.assets.prefix
- # config.assets.manifest = YOUR_PATH
-
- # Specifies the header that your server uses for sending files
- # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache
- # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx
-
- # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
- # config.force_ssl = true
-
- # See everything in the log (default is :info)
- # config.log_level = :debug
-
- # Prepend all log lines with the following tags
- # config.log_tags = [ :subdomain, :uuid ]
-
- # Use a different logger for distributed setups
- # config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new)
-
- # Use a different cache store in production
- # config.cache_store = :mem_cache_store
-
- # Enable serving of images, stylesheets, and JavaScripts from an asset server
- # config.action_controller.asset_host = "http://assets.example.com"
-
- # Precompile additional assets (application.js, application.css, and all non-JS/CSS are already added)
- # config.assets.precompile += %w( search.js )
-
- # Disable delivery errors, bad email addresses will be ignored
- # config.action_mailer.raise_delivery_errors = false
-
- # Enable threaded mode
- # config.threadsafe!
-
- # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
- # the I18n.default_locale when a translation can not be found)
- config.i18n.fallbacks = true
-
- # Send deprecation notices to registered listeners
- config.active_support.deprecation = :notify
-
- # Log the query plan for queries taking more than this (works
- # with SQLite, MySQL, and PostgreSQL)
- # config.active_record.auto_explain_threshold_in_seconds = 0.5
-end
View
37 test/dummy/config/environments/test.rb
@@ -1,37 +0,0 @@
-Dummy::Application.configure do
- # Settings specified here will take precedence over those in config/application.rb
-
- # The test environment is used exclusively to run your application's
- # test suite. You never need to work with it otherwise. Remember that
- # your test database is "scratch space" for the test suite and is wiped
- # and recreated between test runs. Don't rely on the data there!
- config.cache_classes = true
-
- # Configure static asset server for tests with Cache-Control for performance
- config.serve_static_assets = true
- config.static_cache_control = "public, max-age=3600"
-
- # Log error messages when you accidentally call methods on nil
- config.whiny_nils = true
-
- # Show full error reports and disable caching
- config.consider_all_requests_local = true
- config.action_controller.perform_caching = false
-
- # Raise exceptions instead of rendering exception templates
- config.action_dispatch.show_exceptions = false
-
- # Disable request forgery protection in test environment
- config.action_controller.allow_forgery_protection = false
-
- # Tell Action Mailer not to deliver emails to the real world.
- # The :test delivery method accumulates sent emails in the
- # ActionMailer::Base.deliveries array.
- config.action_mailer.delivery_method = :test
-
- # Raise exception on mass assignment protection for Active Record models
- config.active_record.mass_assignment_sanitizer = :strict
-
- # Print deprecation notices to the stderr
- config.active_support.deprecation = :stderr
-end
View
7 test/dummy/config/initializers/backtrace_silencers.rb
@@ -1,7 +0,0 @@
-# Be sure to restart your server when you modify this file.
-
-# You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
-# Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ }
-
-# You can also remove all the silencers if you're trying to debug a problem that might stem from framework code.
-# Rails.backtrace_cleaner.remove_silencers!
View
15 test/dummy/config/initializers/inflections.rb
@@ -1,15 +0,0 @@
-# Be sure to restart your server when you modify this file.
-
-# Add new inflection rules using the following format
-# (all these examples are active by default):
-# ActiveSupport::Inflector.inflections do |inflect|
-# inflect.plural /^(ox)$/i, '\1en'
-# inflect.singular /^(ox)en/i, '\1'
-# inflect.irregular 'person', 'people'
-# inflect.uncountable %w( fish sheep )
-# end
-#
-# These inflection rules are supported but not enabled by default:
-# ActiveSupport::Inflector.inflections do |inflect|
-# inflect.acronym 'RESTful'
-# end
View
5 test/dummy/config/initializers/mime_types.rb
@@ -1,5 +0,0 @@
-# Be sure to restart your server when you modify this file.
-
-# Add new mime types for use in respond_to blocks:
-# Mime::Type.register "text/richtext", :rtf
-# Mime::Type.register_alias "text/html", :iphone
View
7 test/dummy/config/initializers/secret_token.rb
@@ -1,7 +0,0 @@
-# Be sure to restart your server when you modify this file.
-
-# Your secret key for verifying the integrity of signed cookies.
-# If you change this key, all old signed cookies will become invalid!
-# Make sure the secret is at least 30 characters and all random,
-# no regular words or you'll be exposed to dictionary attacks.
-Dummy::Application.config.secret_token = 'bf8bc9092fdb9df9874a35c992dfd0f4791cb5e5dc29a0af41731c90df5b2374e0d0660e68a977217a5b225cc13ff8a5dfb776a51533304c485de10b3a40eb64'
View
8 test/dummy/config/initializers/session_store.rb
@@ -1,8 +0,0 @@
-# Be sure to restart your server when you modify this file.
-
-Dummy::Application.config.session_store :cookie_store, key: '_dummy_session'
-
-# Use the database for sessions instead of the cookie-based default,
-# which shouldn't be used to store highly confidential information
-# (create the session table with "rails generate session_migration")
-# Dummy::Application.config.session_store :active_record_store
View
14 test/dummy/config/initializers/wrap_parameters.rb
@@ -1,14 +0,0 @@
-# Be sure to restart your server when you modify this file.
-#
-# This file contains settings for ActionController::ParamsWrapper which
-# is enabled by default.
-
-# Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array.
-ActiveSupport.on_load(:action_controller) do
- wrap_parameters format: [:json]
-end
-
-# Disable root element in JSON by default.
-ActiveSupport.on_load(:active_record) do
- self.include_root_in_json = false
-end
View
5 test/dummy/config/locales/en.yml
@@ -1,5 +0,0 @@
-# Sample localization file for English. Add more files in this directory for other locales.
-# See https://github.com/svenfuchs/rails-i18n/tree/master/rails%2Flocale for starting points.
-
-en:
- hello: "Hello world"
View
58 test/dummy/config/routes.rb
@@ -1,58 +0,0 @@
-Dummy::Application.routes.draw do
- # The priority is based upon order of creation:
- # first created -> highest priority.
-
- # Sample of regular route:
- # match 'products/:id' => 'catalog#view'
- # Keep in mind you can assign values other than :controller and :action
-
- # Sample of named route:
- # match 'products/:id/purchase' => 'catalog#purchase', :as => :purchase
- # This route can be invoked with purchase_url(:id => product.id)
-
- # Sample resource route (maps HTTP verbs to controller actions automatically):
- # resources :products
-
- # Sample resource route with options:
- # resources :products do
- # member do
- # get 'short'
- # post 'toggle'
- # end
- #
- # collection do
- # get 'sold'
- # end
- # end
-
- # Sample resource route with sub-resources:
- # resources :products do
- # resources :comments, :sales
- # resource :seller
- # end
-
- # Sample resource route with more complex sub-resources
- # resources :products do
- # resources :comments
- # resources :sales do
- # get 'recent', :on => :collection
- # end
- # end
-
- # Sample resource route within a namespace:
- # namespace :admin do
- # # Directs /admin/products/* to Admin::ProductsController
- # # (app/controllers/admin/products_controller.rb)
- # resources :products
- # end
-
- # You can have the root of your site routed with "root"
- # just remember to delete public/index.html.
- # root :to => 'welcome#index'
-
- # See how all your routes lay out with "rake routes"
-
- # This is a legacy wild controller route that's not recommended for RESTful applications.
- # Note: This route will make all actions in every controller accessible via GET requests.
- # match ':controller(/:action(/:id))(.:format)'
-end
View
0 test/dummy/lib/assets/.gitkeep
No changes.
View
0 test/dummy/log/.gitkeep
No changes.
View
26 test/dummy/public/404.html
@@ -1,26 +0,0 @@
-<!DOCTYPE html>
-<html>
-<head>
- <title>The page you were looking for doesn't exist (404)</title>
- <style type="text/css">
- body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
- div.dialog {
- width: 25em;
- padding: 0 4em;
- margin: 4em auto 0 auto;
- border: 1px solid #ccc;
- border-right-color: #999;
- border-bottom-color: #999;
- }
- h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
- </style>
-</head>
-
-<body>
- <!-- This file lives in public/404.html -->
- <div class="dialog">
- <h1>The page you were looking for doesn't exist.</h1>
- <p>You may have mistyped the address or the page may have moved.</p>
- </div>
-</body>
-</html>
View
26 test/dummy/public/422.html
@@ -1,26 +0,0 @@
-<!DOCTYPE html>
-<html>
-<head>
- <title>The change you wanted was rejected (422)</title>
- <style type="text/css">
- body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
- div.dialog {
- width: 25em;
- padding: 0 4em;
- margin: 4em auto 0 auto;
- border: 1px solid #ccc;
- border-right-color: #999;
- border-bottom-color: #999;
- }
- h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
- </style>
-</head>
-
-<body>
- <!-- This file lives in public/422.html -->
- <div class="dialog">
- <h1>The change you wanted was rejected.</h1>
- <p>Maybe you tried to change something you didn't have access to.</p>
- </div>
-</body>
-</html>
View
25 test/dummy/public/500.html
@@ -1,25 +0,0 @@
-<!DOCTYPE html>
-<html>
-<head>
- <title>We're sorry, but something went wrong (500)</title>
- <style type="text/css">
- body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
- div.dialog {
- width: 25em;
- padding: 0 4em;
- margin: 4em auto 0 auto;
- border: 1px solid #ccc;
- border-right-color: #999;
- border-bottom-color: #999;
- }
- h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
- </style>
-</head>
-
-<body>
- <!-- This file lives in public/500.html -->
- <div class="dialog">
- <h1>We're sorry, but something went wrong.</h1>
- </div>
-</body>
-</html>
View
0 test/dummy/public/favicon.ico
No changes.
View
6 test/dummy/script/rails
@@ -1,6 +0,0 @@
-#!/usr/bin/env ruby
-# This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application.
-
-APP_PATH = File.expand_path('../../config/application', __FILE__)
-require File.expand_path('../../config/boot', __FILE__)
-require 'rails/commands'
View
0 test/dummy/test/factories/.gitkeep
No changes.
View
36 test/dummy/test/minitest_helper.rb
@@ -1,36 +0,0 @@
-if RUBY_ENGINE == "ruby"
- begin
- require "simplecov"
- SimpleCov.add_filter "test"
- SimpleCov.add_filter "config"
- SimpleCov.command_name "MiniTest"
- SimpleCov.start
- rescue LoadError
- warn "unable to load SimpleCov"
- end
-end
-
-ENV["RAILS_ENV"] = "test"
-require File.expand_path('../../config/environment', __FILE__)
-
-require "minitest/autorun"
-require "minitest/rails"
-require "minitest/pride" # Provides awesome colorful output
-
-# Uncomment if you want Capybara in accceptance/integration tests
-# require "minitest/rails/capybara"
-
-require "mocha/setup"
-
-# Requires supporting ruby files with custom matchers and macros, etc,
-# in spec/support/ and its subdirectories.
-Dir[File.join("./test/support/**/*.rb")].sort.each { |f| require f }
-
-class MiniTest::Rails::ActiveSupport::TestCase
- # Setup all fixtures in test/fixtures/*.(yml|csv) for all tests in alphabetical order.
- # fixtures :all
-
- # Add more helper methods to be used by all tests here...
-end
-
-MiniTest::Rails.override_testunit!
View
10 test/integration/navigation_test.rb
@@ -1,10 +0,0 @@
-require 'test_helper'
-
-class NavigationTest < ActionDispatch::IntegrationTest
- fixtures :all
-
- # test "the truth" do
- # assert true
- # end
-end
-
View
17 test/test_helper.rb
@@ -1,15 +1,2 @@
-# Configure Rails Environment
-ENV["RAILS_ENV"] = "test"
-
-require File.expand_path("../dummy/config/environment.rb", __FILE__)
-require "rails/test_help"
-
-Rails.backtrace_cleaner.remove_silencers!
-
-# Load support files
-Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each { |f| require f }
-
-# Load fixtures from the engine
-if ActiveSupport::TestCase.method_defined?(:fixture_path=)
- ActiveSupport::TestCase.fixture_path = File.expand_path("../fixtures", __FILE__)
-end
+require "minitest/autorun"
+require "minitest/pride"
View
8 test/thincloud-test_test.rb
@@ -1,7 +1,5 @@
-require 'test_helper'
+require "test_helper"
-class ThincloudTestTest < ActiveSupport::TestCase
- test "truth" do
- assert_kind_of Module, Thincloud::Test
- end
+describe Thincloud::Test do
+ it { Thincloud::Test.must_be_kind_of Module }
end
View
32 thincloud-test.gemspec
@@ -5,8 +5,10 @@ Gem::Specification.new do |s|
s.authors = ["Robert Bousquet", "Phil Cohen", "Don Morrison"]
s.email = ["rbousquet@newleaders.com", "pcohen@newleaders.com",
"dmorrison@newleaders.com"]
- s.description = "Test harness generator for new Thincloud apps."
- s.summary = "Test harness generator for new Thincloud apps."
+ s.description = "Opinionated test dependencies and conventions for " <<
+ "Ruby applications."
+ s.summary = "Opinionated test dependencies and conventions for " <<
+ "Ruby applications."
s.homepage = "http://newleaders.github.com/thincloud-test"
s.files = `git ls-files`.split($\)
@@ -16,22 +18,16 @@ Gem::Specification.new do |s|
s.require_paths = ["lib"]
s.version = Thincloud::Test::VERSION
- s.add_dependency "rails", "~> 3.2.11"
- s.add_dependency "cane", "~> 2.5.0"
- s.add_dependency "capybara", "~> 2.0.2"
- s.add_dependency "database_cleaner", "~> 0.9.1"
- s.add_dependency "guard", "~> 1.6.1"
- s.add_dependency "factory_girl_rails", "~> 4.1.0"
- s.add_dependency "minitest", "~> 4.5.0"
- s.add_dependency "minitest-rails", "~> 0.5.0"
- s.add_dependency "guard-minitest", "~> 0.5.0"
- s.add_dependency "minitest-rails-shoulda", "~> 0.4.0"
- s.add_dependency "rb-fsevent", "~> 0.9.1"
- s.add_dependency "simplecov", "~> 0.7.1"
+ s.add_dependency "cane", "~> 2.5.2"
+ s.add_dependency "guard", "~> 1.6.1"
+ s.add_dependency "minitest", "~> 4.5.0"
+ s.add_dependency "minitest-reporters", "~> 0.14.7"
+ s.add_dependency "guard-minitest", "~> 0.5.0"
+ s.add_dependency "rb-fsevent", "~> 0.9.1"
+ s.add_dependency "simplecov", "~> 0.7.1"
s.add_dependency "terminal-notifier-guard", "~> 1.5.3"
- s.add_dependency "mocha", "~> 0.13.2" # Must be after minitest
- s.add_dependency "minitest-rails-capybara", "~> 0.5.1"
- s.add_dependency "shoulda-matchers", "1.4.1" # 1.4.2 requires mocha 0.10
- s.add_dependency "minitest-reporters", "~> 0.14.6"
+ s.add_dependency "thor", "~> 0.17.0"
+ s.add_dependency "mocha", "~> 0.13.2" # Must be after minitest
+ s.add_development_dependency "rake"
end

0 comments on commit 502dcaf

Please sign in to comment.
Something went wrong with that request. Please try again.