define TestEnv and keep all global stubs in one place
This commit is contained in:
parent
7bb71bb088
commit
22817398e6
5 changed files with 72 additions and 87 deletions
|
@ -25,7 +25,7 @@ FactoryGirl.define do
|
|||
|
||||
factory :project do
|
||||
sequence(:name) { |n| "project#{n}" }
|
||||
path { name.downcase.gsub(/\s/, '_') }
|
||||
path { 'gitlabhq' }
|
||||
creator
|
||||
end
|
||||
|
||||
|
|
|
@ -1,71 +0,0 @@
|
|||
require "gitlab/git/repository"
|
||||
require "project"
|
||||
require "merge_request"
|
||||
require "shell"
|
||||
|
||||
# Stubs out all Git repository access done by models so that specs can run
|
||||
# against fake repositories without Grit complaining that they don't exist.
|
||||
class Project
|
||||
def repository
|
||||
if path == "empty" || !path
|
||||
nil
|
||||
else
|
||||
GitLabTestRepo.new(Rails.root.join('tmp', 'repositories', 'gitlabhq'), 'master')
|
||||
end
|
||||
end
|
||||
|
||||
def satellite
|
||||
FakeSatellite.new
|
||||
end
|
||||
|
||||
class FakeSatellite
|
||||
def exists?
|
||||
true
|
||||
end
|
||||
|
||||
def destroy
|
||||
true
|
||||
end
|
||||
|
||||
def create
|
||||
true
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
class MergeRequest
|
||||
def check_if_can_be_merged
|
||||
true
|
||||
end
|
||||
end
|
||||
|
||||
class GitLabTestRepo < Repository
|
||||
# patch repo size (in mb)
|
||||
def size
|
||||
12.45
|
||||
end
|
||||
end
|
||||
|
||||
module Gitlab
|
||||
class Shell
|
||||
def add_repository name
|
||||
true
|
||||
end
|
||||
|
||||
def mv_repository name, new_name
|
||||
true
|
||||
end
|
||||
|
||||
def remove_repository name
|
||||
true
|
||||
end
|
||||
|
||||
def add_key id, key
|
||||
true
|
||||
end
|
||||
|
||||
def remove_key id, key
|
||||
true
|
||||
end
|
||||
end
|
||||
end
|
63
spec/support/test_env.rb
Normal file
63
spec/support/test_env.rb
Normal file
|
@ -0,0 +1,63 @@
|
|||
module TestEnv
|
||||
extend self
|
||||
|
||||
# Test environment
|
||||
#
|
||||
# all repositories and namespaces stored at
|
||||
# RAILS_APP/tmp/test-git-base-path
|
||||
#
|
||||
# Next shell methods are stubbed and return true
|
||||
# - mv_repository
|
||||
# - remove_repository
|
||||
# - add_key
|
||||
# - remove_key
|
||||
#
|
||||
def init
|
||||
# Use tmp dir for FS manipulations
|
||||
repos_path = Rails.root.join('tmp', 'test-git-base-path')
|
||||
Gitlab.config.gitlab_shell.stub(repos_path: repos_path)
|
||||
|
||||
Gitlab::Shell.any_instance.stub(
|
||||
add_repository: ->(path) { create_temp_repo(File.join(repos_path, "#{path}.git")) },
|
||||
mv_repository: true,
|
||||
remove_repository: true,
|
||||
add_key: true,
|
||||
remove_key: true
|
||||
)
|
||||
|
||||
fake_satellite = double(
|
||||
exists?: true,
|
||||
destroy: true,
|
||||
create: true
|
||||
)
|
||||
|
||||
Project.any_instance.stub(
|
||||
satellite: fake_satellite
|
||||
)
|
||||
|
||||
MergeRequest.any_instance.stub(
|
||||
check_if_can_be_merged: true
|
||||
)
|
||||
|
||||
Repository.any_instance.stub(
|
||||
size: 12.45
|
||||
)
|
||||
|
||||
# Remove tmp/test-git-base-path
|
||||
FileUtils.rm_rf Gitlab.config.gitlab_shell.repos_path
|
||||
|
||||
# Recreate tmp/test-git-base-path
|
||||
FileUtils.mkdir_p Gitlab.config.gitlab_shell.repos_path
|
||||
|
||||
# Symlink tmp/repositories/gitlabhq to tmp/test-git-base-path/gitlabhq
|
||||
seed_repo = Rails.root.join('tmp', 'repositories', 'gitlabhq')
|
||||
target_repo = File.join(repos_path, 'gitlabhq.git')
|
||||
system("ln -s #{seed_repo} #{target_repo}")
|
||||
end
|
||||
|
||||
def create_temp_repo(path)
|
||||
FileUtils.mkdir_p path
|
||||
command = "git init --quiet --bare #{path};"
|
||||
system(command)
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue