Commit 309e2ceaf85929cc1d8dceaa24620cc1bdae0ede
Exists in
master
and in
4 other branches
Merge pull request #2650 from riyad/setup-task-warning
Improve setup task, by making it less dangerous
Showing
4 changed files
with
47 additions
and
21 deletions
Show diff stats
doc/install/installation.md
... | ... | @@ -260,7 +260,7 @@ used for the `email.from` setting in `config/gitlab.yml`) |
260 | 260 | |
261 | 261 | ## Initialise Database and Activate Advanced Features |
262 | 262 | |
263 | - sudo -u gitlab -H bundle exec rake gitlab:app:setup RAILS_ENV=production | |
263 | + sudo -u gitlab -H bundle exec rake gitlab:setup RAILS_ENV=production | |
264 | 264 | |
265 | 265 | |
266 | 266 | ## Install Init Script | ... | ... |
doc/raketasks/maintenance.md
1 | -### Setup production application | |
2 | - | |
3 | -Runs the following rake tasks: | |
4 | - | |
5 | -* db:setup (Create the database, load the schema, and initialize with the seed data) | |
6 | -* db:seed_fu (Loads seed data for the current environment.) | |
7 | -* gitlab:app:enable_automerge (see "Features") | |
8 | - | |
9 | -``` | |
10 | -bundle exec rake gitlab:app:setup RAILS_ENV=production | |
11 | -``` | |
12 | - | |
13 | - | |
14 | 1 | ### Gather information about GitLab and the system it runs on |
15 | 2 | |
16 | 3 | This command gathers information about your GitLab installation and the System | ... | ... |
lib/tasks/gitlab/setup.rake
1 | 1 | namespace :gitlab do |
2 | - namespace :app do | |
3 | - desc "GITLAB | Setup production application" | |
4 | - task :setup => [ | |
5 | - 'db:setup', | |
6 | - 'db:seed_fu', | |
7 | - 'gitlab:enable_automerge' | |
8 | - ] | |
2 | + desc "GITLAB | Setup production application" | |
3 | + task :setup => :environment do | |
4 | + setup | |
5 | + end | |
6 | + | |
7 | + def setup | |
8 | + warn_user_is_not_gitlab | |
9 | + | |
10 | + puts "This will create the necessary database tables and seed the database." | |
11 | + puts "You will lose any previous data stored in the database." | |
12 | + ask_to_continue | |
13 | + puts "" | |
14 | + | |
15 | + Rake::Task["db:setup"].invoke | |
16 | + Rake::Task["db:seed_fu"].invoke | |
17 | + Rake::Task["gitlab:enable_automerge"].invoke | |
18 | + rescue Gitlab::TaskAbortedByUserError | |
19 | + puts "Quitting...".red | |
20 | + exit 1 | |
9 | 21 | end |
10 | 22 | end | ... | ... |
lib/tasks/gitlab/task_helpers.rake
1 | +module Gitlab | |
2 | + class TaskAbortedByUserError < StandardError; end | |
3 | +end | |
4 | + | |
1 | 5 | namespace :gitlab do |
2 | 6 | |
7 | + # Ask if the user wants to continue | |
8 | + # | |
9 | + # Returns "yes" the user chose to continue | |
10 | + # Raises Gitlab::TaskAbortedByUserError if the user chose *not* to continue | |
11 | + def ask_to_continue | |
12 | + answer = prompt("Do you want to continue (yes/no)? ".blue, %w{yes no}) | |
13 | + raise Gitlab::TaskAbortedByUserError unless answer == "yes" | |
14 | + end | |
15 | + | |
3 | 16 | # Check which OS is running |
4 | 17 | # |
5 | 18 | # It will primarily use lsb_relase to determine the OS. |
... | ... | @@ -22,6 +35,20 @@ namespace :gitlab do |
22 | 35 | os_name.try(:squish!) |
23 | 36 | end |
24 | 37 | |
38 | + # Prompt the user to input something | |
39 | + # | |
40 | + # message - the message to display before input | |
41 | + # choices - array of strings of acceptible answers or nil for any answer | |
42 | + # | |
43 | + # Returns the user's answer | |
44 | + def prompt(message, choices = nil) | |
45 | + begin | |
46 | + print(message) | |
47 | + answer = STDIN.gets.chomp | |
48 | + end while choices.present? && !choices.include?(answer) | |
49 | + answer | |
50 | + end | |
51 | + | |
25 | 52 | # Runs the given command and matches the output agains the given pattern |
26 | 53 | # |
27 | 54 | # Returns nil if nothing matched | ... | ... |