Commit 037a62f3 authored by Robert Speicher's avatar Robert Speicher

Remove `:empty_project` factory, implement `:repository` trait

parent 89c73add
...@@ -5,7 +5,7 @@ FactoryGirl.define do ...@@ -5,7 +5,7 @@ FactoryGirl.define do
# #
# Project does not have bare repository. # Project does not have bare repository.
# Use this factory if you don't need repository in tests # Use this factory if you don't need repository in tests
factory :empty_project, class: 'Project' do factory :project, class: 'Project' do
sequence(:name) { |n| "project#{n}" } sequence(:name) { |n| "project#{n}" }
path { name.downcase.gsub(/\s/, '_') } path { name.downcase.gsub(/\s/, '_') }
namespace namespace
...@@ -68,8 +68,44 @@ FactoryGirl.define do ...@@ -68,8 +68,44 @@ FactoryGirl.define do
avatar { File.open(Rails.root.join('spec/fixtures/dk.png')) } avatar { File.open(Rails.root.join('spec/fixtures/dk.png')) }
end end
# Project with test repository
#
# Repository source is at https://gitlab.com/gitlab-org/gitlab-test
trait :repository do trait :repository do
# no-op... for now! path { 'gitlabhq' }
test_repo
transient do
create_template nil
end
after :create do |project, evaluator|
if evaluator.create_template
args = evaluator.create_template
project.add_user(args[:user], args[:access])
project.repository.create_file(
args[:user],
".gitlab/#{args[:path]}/bug.md",
'something valid',
message: 'test 3',
branch_name: 'master')
project.repository.create_file(
args[:user],
".gitlab/#{args[:path]}/template_test.md",
'template_test',
message: 'test 1',
branch_name: 'master')
project.repository.create_file(
args[:user],
".gitlab/#{args[:path]}/feature_proposal.md",
'feature_proposal',
message: 'test 2',
branch_name: 'master')
end
end
end end
trait :empty_repo do trait :empty_repo do
...@@ -175,63 +211,18 @@ FactoryGirl.define do ...@@ -175,63 +211,18 @@ FactoryGirl.define do
# #
# This is a case when you just created a project # This is a case when you just created a project
# but not pushed any code there yet # but not pushed any code there yet
factory :project_empty_repo, parent: :empty_project do factory :project_empty_repo, parent: :project do
empty_repo empty_repo
end end
# Project with broken repository # Project with broken repository
# #
# Project with an invalid repository state # Project with an invalid repository state
factory :project_broken_repo, parent: :empty_project do factory :project_broken_repo, parent: :project do
broken_repo broken_repo
end end
# Project with test repository factory :forked_project_with_submodules, parent: :project do
#
# Test repository source can be found at
# https://gitlab.com/gitlab-org/gitlab-test
factory :project, parent: :empty_project do
path { 'gitlabhq' }
test_repo
transient do
create_template nil
end
after :create do |project, evaluator|
TestEnv.copy_repo(project,
bare_repo: TestEnv.factory_repo_path_bare,
refs: TestEnv::BRANCH_SHA)
if evaluator.create_template
args = evaluator.create_template
project.add_user(args[:user], args[:access])
project.repository.create_file(
args[:user],
".gitlab/#{args[:path]}/bug.md",
'something valid',
message: 'test 3',
branch_name: 'master')
project.repository.create_file(
args[:user],
".gitlab/#{args[:path]}/template_test.md",
'template_test',
message: 'test 1',
branch_name: 'master')
project.repository.create_file(
args[:user],
".gitlab/#{args[:path]}/feature_proposal.md",
'feature_proposal',
message: 'test 2',
branch_name: 'master')
end
end
end
factory :forked_project_with_submodules, parent: :empty_project do
path { 'forked-gitlabhq' } path { 'forked-gitlabhq' }
after :create do |project| after :create do |project|
...@@ -261,11 +252,11 @@ FactoryGirl.define do ...@@ -261,11 +252,11 @@ FactoryGirl.define do
jira_service jira_service
end end
factory :kubernetes_project, parent: :empty_project do factory :kubernetes_project, parent: :project do
kubernetes_service kubernetes_service
end end
factory :prometheus_project, parent: :empty_project do factory :prometheus_project, parent: :project do
after :create do |project| after :create do |project|
project.create_prometheus_service( project.create_prometheus_service(
active: true, active: true,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment