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 | ... | ... |