forked from lukeredpath/mimic
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRakefile
99 lines (81 loc) · 2.79 KB
/
Rakefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
require 'rubygems'
require 'cucumber'
require 'cucumber/rake/task'
require 'rspec/core/rake_task'
ENV["MIMIC_TEST_PROXY"] = nil
desc "Run all Cucumber features"
Cucumber::Rake::Task.new(:features) do |t|
t.cucumber_opts = "features --format pretty"
end
desc "Run all specs"
RSpec::Core::RakeTask.new(:spec) do |t|
end
task :default => :spec
task :all => [:spec, :features]
require "rubygems/package_task"
require "rdoc/task"
# This builds the actual gem. For details of what all these options
# mean, and other ones you can add, check the documentation here:
#
# http://rubygems.org/read/chapter/20
#
spec = Gem::Specification.new do |s|
# Change these as appropriate
s.name = "mimic"
s.version = "0.4.3"
s.summary = "A Ruby gem for faking external web services for testing"
s.authors = "Luke Redpath"
s.email = "[email protected]"
s.homepage = "http://lukeredpath.co.uk"
s.has_rdoc = true
s.extra_rdoc_files = %w(README.md)
s.rdoc_options = %w(--main README.md)
# Add any extra files to include in the gem
s.files = %w(LICENSE CHANGES Rakefile README.md) + Dir.glob("{spec,lib/**/*}")
s.require_paths = ["lib"]
# If you want to depend on other gems, add them here, along with any
# relevant versions
s.add_dependency("rack")
s.add_dependency("sinatra")
s.add_dependency("json")
s.add_dependency("plist")
# If your tests use any gems, include them here
s.add_development_dependency("rspec", "~> 2.4.0")
s.add_development_dependency("cucumber")
s.add_development_dependency("mocha")
s.add_development_dependency("rest-client")
end
# This task actually builds the gem. We also regenerate a static
# .gemspec file, which is useful if something (i.e. GitHub) will
# be automatically building a gem for this project. If you're not
# using GitHub, edit as appropriate.
#
# To publish your gem online, install the 'gemcutter' gem; Read more
# about that here: http://gemcutter.org/pages/gem_docs
Gem::PackageTask.new(spec) do |pkg|
pkg.gem_spec = spec
end
desc "Build the gemspec file #{spec.name}.gemspec"
task :gemspec do
file = File.dirname(__FILE__) + "/#{spec.name}.gemspec"
File.open(file, "w") {|f| f << spec.to_ruby }
end
task :package => :gemspec
# Generate documentation
RDoc::Task.new do |rd|
rd.main = "README.md"
rd.rdoc_files.include("README.md", "lib/**/*.rb")
rd.rdoc_dir = "rdoc"
end
desc 'Clear out RDoc and generated packages'
task :clean => [:clobber_rdoc, :clobber_package] do
rm "#{spec.name}.gemspec"
end
task 'Release if all specs pass'
task :release => [:clean, :bundle, :spec, :features, :package] do
system("gem push pkg/#{spec.name}-#{spec.version}.gem")
end
desc 'Install all gem dependencies'
task :bundle => :gemspec do
system("bundle")
end