forked from puppetlabs-toy-chest/razor-server
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRakefile
171 lines (143 loc) · 4.54 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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
require 'rake'
require 'yaml'
task :default do
system("rake -T")
end
namespace :bundler do
task :setup do
require 'bundler/setup'
end
end
task :environment, [:env] => 'bundler:setup' do |cmd, args|
ENV["RACK_ENV"] = args[:env] || "development"
require_relative "./lib/razor/initialize"
end
namespace :db do
desc "Run database migrations"
task :migrate, :env do |cmd, args|
env = args[:env] || "development"
Rake::Task['environment'].invoke(env)
sh "./bin/razor-admin -e #{env} migrate-database"
end
desc "Rollback the database"
task :rollback, :env do |cmd, args|
env = args[:env] || "development"
Rake::Task['environment'].invoke(env)
require 'sequel/extensions/migration'
version = (row = Razor.database[:schema_info].first) ? row[:version] : nil
Sequel::Migrator.apply(Razor.database, "db/migrate", version - 1)
end
desc "Nuke the database (drop all tables)"
task :nuke, :env do |cmd, args|
env = args[:env] || "development"
Rake::Task['environment'].invoke(env)
sh "./bin/razor-admin -e #{env} reset-database"
end
desc "Reset the database"
task :reset, [:env] => [:nuke, :migrate]
end
namespace :spec do
begin
require 'rspec/core'
require 'rspec/core/rake_task'
task :reset_tests do
Rake::Task['db:reset'].invoke("test")
end
desc "Run all specs"
RSpec::Core::RakeTask.new(:all => :reset_tests) do |t|
t.pattern = 'spec/**/*_spec.rb'
end
rescue LoadError
# ignore
end
end
desc "Open a preloaded irb session"
task :console do
$: << File::expand_path(File::join(File::dirname(__FILE__), "lib"))
require 'irb'
require 'razor/initialize'
require 'razor'
puts "Model classes from Razor::Data have been included in the toplevel"
include Razor::Data
ARGV.clear
IRB.start
end
desc "Build an archive"
task :archive do
unless ENV["VERSION"]
puts "Specify the version for the archive with VERSION="
exit 1
end
require 'torquebox-rake-support'
topdir = Pathname.new(File::expand_path(File::dirname(__FILE__)))
pkgdir = topdir + "pkg"
pkgdir.mkpath
full_archive = "razor-server-#{ENV["VERSION"]}-full.knob"
Dir.mktmpdir("razor-server-archive") do |tmp|
puts "Cloning into #{tmp}"
system("git clone -q #{topdir} #{tmp}")
puts "Create archive #{full_archive}"
TorqueBox::DeployUtils.create_archive(
name: full_archive,
app_dir: tmp,
dest_dir: pkgdir.to_s,
package_without: %w[development test doc],
package_gems: true)
end
end
# Support for our internal packaging toolchain. Most people outside of Puppet
# Labs will never actually need to deal with these.
begin
load File.join(File.dirname(__FILE__), 'ext', 'packaging', 'packaging.rake')
rescue LoadError
end
begin
@build_defaults ||= YAML.load_file('ext/build_defaults.yaml')
@packaging_url = @build_defaults['packaging_url']
@packaging_repo = @build_defaults['packaging_repo']
rescue
STDERR.puts "Unable to read the packaging repo info from ext/build_defaults.yaml"
end
namespace :package do
desc "Bootstrap packaging automation, e.g. clone into packaging repo"
task :bootstrap do
if File.exist?("ext/#{@packaging_repo}")
puts "It looks like you already have ext/#{@packaging_repo}. If you don't like it, blow it away with package:implode."
else
cd 'ext' do
%x{git clone #{@packaging_url}}
end
end
end
desc "Remove all cloned packaging automation"
task :implode do
rm_rf "ext/#{@packaging_repo}"
end
desc "Prepare the tree for TroqueBox distribution"
task :torquebox do
# This defaults to the JRuby used on our internal builders, if present, and
# then falls back to searching the path as it should.
jruby = (["/usr/local/share/pl-jruby/bin"] + ENV['PATH'].split(':')).find do |path|
File.executable?(File.join(path, 'jruby'))
end or raise "unable to locate JRuby to run bundler!"
jruby = File.join(jruby, 'jruby')
begin
rm_f "Gemfile.lock"
sh "#{jruby} -S bundle install --clean --no-cache --path vendor/bundle --without 'development test doc'"
rm_f ".bundle/install.log"
rescue
unless @tried_to_install_bundler
# Maybe the executable isn't installed in the parent, try and get it now.
sh "#{jruby} -S gem install bundler" rescue nil
@tried_to_install_bundler = true
retry
end
unless @retried and @retried > 9
@retried = (@retried || 0) + 1
puts "gonna just retry that there bundle install against network errors"
retry
end
raise
end
end
end