Commit 10ec9b2293646f88a1edeea472de82bda340d9c6

Authored by Dmitriy Zaporozhets
2 parents c19e766f a9c2500a

Merge pull request #2017 from duksis/backup_restore

bugfix: backup data retrieved with the same type keys as saved
lib/tasks/gitlab/backup.rake
... ... @@ -82,7 +82,7 @@ namespace :gitlab do
82 82 end
83 83  
84 84 settings = YAML.load_file("backup_information.yml")
85   - ENV["VERSION"] = "#{settings["db_version"]}" if settings["db_version"].to_i > 0
  85 + ENV["VERSION"] = "#{settings[:db_version]}" if settings[:db_version].to_i > 0
86 86  
87 87 # restoring mismatching backups can lead to unexpected problems
88 88 if settings[:gitlab_version] != %x{git rev-parse HEAD}.gsub(/\n/,"")
... ...
spec/tasks/gitlab/backup_rake_spec.rb 0 → 100644
... ... @@ -0,0 +1,46 @@
  1 +require 'spec_helper'
  2 +require 'rake'
  3 +
  4 +describe 'gitlab:app namespace rake task' do
  5 + before :all do
  6 + Rake.application.rake_require "tasks/gitlab/backup"
  7 + # empty task as env is already loaded
  8 + Rake::Task.define_task :environment
  9 + end
  10 +
  11 + describe 'backup_restore' do
  12 + before do
  13 + # avoid writing task output to spec progress
  14 + $stdout.stub :write
  15 + end
  16 +
  17 + let :run_rake_task do
  18 + Rake::Task["gitlab:app:backup_restore"].reenable
  19 + Rake.application.invoke_task "gitlab:app:backup_restore"
  20 + end
  21 +
  22 + context 'gitlab version' do
  23 + before do
  24 + Dir.stub :glob => []
  25 + Dir.stub :chdir
  26 + File.stub :exists? => true
  27 + Kernel.stub :system => true
  28 + end
  29 +
  30 + let(:gitlab_version) { %x{git rev-parse HEAD}.gsub(/\n/,"") }
  31 +
  32 + it 'should fail on mismach' do
  33 + YAML.stub :load_file => {:gitlab_version => gitlab_version.reverse}
  34 + expect { run_rake_task }.to raise_error SystemExit
  35 + end
  36 +
  37 + it 'should invoke restoration on mach' do
  38 + YAML.stub :load_file => {:gitlab_version => gitlab_version}
  39 + Rake::Task["gitlab:app:db_restore"].should_receive :invoke
  40 + Rake::Task["gitlab:app:repo_restore"].should_receive :invoke
  41 + expect { run_rake_task }.to_not raise_error SystemExit
  42 + end
  43 + end
  44 +
  45 + end # backup_restore task
  46 +end # gitlab:app namespace
... ...