BigW Consortium Gitlab

Commit 1d337def by Marin Jankovski

Merge pull request #8168 from cirosantilli/dev-fixtures-visibility

Create dev fixture projects with fixed visibility
parents 2bb8e93d a9fadce3
require 'sidekiq/testing' Gitlab::Seeder.quiet do
project_urls = [
Sidekiq::Testing.inline! do 'https://github.com/documentcloud/underscore.git',
Gitlab::Seeder.quiet do 'https://gitlab.com/gitlab-org/gitlab-ce.git',
project_urls = [ 'https://gitlab.com/gitlab-org/gitlab-ci.git',
'https://github.com/documentcloud/underscore.git', 'https://gitlab.com/gitlab-org/gitlab-shell.git',
'https://gitlab.com/gitlab-org/gitlab-ce.git', 'https://gitlab.com/gitlab-org/gitlab-test.git',
'https://gitlab.com/gitlab-org/gitlab-ci.git', 'https://github.com/twitter/flight.git',
'https://gitlab.com/gitlab-org/gitlab-shell.git', 'https://github.com/twitter/typeahead.js.git',
'https://gitlab.com/gitlab-org/gitlab-test.git', 'https://github.com/h5bp/html5-boilerplate.git',
'https://github.com/twitter/flight.git', ]
'https://github.com/twitter/typeahead.js.git',
'https://github.com/h5bp/html5-boilerplate.git', project_urls.each do |url|
] group_path, project_path = url.split('/')[-2..-1]
project_urls.each_with_index do |url, i| group = Group.find_by(path: group_path)
group_path, project_path = url.split('/')[-2..-1]
unless group
group = Group.find_by(path: group_path) group = Group.new(
name: group_path.titleize,
unless group path: group_path
group = Group.new( )
name: group_path.titleize, group.description = Faker::Lorem.sentence
path: group_path group.save
)
group.description = Faker::Lorem.sentence group.add_owner(User.first)
group.save end
group.add_owner(User.first) project_path.gsub!('.git', '')
end
params = {
project_path.gsub!(".git", "") import_url: url,
namespace_id: group.id,
params = { name: project_path.titleize,
import_url: url, description: Faker::Lorem.sentence,
namespace_id: group.id, visibility_level: Gitlab::VisibilityLevel.values.sample
name: project_path.titleize, }
description: Faker::Lorem.sentence,
visibility_level: Gitlab::VisibilityLevel.values.sample project = Projects::CreateService.new(User.first, params).execute
}
if project.valid?
project = Projects::CreateService.new(User.first, params).execute print '.'
else
if project.valid? puts project.errors.full_messages
print '.' print 'F'
else
puts project.errors.full_messages
print 'F'
end
end end
end end
end end
require Rails.root.join('db', 'fixtures', Rails.env, 'fixtures_development_helper')
Gitlab::Seeder.quiet do
Gitlab::VisibilityLevel.options.each do |visibility_label, visibility_value|
visibility_label_downcase = visibility_label.downcase
begin
user = User.seed(:username) do |s|
username = "#{visibility_label_downcase}-owner"
s.username = username
s.name = "#{visibility_label} Owner"
s.email = "#{username}@example.com"
s.password = '12345678'
s.confirmed_at = DateTime.now
end[0]
# import_url does not work for local paths,
# so we just copy the template repository in.
unless Project.find_with_namespace("#{user.namespace.id}/"\
"#{visibility_label_downcase}")
params = {
name: "#{visibility_label} Project",
description: "#{visibility_label} Project description",
namespace_id: user.namespace.id,
visibility_level: visibility_value,
}
project = Projects::CreateService.new(user, params).execute
new_path = project.repository.path
FileUtils.rm_rf(new_path)
FileUtils.cp_r(FixturesDevelopmentHelper.template_project.repository.path,
new_path)
end
print '.'
rescue ActiveRecord::RecordNotSaved
print 'F'
end
end
end
module FixturesDevelopmentHelper
class << self
def template_project
@template_project ||= Project.
find_with_namespace('gitlab-org/gitlab-test')
end
end
end
require 'sidekiq/testing'
module Gitlab module Gitlab
class Seeder class Seeder
def self.quiet def self.quiet
mute_mailer mute_mailer
SeedFu.quiet = true SeedFu.quiet = true
yield Sidekiq::Testing.inline! do
yield
end
SeedFu.quiet = false SeedFu.quiet = false
puts "\nOK".green puts "\nOK".green
end end
......
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