Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
6e54f823
Commit
6e54f823
authored
Jan 15, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
84769a03
267ce96e
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
44 additions
and
10 deletions
+44
-10
changelogs/unreleased/api-wiki-dot-slug.yml
changelogs/unreleased/api-wiki-dot-slug.yml
+5
-0
changelogs/unreleased/sh-fix-backfill-project-repo-migration.yml
...ogs/unreleased/sh-fix-backfill-project-repo-migration.yml
+5
-0
lib/api/wikis.rb
lib/api/wikis.rb
+4
-2
lib/gitlab/background_migration/backfill_project_repositories.rb
...lab/background_migration/backfill_project_repositories.rb
+12
-2
spec/factories/wiki_pages.rb
spec/factories/wiki_pages.rb
+1
-1
spec/lib/gitlab/background_migration/backfill_project_repositories_spec.rb
...ackground_migration/backfill_project_repositories_spec.rb
+13
-3
spec/requests/api/wikis_spec.rb
spec/requests/api/wikis_spec.rb
+1
-1
spec/support/shared_examples/lib/gitlab/background_migration/backfill_project_repositories_examples.rb
...round_migration/backfill_project_repositories_examples.rb
+3
-1
No files found.
changelogs/unreleased/api-wiki-dot-slug.yml
0 → 100644
View file @
6e54f823
---
title
:
'
API:
Support
dots
in
wiki
slugs'
merge_request
:
24383
author
:
Robert Schilling
type
:
fixed
changelogs/unreleased/sh-fix-backfill-project-repo-migration.yml
0 → 100644
View file @
6e54f823
---
title
:
Fix duplicate project disk path in BackfillLegacyProjectRepositories
merge_request
:
24213
author
:
type
:
changed
lib/api/wikis.rb
View file @
6e54f823
...
@@ -22,7 +22,9 @@ module API
...
@@ -22,7 +22,9 @@ module API
end
end
end
end
resource
:projects
,
requirements:
API
::
NAMESPACE_OR_PROJECT_REQUIREMENTS
do
WIKI_ENDPOINT_REQUIREMENTS
=
API
::
NAMESPACE_OR_PROJECT_REQUIREMENTS
.
merge
(
slug:
API
::
NO_SLASH_URL_PART_REGEX
)
resource
:projects
,
requirements:
WIKI_ENDPOINT_REQUIREMENTS
do
desc
'Get a list of wiki pages'
do
desc
'Get a list of wiki pages'
do
success
Entities
::
WikiPageBasic
success
Entities
::
WikiPageBasic
end
end
...
@@ -103,7 +105,7 @@ module API
...
@@ -103,7 +105,7 @@ module API
requires
:file
,
type:
::
API
::
Validations
::
Types
::
SafeFile
,
desc:
'The attachment file to be uploaded'
requires
:file
,
type:
::
API
::
Validations
::
Types
::
SafeFile
,
desc:
'The attachment file to be uploaded'
optional
:branch
,
type:
String
,
desc:
'The name of the branch'
optional
:branch
,
type:
String
,
desc:
'The name of the branch'
end
end
post
":id/wikis/attachments"
,
requirements:
API
::
NAMESPACE_OR_PROJECT_REQUIREMENTS
do
post
":id/wikis/attachments"
do
authorize!
:create_wiki
,
user_project
authorize!
:create_wiki
,
user_project
result
=
::
Wikis
::
CreateAttachmentService
.
new
(
user_project
,
result
=
::
Wikis
::
CreateAttachmentService
.
new
(
user_project
,
...
...
lib/gitlab/background_migration/backfill_project_repositories.rb
View file @
6e54f823
...
@@ -83,7 +83,7 @@ module Gitlab
...
@@ -83,7 +83,7 @@ module Gitlab
extend
ActiveSupport
::
Concern
extend
ActiveSupport
::
Concern
def
full_path
def
full_path
@full_path
||=
build_full_path
route
&
.
path
||
build_full_path
end
end
def
build_full_path
def
build_full_path
...
@@ -99,7 +99,12 @@ module Gitlab
...
@@ -99,7 +99,12 @@ module Gitlab
end
end
end
end
# Namespace model.
# Route model
class
Route
<
ActiveRecord
::
Base
belongs_to
:source
,
inverse_of: :route
,
polymorphic:
true
end
# Namespace model
class
Namespace
<
ActiveRecord
::
Base
class
Namespace
<
ActiveRecord
::
Base
self
.
table_name
=
'namespaces'
self
.
table_name
=
'namespaces'
self
.
inheritance_column
=
nil
self
.
inheritance_column
=
nil
...
@@ -108,6 +113,8 @@ module Gitlab
...
@@ -108,6 +113,8 @@ module Gitlab
belongs_to
:parent
,
class_name:
'Namespace'
,
inverse_of:
'namespaces'
belongs_to
:parent
,
class_name:
'Namespace'
,
inverse_of:
'namespaces'
has_one
:route
,
->
{
where
(
source_type:
'Namespace'
)
},
inverse_of: :source
,
foreign_key: :source_id
has_many
:projects
,
inverse_of: :parent
has_many
:projects
,
inverse_of: :parent
has_many
:namespaces
,
inverse_of: :parent
has_many
:namespaces
,
inverse_of: :parent
end
end
...
@@ -134,6 +141,7 @@ module Gitlab
...
@@ -134,6 +141,7 @@ module Gitlab
belongs_to
:parent
,
class_name:
'Namespace'
,
foreign_key: :namespace_id
,
inverse_of:
'projects'
belongs_to
:parent
,
class_name:
'Namespace'
,
foreign_key: :namespace_id
,
inverse_of:
'projects'
has_one
:route
,
->
{
where
(
source_type:
'Project'
)
},
inverse_of: :source
,
foreign_key: :source_id
has_one
:project_repository
,
inverse_of: :project
has_one
:project_repository
,
inverse_of: :project
delegate
:disk_path
,
to: :storage
delegate
:disk_path
,
to: :storage
...
@@ -194,6 +202,8 @@ module Gitlab
...
@@ -194,6 +202,8 @@ module Gitlab
def
project_repositories
(
start_id
,
stop_id
)
def
project_repositories
(
start_id
,
stop_id
)
projects
projects
.
without_project_repository
.
without_project_repository
.
includes
(
:route
,
parent:
[
:route
]).
references
(
:routes
)
.
includes
(
:parent
).
references
(
:namespaces
)
.
where
(
id:
start_id
..
stop_id
)
.
where
(
id:
start_id
..
stop_id
)
.
map
{
|
project
|
build_attributes_for_project
(
project
)
}
.
map
{
|
project
|
build_attributes_for_project
(
project
)
}
.
compact
.
compact
...
...
spec/factories/wiki_pages.rb
View file @
6e54f823
...
@@ -5,7 +5,7 @@ FactoryBot.define do
...
@@ -5,7 +5,7 @@ FactoryBot.define do
transient
do
transient
do
attrs
do
attrs
do
{
{
title:
'Title'
,
title:
'Title
.with.dot
'
,
content:
'Content for wiki page'
,
content:
'Content for wiki page'
,
format:
'markdown'
format:
'markdown'
}
}
...
...
spec/lib/gitlab/background_migration/backfill_project_repositories_spec.rb
View file @
6e54f823
...
@@ -34,6 +34,7 @@ describe Gitlab::BackgroundMigration::BackfillProjectRepositories do
...
@@ -34,6 +34,7 @@ describe Gitlab::BackgroundMigration::BackfillProjectRepositories do
let!
(
:project_hashed_storage_2
)
{
create
(
:project
,
name:
'bar'
,
path:
'bar'
,
namespace:
group
,
storage_version:
2
)
}
let!
(
:project_hashed_storage_2
)
{
create
(
:project
,
name:
'bar'
,
path:
'bar'
,
namespace:
group
,
storage_version:
2
)
}
let!
(
:project_legacy_storage_3
)
{
create
(
:project
,
name:
'baz'
,
path:
'baz'
,
namespace:
group
,
storage_version:
0
)
}
let!
(
:project_legacy_storage_3
)
{
create
(
:project
,
name:
'baz'
,
path:
'baz'
,
namespace:
group
,
storage_version:
0
)
}
let!
(
:project_legacy_storage_4
)
{
create
(
:project
,
name:
'zoo'
,
path:
'zoo'
,
namespace:
group
,
storage_version:
nil
)
}
let!
(
:project_legacy_storage_4
)
{
create
(
:project
,
name:
'zoo'
,
path:
'zoo'
,
namespace:
group
,
storage_version:
nil
)
}
let!
(
:project_legacy_storage_5
)
{
create
(
:project
,
name:
'test'
,
path:
'test'
,
namespace:
group
,
storage_version:
nil
)
}
describe
'.on_hashed_storage'
do
describe
'.on_hashed_storage'
do
it
'finds projects with repository on hashed storage'
do
it
'finds projects with repository on hashed storage'
do
...
@@ -47,7 +48,7 @@ describe Gitlab::BackgroundMigration::BackfillProjectRepositories do
...
@@ -47,7 +48,7 @@ describe Gitlab::BackgroundMigration::BackfillProjectRepositories do
it
'finds projects with repository on legacy storage'
do
it
'finds projects with repository on legacy storage'
do
projects
=
described_class
.
on_legacy_storage
.
pluck
(
:id
)
projects
=
described_class
.
on_legacy_storage
.
pluck
(
:id
)
expect
(
projects
).
to
match_array
([
project_legacy_storage_3
.
id
,
project_legacy_storage_4
.
id
])
expect
(
projects
).
to
match_array
([
project_legacy_storage_3
.
id
,
project_legacy_storage_4
.
id
,
project_legacy_storage_5
.
id
])
end
end
end
end
...
@@ -58,7 +59,7 @@ describe Gitlab::BackgroundMigration::BackfillProjectRepositories do
...
@@ -58,7 +59,7 @@ describe Gitlab::BackgroundMigration::BackfillProjectRepositories do
projects
=
described_class
.
without_project_repository
.
pluck
(
:id
)
projects
=
described_class
.
without_project_repository
.
pluck
(
:id
)
expect
(
projects
).
to
contain_exactly
(
project_hashed_storage_2
.
id
,
project_legacy_storage_4
.
id
)
expect
(
projects
).
to
contain_exactly
(
project_hashed_storage_2
.
id
,
project_legacy_storage_4
.
id
,
project_legacy_storage_5
.
id
)
end
end
end
end
...
@@ -78,14 +79,23 @@ describe Gitlab::BackgroundMigration::BackfillProjectRepositories do
...
@@ -78,14 +79,23 @@ describe Gitlab::BackgroundMigration::BackfillProjectRepositories do
expect
(
project
.
disk_path
).
to
eq
(
project_legacy_storage_3
.
disk_path
)
expect
(
project
.
disk_path
).
to
eq
(
project_legacy_storage_3
.
disk_path
)
end
end
it
'returns the correct disk_path using the route entry'
do
project_legacy_storage_5
.
route
.
update
(
path:
'zoo/new-test'
)
project
=
described_class
.
find
(
project_legacy_storage_5
.
id
)
expect
(
project
.
disk_path
).
to
eq
(
'zoo/new-test'
)
end
it
'raises OrphanedNamespaceError when any parent namespace does not exist'
do
it
'raises OrphanedNamespaceError when any parent namespace does not exist'
do
subgroup
=
create
(
:group
,
parent:
group
)
subgroup
=
create
(
:group
,
parent:
group
)
project_orphaned_namespace
=
create
(
:project
,
name:
'baz'
,
path:
'baz'
,
namespace:
subgroup
,
storage_version:
nil
)
project_orphaned_namespace
=
create
(
:project
,
name:
'baz'
,
path:
'baz'
,
namespace:
subgroup
,
storage_version:
nil
)
subgroup
.
update_column
(
:parent_id
,
Namespace
.
maximum
(
:id
).
succ
)
subgroup
.
update_column
(
:parent_id
,
Namespace
.
maximum
(
:id
).
succ
)
project
=
described_class
.
find
(
project_orphaned_namespace
.
id
)
project
=
described_class
.
find
(
project_orphaned_namespace
.
id
)
project
.
route
.
destroy
subgroup
.
route
.
destroy
expect
{
project
.
disk_path
}
expect
{
project
.
reload
.
disk_path
}
.
to
raise_error
(
Gitlab
::
BackgroundMigration
::
BackfillProjectRepositories
::
OrphanedNamespaceError
)
.
to
raise_error
(
Gitlab
::
BackgroundMigration
::
BackfillProjectRepositories
::
OrphanedNamespaceError
)
end
end
end
end
...
...
spec/requests/api/wikis_spec.rb
View file @
6e54f823
...
@@ -22,7 +22,7 @@ describe API::Wikis do
...
@@ -22,7 +22,7 @@ describe API::Wikis do
context
'when wiki has pages'
do
context
'when wiki has pages'
do
let!
(
:pages
)
do
let!
(
:pages
)
do
[
create
(
:wiki_page
,
wiki:
project_wiki
,
attrs:
{
title:
'page1'
,
content:
'content of page1'
}),
[
create
(
:wiki_page
,
wiki:
project_wiki
,
attrs:
{
title:
'page1'
,
content:
'content of page1'
}),
create
(
:wiki_page
,
wiki:
project_wiki
,
attrs:
{
title:
'page2'
,
content:
'content of page2'
})]
create
(
:wiki_page
,
wiki:
project_wiki
,
attrs:
{
title:
'page2
.with.dot
'
,
content:
'content of page2'
})]
end
end
it
'returns the list of wiki pages without content'
do
it
'returns the list of wiki pages without content'
do
...
...
spec/support/shared_examples/lib/gitlab/background_migration/backfill_project_repositories_examples.rb
View file @
6e54f823
...
@@ -32,11 +32,13 @@ shared_examples 'backfill migration for project repositories' do |storage|
...
@@ -32,11 +32,13 @@ shared_examples 'backfill migration for project repositories' do |storage|
it
'inserts rows in a single query'
do
it
'inserts rows in a single query'
do
projects
.
create!
(
name:
'foo'
,
path:
'foo'
,
namespace_id:
group
.
id
,
storage_version:
storage_version
,
repository_storage:
shard
.
name
)
projects
.
create!
(
name:
'foo'
,
path:
'foo'
,
namespace_id:
group
.
id
,
storage_version:
storage_version
,
repository_storage:
shard
.
name
)
group2
=
namespaces
.
create!
(
name:
'gro'
,
path:
'gro'
)
control_count
=
ActiveRecord
::
QueryRecorder
.
new
{
described_class
.
new
.
perform
(
1
,
projects
.
last
.
id
)
}
control_count
=
ActiveRecord
::
QueryRecorder
.
new
{
described_class
.
new
.
perform
(
1
,
projects
.
last
.
id
)
}
projects
.
create!
(
name:
'bar'
,
path:
'bar'
,
namespace_id:
group
.
id
,
storage_version:
storage_version
,
repository_storage:
shard
.
name
)
projects
.
create!
(
name:
'bar'
,
path:
'bar'
,
namespace_id:
group
.
id
,
storage_version:
storage_version
,
repository_storage:
shard
.
name
)
projects
.
create!
(
name:
'zoo'
,
path:
'zoo'
,
namespace_id:
group
.
id
,
storage_version:
storage_version
,
repository_storage:
shard
.
name
)
projects
.
create!
(
name:
'top'
,
path:
'top'
,
namespace_id:
group
.
id
,
storage_version:
storage_version
,
repository_storage:
shard
.
name
)
projects
.
create!
(
name:
'zoo'
,
path:
'zoo'
,
namespace_id:
group2
.
id
,
storage_version:
storage_version
,
repository_storage:
shard
.
name
)
expect
{
described_class
.
new
.
perform
(
1
,
projects
.
last
.
id
)
}.
not_to
exceed_query_limit
(
control_count
)
expect
{
described_class
.
new
.
perform
(
1
,
projects
.
last
.
id
)
}.
not_to
exceed_query_limit
(
control_count
)
end
end
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment