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
e26e4c49
Commit
e26e4c49
authored
Jun 17, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
4686d99c
b37ca626
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
79 additions
and
1 deletion
+79
-1
app/models/project.rb
app/models/project.rb
+17
-1
changelogs/unreleased/sh-fix-issue-63158.yml
changelogs/unreleased/sh-fix-issue-63158.yml
+5
-0
lib/gitlab/visibility_level.rb
lib/gitlab/visibility_level.rb
+13
-0
spec/models/project_spec.rb
spec/models/project_spec.rb
+17
-0
spec/services/projects/create_service_spec.rb
spec/services/projects/create_service_spec.rb
+27
-0
No files found.
app/models/project.rb
View file @
e26e4c49
...
...
@@ -72,7 +72,6 @@ class Project < ApplicationRecord
delegate
:no_import?
,
to: :import_state
,
allow_nil:
true
default_value_for
:archived
,
false
default_value_for
(
:visibility_level
)
{
Gitlab
::
CurrentSettings
.
default_project_visibility
}
default_value_for
:resolve_outdated_diff_discussions
,
false
default_value_for
:container_registry_enabled
,
gitlab_config_features
.
container_registry
default_value_for
(
:repository_storage
)
{
Gitlab
::
CurrentSettings
.
pick_repository_storage
}
...
...
@@ -613,6 +612,23 @@ class Project < ApplicationRecord
end
end
def
initialize
(
attributes
=
{})
# We can't use default_value_for because the database has a default
# value of 0 for visibility_level. If someone attempts to create a
# private project, default_value_for will assume that the
# visibility_level hasn't changed and will use the application
# setting default, which could be internal or public. For projects
# inside a private group, those levels are invalid.
#
# To fix the problem, we assign the actual default in the application if
# no explicit visibility has been initialized.
unless
visibility_attribute_present?
(
attributes
)
attributes
[
:visibility_level
]
=
Gitlab
::
CurrentSettings
.
default_project_visibility
end
super
end
def
all_pipelines
if
builds_enabled?
super
...
...
changelogs/unreleased/sh-fix-issue-63158.yml
0 → 100644
View file @
e26e4c49
---
title
:
Fix inability to set visibility_level on project via API
merge_request
:
29578
author
:
type
:
fixed
lib/gitlab/visibility_level.rb
View file @
e26e4c49
...
...
@@ -138,5 +138,18 @@ module Gitlab
def
visibility
=
(
level
)
self
[
visibility_level_field
]
=
Gitlab
::
VisibilityLevel
.
level_value
(
level
)
end
def
visibility_attribute_present?
(
attributes
)
visibility_level_attributes
.
each
do
|
attr
|
return
true
if
attributes
[
attr
].
present?
end
false
end
def
visibility_level_attributes
[
visibility_level_field
,
visibility_level_field
.
to_s
,
:visibility
,
'visibility'
]
end
end
end
spec/models/project_spec.rb
View file @
e26e4c49
...
...
@@ -1479,11 +1479,28 @@ describe Project do
end
context
'when set to INTERNAL in application settings'
do
using
RSpec
::
Parameterized
::
TableSyntax
before
do
stub_application_setting
(
default_project_visibility:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
end
it
{
is_expected
.
to
eq
(
Gitlab
::
VisibilityLevel
::
INTERNAL
)
}
where
(
:attribute_name
,
:value
)
do
:visibility
|
'public'
:visibility_level
|
Gitlab
::
VisibilityLevel
::
PUBLIC
'visibility'
|
'public'
'visibility_level'
|
Gitlab
::
VisibilityLevel
::
PUBLIC
end
with_them
do
it
'sets the visibility level'
do
proj
=
described_class
.
new
(
attribute_name
=>
value
,
name:
'test'
,
path:
'test'
)
expect
(
proj
.
visibility_level
).
to
eq
(
Gitlab
::
VisibilityLevel
::
PUBLIC
)
end
end
end
end
...
...
spec/services/projects/create_service_spec.rb
View file @
e26e4c49
...
...
@@ -152,6 +152,33 @@ describe Projects::CreateService, '#execute' do
end
end
context
'default visibility level'
do
let
(
:group
)
{
create
(
:group
,
:private
)
}
before
do
stub_application_setting
(
default_project_visibility:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
group
.
add_developer
(
user
)
opts
.
merge!
(
visibility:
'private'
,
name:
'test'
,
namespace:
group
,
path:
'foo'
)
end
it
'creates a private project'
do
project
=
create_project
(
user
,
opts
)
expect
(
project
).
to
respond_to
(
:errors
)
expect
(
project
.
errors
.
any?
).
to
be
(
false
)
expect
(
project
.
visibility_level
).
to
eq
(
Gitlab
::
VisibilityLevel
::
PRIVATE
)
expect
(
project
.
saved?
).
to
be
(
true
)
expect
(
project
.
valid?
).
to
be
(
true
)
end
end
context
'restricted visibility level'
do
before
do
stub_application_setting
(
restricted_visibility_levels:
[
Gitlab
::
VisibilityLevel
::
PUBLIC
])
...
...
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