require 'rake/rdoctask' require 'rake/gempackagetask' require 'rake/testtask' module Mocha VERSION = "0.9.7" end desc "Run all tests" task 'default' => ['test:units', 'test:acceptance', 'test:performance'] namespace 'test' do unit_tests = FileList['test/unit/**/*_test.rb'] acceptance_tests = FileList['test/acceptance/*_test.rb'] desc "Run unit tests" Rake::TestTask.new('units') do |t| t.libs << 'test' t.test_files = unit_tests t.verbose = true t.warning = true end desc "Run acceptance tests" Rake::TestTask.new('acceptance') do |t| t.libs << 'test' t.test_files = acceptance_tests t.verbose = true t.warning = true end # require 'rcov/rcovtask' # Rcov::RcovTask.new('coverage') do |t| # t.libs << 'test' # t.test_files = unit_tests + acceptance_tests # t.verbose = true # t.warning = true # t.rcov_opts << '--sort coverage' # t.rcov_opts << '--xref' # end desc "Run performance tests" task 'performance' do require 'test/acceptance/stubba_example_test' require 'test/acceptance/mocha_example_test' iterations = 1000 puts "\nBenchmarking with #{iterations} iterations..." [MochaExampleTest, StubbaExampleTest].each do |test_case| puts "#{test_case}: #{benchmark_test_case(test_case, iterations)} seconds." end end end def benchmark_test_case(klass, iterations) require 'benchmark' require 'test/unit/ui/console/testrunner' begin require 'test/unit/ui/console/outputlevel' silent_option = { :output_level => Test::Unit::UI::Console::OutputLevel::SILENT } rescue LoadError silent_option = Test::Unit::UI::SILENT end time = Benchmark.realtime { iterations.times { Test::Unit::UI::Console::TestRunner.run(klass, silent_option) } } end desc 'Generate RDoc' Rake::RDocTask.new('rdoc') do |task| task.main = 'README' task.title = "Mocha #{Mocha::VERSION}" task.rdoc_dir = 'doc' task.template = File.expand_path(File.join(File.dirname(__FILE__), "templates", "html_with_google_analytics")) task.rdoc_files.include( 'README', 'RELEASE', 'COPYING', 'MIT-LICENSE', 'agiledox.txt', 'lib/mocha/api.rb', 'lib/mocha/mock.rb', 'lib/mocha/expectation.rb', 'lib/mocha/object.rb', 'lib/mocha/parameter_matchers.rb', 'lib/mocha/parameter_matchers', 'lib/mocha/state_machine.rb', 'lib/mocha/configuration.rb', 'lib/mocha/stubbing_error.rb' ) end desc "Generate all documentation" task 'generate_docs' => ['clobber_rdoc', 'rdoc', 'examples', 'agiledox.txt'] desc "Upload RDoc to RubyForge" task 'publish_docs' do require 'rake/contrib/sshpublisher' Rake::SshDirPublisher.new("jamesmead@rubyforge.org", "/var/www/gforge-projects/mocha", "doc").upload end desc "Generate agiledox-like documentation for tests" file 'agiledox.txt' do File.open('agiledox.txt', 'w') do |output| tests = FileList['test/**/*_test.rb'] tests.each do |file| m = %r".*/([^/].*)_test.rb".match(file) output << m[1]+" should:\n" test_definitions = File::readlines(file).select {|line| line =~ /.*def test.*/} test_definitions.sort.each do |definition| m = %r"test_(should_)?(.*)".match(definition) output << " - "+m[2].gsub(/_/," ") << "\n" end end end end desc "Convert example ruby files to syntax-highlighted html" task 'examples' do require 'coderay' mkdir_p 'doc/examples' File.open('doc/examples/coderay.css', 'w') do |output| output << CodeRay::Encoders[:html]::CSS.new.stylesheet end ['mocha', 'stubba', 'misc'].each do |filename| File.open("doc/examples/#{filename}.html", 'w') do |file| file << "" file << "" file << %q() file << "" file << "" file << CodeRay.scan_file("examples/#{filename}.rb").html.div file << "" file << "" end end end Gem.manage_gems if Gem::RubyGemsVersion < '1.2.0' def build_specification(version = Mocha::VERSION) Gem::Specification.new do |s| s.name = "mocha" s.summary = "Mocking and stubbing library" s.version = version s.platform = Gem::Platform::RUBY s.author = 'James Mead' s.description = <<-EOF Mocking and stubbing library with JMock/SchMock syntax, which allows mocking and stubbing of methods on real (non-mock) classes. EOF s.email = 'mocha-developer@googlegroups.com' s.homepage = 'http://mocha.rubyforge.org' s.rubyforge_project = 'mocha' s.has_rdoc = true s.extra_rdoc_files = ['README', 'COPYING'] s.rdoc_options << '--title' << 'Mocha' << '--main' << 'README' << '--line-numbers' s.add_dependency('rake') s.files = FileList['{lib,test,examples}/**/*.rb', '[A-Z]*'].exclude('TODO').to_a end end specification = build_specification Rake::GemPackageTask.new(specification) do |package| package.need_zip = true package.need_tar = true end desc 'Generate updated gemspec with unique version, which will cause gem to be auto-built on github.' task :update_gemspec do File.open('mocha.gemspec', 'w') do |output| output << build_specification(Mocha::VERSION + '.' + Time.now.strftime('%Y%m%d%H%M%S')).to_ruby end end task 'verify_user' do raise "RUBYFORGE_USER environment variable not set!" unless ENV['RUBYFORGE_USER'] end task 'verify_password' do raise "RUBYFORGE_PASSWORD environment variable not set!" unless ENV['RUBYFORGE_PASSWORD'] end desc "Publish package files on RubyForge." task 'publish_packages' => ['verify_user', 'verify_password', 'clobber_package', 'package'] do require 'meta_project' require 'rake/contrib/xforge' release_files = FileList[ "pkg/mocha-#{Mocha::VERSION}.gem", "pkg/mocha-#{Mocha::VERSION}.tgz", "pkg/mocha-#{Mocha::VERSION}.zip" ] Rake::XForge::Release.new(MetaProject::Project::XForge::RubyForge.new('mocha')) do |release| release.user_name = ENV['RUBYFORGE_USER'] release.password = ENV['RUBYFORGE_PASSWORD'] release.files = release_files.to_a release.release_name = "Mocha #{Mocha::VERSION}" release.release_changes = '' release.release_notes = '' end end desc "Do a full release." task 'release' => ['default', 'generate_docs', 'publish_packages', 'publish_docs', 'update_gemspec'] do puts puts "*** Remember to commit newly generated gemspec after release ***" puts end