forked from gocardless/postgres_ext
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Rakefile
125 lines (104 loc) · 3.17 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
#!/usr/bin/env rake
begin
require 'bundler/setup'
rescue LoadError
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 = 'postgres_ext'
rdoc.options << '--line-numbers'
rdoc.rdoc_files.include('README.rdoc')
rdoc.rdoc_files.include('lib/**/*.rb')
end
Bundler::GemHelper.install_tasks
require 'rake/testtask'
Rake::TestTask.new(:test) do |t|
t.libs << 'lib'
t.libs << 'test'
t.pattern = 'test/**/*_test.rb'
t.verbose = false
end
task :default => :test
namespace :test do
desc 'Test against all supported ActiveRecord versions'
task :all do
# Currently only supports Active Record v4.0
%w(4.0.x 4.1.x 4.2.x).each do |version|
sh "BUNDLE_GEMFILE='gemfiles/Gemfile.activerecord-#{version}' bundle install --quiet"
sh "BUNDLE_GEMFILE='gemfiles/Gemfile.activerecord-#{version}' bundle exec rake test"
end
end
end
task :setup do
if File.exist?('.env')
puts 'This will overwrite your existing .env file'
end
print 'Enter your database name: [postgres_ext_test] '
db_name = STDIN.gets.chomp
print 'Enter your database user: [] '
db_user = STDIN.gets.chomp
print 'Enter your database password: [] '
db_password = STDIN.gets.chomp
print 'Enter your database server: [localhost] '
db_server = STDIN.gets.chomp
db_name = 'postgres_ext_test' if db_name.empty?
db_password = ":#{db_password}" unless db_password.empty?
db_server = 'localhost' if db_server.empty?
db_server = "@#{db_server}" unless db_user.empty?
env_path = File.expand_path('./.env')
File.open(env_path, 'w') do |file|
file.puts "DATABASE_NAME=#{db_name}"
file.puts "DATABASE_URL=\"postgres://#{db_user}#{db_password}#{db_server}/#{db_name}\""
end
puts '.env file saved'
end
namespace :db do
task :load_db_settings do
require 'active_record'
unless ENV['DATABASE_URL']
require 'dotenv'
Dotenv.load
end
end
task :drop => :load_db_settings do
%x{ dropdb #{ENV['DATABASE_NAME']} }
end
task :create => :load_db_settings do
%x{ createdb #{ENV['DATABASE_NAME']} }
end
task :migrate => :load_db_settings do
ActiveRecord::Base.establish_connection
ActiveRecord::Base.connection.enable_extension 'hstore'
ActiveRecord::Base.connection.create_table :people, force: true do |t|
t.inet "ip"
t.cidr "subnet"
t.integer "tag_ids", array: true
t.string "tags", array: true
t.hstore "data"
t.integer "lucky_number"
t.datetime "created_at"
t.datetime "updated_at"
end
ActiveRecord::Base.connection.create_table :people_tags, force: true do |t|
t.integer "person_id"
t.integer "tag_id"
end
ActiveRecord::Base.connection.create_table :tags, force: true do |t|
t.integer "person_id"
t.string "categories", array: true
t.datetime "created_at"
t.datetime "updated_at"
t.integer "parent_id"
t.string "type"
end
puts 'Database migrated'
end
end