forked from DavyJonesLocker/postgres_ext-serializers
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Rakefile
124 lines (104 loc) · 3.26 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
require 'bundler/gem_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
task :setup do
if File.exist?('.env')
puts 'This will overwrite your existing .env file'
end
print 'Enter your database name: [postgres_ext_serializers_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 :psql => :load_db_settings do
exec "psql #{ENV['DATABASE_NAME']}"
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.create_table :people, force: true do |t|
t.string "first_name"
t.string "last_name"
t.datetime "created_at"
t.datetime "updated_at"
end
ActiveRecord::Base.connection.create_table :notes, force: true do |t|
t.string "name"
t.string "content"
t.datetime "created_at"
t.datetime "updated_at"
end
ActiveRecord::Base.connection.create_table :tags, force: true do |t|
t.integer "note_id"
t.string "name"
t.boolean "popular"
t.datetime "created_at"
t.datetime "updated_at"
end
ActiveRecord::Base.connection.create_table :offers, force: true do |t|
t.integer "created_by_id"
t.integer "reviewed_by_id"
t.datetime "created_at"
t.datetime "updated_at"
end
ActiveRecord::Base.connection.create_table :users, force: true do |t|
t.string "name"
t.string "mobile"
t.datetime "created_at"
t.datetime "updated_at"
end
ActiveRecord::Base.connection.create_table :addresses, force: true do |t|
t.string "district_name"
t.integer "user_id"
t.datetime "created_at"
t.datetime "updated_at"
end
puts 'Database migrated'
end
end
namespace :test do
desc 'Test against all supported ActiveRecord versions'
task :all do
# Escape current bundler environment
Bundler.with_clean_env do
# Currently only supports Active Record v4.0-v4.2
%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
end