Merge branch '4826-geo-wikisyncservice-attempts-to-sync-projects' into 'master'
Create an empty wiki when there is no wiki in the gitlab export bundle See merge request gitlab-org/gitlab-ce!17010
This commit is contained in:
commit
0a22ff267b
4 changed files with 76 additions and 2 deletions
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
title: Create empty wiki when import from GitLab and wiki is not there
|
||||||
|
merge_request:
|
||||||
|
author:
|
||||||
|
type: fixed
|
|
@ -50,9 +50,10 @@ module Gitlab
|
||||||
end
|
end
|
||||||
|
|
||||||
def wiki_restorer
|
def wiki_restorer
|
||||||
Gitlab::ImportExport::RepoRestorer.new(path_to_bundle: wiki_repo_path,
|
Gitlab::ImportExport::WikiRestorer.new(path_to_bundle: wiki_repo_path,
|
||||||
shared: @shared,
|
shared: @shared,
|
||||||
project: ProjectWiki.new(project_tree.restored_project))
|
project: ProjectWiki.new(project_tree.restored_project),
|
||||||
|
wiki_enabled: @project.wiki_enabled?)
|
||||||
end
|
end
|
||||||
|
|
||||||
def uploads_restorer
|
def uploads_restorer
|
||||||
|
|
23
lib/gitlab/import_export/wiki_restorer.rb
Normal file
23
lib/gitlab/import_export/wiki_restorer.rb
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
module Gitlab
|
||||||
|
module ImportExport
|
||||||
|
class WikiRestorer < RepoRestorer
|
||||||
|
def initialize(project:, shared:, path_to_bundle:, wiki_enabled:)
|
||||||
|
super(project: project, shared: shared, path_to_bundle: path_to_bundle)
|
||||||
|
|
||||||
|
@wiki_enabled = wiki_enabled
|
||||||
|
end
|
||||||
|
|
||||||
|
def restore
|
||||||
|
@project.wiki if create_empty_wiki?
|
||||||
|
|
||||||
|
super
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def create_empty_wiki?
|
||||||
|
!File.exist?(@path_to_bundle) && @wiki_enabled
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
45
spec/lib/gitlab/import_export/wiki_restorer_spec.rb
Normal file
45
spec/lib/gitlab/import_export/wiki_restorer_spec.rb
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
require 'spec_helper'
|
||||||
|
|
||||||
|
describe Gitlab::ImportExport::WikiRestorer do
|
||||||
|
describe 'restore a wiki Git repo' do
|
||||||
|
let!(:project_with_wiki) { create(:project, :wiki_repo) }
|
||||||
|
let!(:project_without_wiki) { create(:project) }
|
||||||
|
let!(:project) { create(:project) }
|
||||||
|
let(:export_path) { "#{Dir.tmpdir}/project_tree_saver_spec" }
|
||||||
|
let(:shared) { Gitlab::ImportExport::Shared.new(relative_path: project.full_path) }
|
||||||
|
let(:bundler) { Gitlab::ImportExport::WikiRepoSaver.new(project: project_with_wiki, shared: shared) }
|
||||||
|
let(:bundle_path) { File.join(shared.export_path, Gitlab::ImportExport.project_bundle_filename) }
|
||||||
|
let(:restorer) do
|
||||||
|
described_class.new(path_to_bundle: bundle_path,
|
||||||
|
shared: shared,
|
||||||
|
project: project.wiki,
|
||||||
|
wiki_enabled: true)
|
||||||
|
end
|
||||||
|
|
||||||
|
before do
|
||||||
|
allow(Gitlab::ImportExport).to receive(:storage_path).and_return(export_path)
|
||||||
|
|
||||||
|
bundler.save
|
||||||
|
end
|
||||||
|
|
||||||
|
after do
|
||||||
|
FileUtils.rm_rf(export_path)
|
||||||
|
Gitlab::Shell.new.remove_repository(project_with_wiki.wiki.repository_storage_path, project_with_wiki.wiki.disk_path)
|
||||||
|
Gitlab::Shell.new.remove_repository(project.wiki.repository_storage_path, project.wiki.disk_path)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'restores the wiki repo successfully' do
|
||||||
|
expect(restorer.restore).to be true
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "no wiki in the bundle" do
|
||||||
|
let(:bundler) { Gitlab::ImportExport::WikiRepoSaver.new(project: project_without_wiki, shared: shared) }
|
||||||
|
|
||||||
|
it 'creates an empty wiki' do
|
||||||
|
expect(restorer.restore).to be true
|
||||||
|
|
||||||
|
expect(project.wiki_repository_exists?).to be true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue