Commit 10ec9b2293646f88a1edeea472de82bda340d9c6
Exists in
master
and in
4 other branches
Merge pull request #2017 from duksis/backup_restore
bugfix: backup data retrieved with the same type keys as saved
Showing
2 changed files
with
47 additions
and
1 deletions
Show diff stats
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/,"") | ... | ... |
... | ... | @@ -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 | ... | ... |