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
b9a3438b
Commit
b9a3438b
authored
May 17, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
5d24b055
74fa088b
Changes
12
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
69 additions
and
169 deletions
+69
-169
app/models/ci/build.rb
app/models/ci/build.rb
+0
-2
app/services/clusters/refresh_service.rb
app/services/clusters/refresh_service.rb
+1
-5
app/services/projects/create_service.rb
app/services/projects/create_service.rb
+0
-6
app/services/projects/transfer_service.rb
app/services/projects/transfer_service.rb
+0
-5
app/workers/cluster_configure_worker.rb
app/workers/cluster_configure_worker.rb
+1
-1
changelogs/unreleased/60379-remove-ci-preparing-state-feature-flag.yml
...released/60379-remove-ci-preparing-state-feature-flag.yml
+5
-0
lib/gitlab/ci/templates/dotNET-Core.yml
lib/gitlab/ci/templates/dotNET-Core.yml
+50
-41
spec/models/ci/build_spec.rb
spec/models/ci/build_spec.rb
+6
-14
spec/services/clusters/refresh_service_spec.rb
spec/services/clusters/refresh_service_spec.rb
+4
-22
spec/services/projects/create_service_spec.rb
spec/services/projects/create_service_spec.rb
+0
-27
spec/services/projects/transfer_service_spec.rb
spec/services/projects/transfer_service_spec.rb
+0
-27
spec/workers/cluster_configure_worker_spec.rb
spec/workers/cluster_configure_worker_spec.rb
+2
-19
No files found.
app/models/ci/build.rb
View file @
b9a3438b
...
...
@@ -378,8 +378,6 @@ module Ci
end
def
any_unmet_prerequisites?
return
false
unless
Feature
.
enabled?
(
:ci_preparing_state
,
default_enabled:
true
)
prerequisites
.
present?
end
...
...
app/services/clusters/refresh_service.rb
View file @
b9a3438b
...
...
@@ -21,11 +21,7 @@ module Clusters
private_class_method
:projects_with_missing_kubernetes_namespaces_for_cluster
def
self
.
clusters_with_missing_kubernetes_namespaces_for_project
(
project
)
if
Feature
.
enabled?
(
:ci_preparing_state
,
default_enabled:
true
)
project
.
clusters
.
managed
.
missing_kubernetes_namespace
(
project
.
kubernetes_namespaces
)
else
project
.
all_clusters
.
managed
.
missing_kubernetes_namespace
(
project
.
kubernetes_namespaces
)
end
end
private_class_method
:clusters_with_missing_kubernetes_namespaces_for_project
...
...
app/services/projects/create_service.rb
View file @
b9a3438b
...
...
@@ -100,8 +100,6 @@ module Projects
current_user
.
invalidate_personal_projects_count
create_readme
if
@initialize_with_readme
configure_group_clusters_for_project
end
# Refresh the current user's authorizations inline (so they can access the
...
...
@@ -127,10 +125,6 @@ module Projects
Files
::
CreateService
.
new
(
@project
,
current_user
,
commit_attrs
).
execute
end
def
configure_group_clusters_for_project
ClusterProjectConfigureWorker
.
perform_async
(
@project
.
id
)
end
def
skip_wiki?
!
@project
.
feature_available?
(
:wiki
,
current_user
)
||
@skip_wiki
end
...
...
app/services/projects/transfer_service.rb
View file @
b9a3438b
...
...
@@ -54,7 +54,6 @@ module Projects
end
attempt_transfer_transaction
configure_group_clusters_for_project
end
# rubocop: enable CodeReuse/ActiveRecord
...
...
@@ -164,10 +163,6 @@ module Projects
@new_namespace
.
full_path
)
end
def
configure_group_clusters_for_project
ClusterProjectConfigureWorker
.
perform_async
(
project
.
id
)
end
end
end
...
...
app/workers/cluster_configure_worker.rb
View file @
b9a3438b
...
...
@@ -6,7 +6,7 @@ class ClusterConfigureWorker
def
perform
(
cluster_id
)
Clusters
::
Cluster
.
managed
.
find_by_id
(
cluster_id
).
try
do
|
cluster
|
if
cluster
.
project_type?
||
Feature
.
disabled?
(
:ci_preparing_state
,
default_enabled:
true
)
if
cluster
.
project_type?
Clusters
::
RefreshService
.
create_or_update_namespaces_for_cluster
(
cluster
)
end
end
...
...
changelogs/unreleased/60379-remove-ci-preparing-state-feature-flag.yml
0 → 100644
View file @
b9a3438b
---
title
:
Remove ability for group clusters to be automatically configured on creation
merge_request
:
27245
author
:
type
:
removed
lib/gitlab/ci/templates/dotNET-Core.yml
View file @
b9a3438b
...
...
@@ -5,8 +5,9 @@
#
# Instead of installing .NET Core SDK manually, a docker image is used
# with already pre-installed .NET Core SDK.
#
# The 'latest' tag targets the latest available version of .NET Core SDK image.
# If preferred, you can explicitly specify version of .NET Core
e.g. using '2.2-sdk' tag
.
# If preferred, you can explicitly specify version of .NET Core
(e.g. using '2.2-sdk' tag)
.
#
# See other available tags for .NET Core: https://hub.docker.com/r/microsoft/dotnet
# Learn more about Docker tags: https://docs.docker.com/glossary/?term=tag
...
...
@@ -36,11 +37,14 @@ stages:
#
# Before building the project, all dependencies (e.g. third-party NuGet packages)
# must be restored. Jobs on GitLab.com's Shared Runners are executed on autoscaled machines.
# Each machine is used only once (for security reasons) and after that it is removed.
# What that means is that before every job a dependency restore must be performed
#
# Each machine is used only once (for security reasons) and after that is removed.
# This means that, before every job, a dependency restore must be performed
# because restored dependencies are removed along with machines. Fortunately,
# GitLab provides cache mechanism with the aim of keeping restored dependencies
# for other jobs. This example shows how to configure cache to pass over restored
# for other jobs.
#
# This example shows how to configure cache to pass over restored
# dependencies for re-use.
#
# With global cache rule, cached dependencies will be downloaded before every job
...
...
@@ -58,23 +62,28 @@ cache:
-
'
$SOURCE_CODE_PATH$OBJECTS_DIRECTORY/*.csproj.nuget.*'
# 3) Path to the directory where restored dependencies are kept.
-
'
$NUGET_PACKAGES_DIRECTORY'
# 'pull-push' policy means that latest cache will be downloaded (if exists)
#
# 'pull-push' policy means that latest cache will be downloaded (if it exists)
# before executing the job, and a newer version will be uploaded afterwards.
# Such setting saves time when there are no changes in referenced third-party
# packages. For example if you run a pipeline with changes in your code,
# Such a setting saves time when there are no changes in referenced third-party
# packages.
#
# For example, if you run a pipeline with changes in your code,
# but with no changes within third-party packages which your project is using,
# then project restore will happen in next to no time as all required dependencies
# will already be there — unzipped from cache. 'pull-push' policy is a default
# cache policy, you do not have to specify it explicitly.
# then project restore will happen quickly as all required dependencies
# will already be there — unzipped from cache.
# 'pull-push' policy is the default cache policy, you do not have to specify it explicitly.
policy
:
pull-push
# ### Restore project dependencies
#
# NuGet packages by default are restored to '.nuget/packages' directory
# in the user's home directory. That directory is out of scope of GitLab caching.
# To get around this a custom path can be specified using '--packages <PATH>' option
# for 'dotnet restore' command. In this example a temporary directory is created
# in the root of project repository, so it's content can be cached.
#
# To get around this, a custom path can be specified using the '--packages <PATH>' option
# for 'dotnet restore' command. In this example, a temporary directory is created
# in the root of project repository, so its content can be cached.
#
# Learn more about GitLab cache: https://docs.gitlab.com/ee/ci/caching/index.html
before_script
:
...
...
@@ -85,10 +94,10 @@ build:
# ### Build all projects discovered from solution file.
#
# Note: this will fail if you have any projects in your solution that are not
# .NET Core
based projects e.g. WCF service, which is based on .NET Framework,
# not .NET Core. In
such scenario you will need to build every .NET Core based
# .NET Core
-based projects (e.g. WCF service), which is based on .NET Framework,
# not .NET Core. In
this scenario, you will need to build every .NET Core-based
# project by explicitly specifying a relative path to the directory
# where it is located
e.g. 'dotnet build ./src/ConsoleApp'.
# where it is located
(e.g. 'dotnet build ./src/ConsoleApp').
# Only one project path can be passed as a parameter to 'dotnet build' command.
script
:
-
'
dotnet
build
--no-restore'
...
...
@@ -99,9 +108,9 @@ tests:
#
# You can either run tests for all test projects that are defined in your solution
# with 'dotnet test' or run tests only for specific project by specifying
# a relative path to the directory where it is located
e.g. 'dotnet test ./test/UnitTests'.
# a relative path to the directory where it is located
(e.g. 'dotnet test ./test/UnitTests').
#
# You may want to define separate testing jobs for different types of testing
#
e.g. integration tests, unit tests etc
.
#
(e.g. integration tests, unit tests etc)
.
script
:
-
'
dotnet
test
--no-restore'
spec/models/ci/build_spec.rb
View file @
b9a3438b
...
...
@@ -2925,26 +2925,18 @@ describe Ci::Build do
subject
{
build
.
any_unmet_prerequisites?
}
context
'build has prerequisites'
do
before
do
allow
(
build
).
to
receive
(
:prerequisites
).
and_return
([
double
]
)
allow
(
build
).
to
receive
(
:prerequisites
).
and_return
(
prerequisites
)
end
it
{
is_expected
.
to
be_truthy
}
context
'and the ci_preparing_state feature is disabled'
do
before
do
stub_feature_flags
(
ci_preparing_state:
false
)
end
context
'build has prerequisites'
do
let
(
:prerequisites
)
{
[
double
]
}
it
{
is_expected
.
to
be_falsey
}
end
it
{
is_expected
.
to
be_truthy
}
end
context
'build does not have prerequisites'
do
before
do
allow
(
build
).
to
receive
(
:prerequisites
).
and_return
([])
end
let
(
:prerequisites
)
{
[]
}
it
{
is_expected
.
to
be_falsey
}
end
...
...
spec/services/clusters/refresh_service_spec.rb
View file @
b9a3438b
...
...
@@ -93,7 +93,6 @@ describe Clusters::RefreshService do
let
(
:group
)
{
cluster
.
group
}
let
(
:project
)
{
create
(
:project
,
group:
group
)
}
context
'when ci_preparing_state feature flag is enabled'
do
include_examples
'does not create a kubernetes namespace'
context
'when project already has kubernetes namespace'
do
...
...
@@ -105,23 +104,6 @@ describe Clusters::RefreshService do
end
end
context
'when ci_preparing_state feature flag is disabled'
do
before
do
stub_feature_flags
(
ci_preparing_state:
false
)
end
include_examples
'creates a kubernetes namespace'
context
'when project already has kubernetes namespace'
do
before
do
create
(
:cluster_kubernetes_namespace
,
project:
project
,
cluster:
cluster
)
end
include_examples
'does not create a kubernetes namespace'
end
end
end
context
'cluster is not managed'
do
let!
(
:cluster
)
{
create
(
:cluster
,
:project
,
:not_managed
,
projects:
[
project
])
}
...
...
spec/services/projects/create_service_spec.rb
View file @
b9a3438b
...
...
@@ -268,33 +268,6 @@ describe Projects::CreateService, '#execute' do
end
end
context
'when group has kubernetes cluster'
do
let
(
:group_cluster
)
{
create
(
:cluster
,
:group
,
:provided_by_gcp
)
}
let
(
:group
)
{
group_cluster
.
group
}
let
(
:token
)
{
'aaaa'
}
let
(
:service_account_creator
)
{
double
(
Clusters
::
Gcp
::
Kubernetes
::
CreateOrUpdateServiceAccountService
,
execute:
true
)
}
let
(
:secrets_fetcher
)
{
double
(
Clusters
::
Gcp
::
Kubernetes
::
FetchKubernetesTokenService
,
execute:
token
)
}
before
do
group
.
add_owner
(
user
)
stub_feature_flags
(
ci_preparing_state:
false
)
expect
(
Clusters
::
Gcp
::
Kubernetes
::
CreateOrUpdateServiceAccountService
).
to
receive
(
:namespace_creator
).
and_return
(
service_account_creator
)
expect
(
Clusters
::
Gcp
::
Kubernetes
::
FetchKubernetesTokenService
).
to
receive
(
:new
).
and_return
(
secrets_fetcher
)
end
it
'creates kubernetes namespace for the project'
do
project
=
create_project
(
user
,
opts
.
merge!
(
namespace_id:
group
.
id
))
expect
(
project
).
to
be_valid
kubernetes_namespace
=
group_cluster
.
kubernetes_namespaces
.
first
expect
(
kubernetes_namespace
).
to
be_present
expect
(
kubernetes_namespace
.
project
).
to
eq
(
project
)
end
end
context
'when there is an active service template'
do
before
do
create
(
:service
,
project:
nil
,
template:
true
,
active:
true
)
...
...
spec/services/projects/transfer_service_spec.rb
View file @
b9a3438b
...
...
@@ -73,33 +73,6 @@ describe Projects::TransferService do
shard_name:
project
.
repository_storage
)
end
context
'new group has a kubernetes cluster'
do
let
(
:group_cluster
)
{
create
(
:cluster
,
:group
,
:provided_by_gcp
)
}
let
(
:group
)
{
group_cluster
.
group
}
let
(
:token
)
{
'aaaa'
}
let
(
:service_account_creator
)
{
double
(
Clusters
::
Gcp
::
Kubernetes
::
CreateOrUpdateServiceAccountService
,
execute:
true
)
}
let
(
:secrets_fetcher
)
{
double
(
Clusters
::
Gcp
::
Kubernetes
::
FetchKubernetesTokenService
,
execute:
token
)
}
subject
{
transfer_project
(
project
,
user
,
group
)
}
before
do
stub_feature_flags
(
ci_preparing_state:
false
)
expect
(
Clusters
::
Gcp
::
Kubernetes
::
CreateOrUpdateServiceAccountService
).
to
receive
(
:namespace_creator
).
and_return
(
service_account_creator
)
expect
(
Clusters
::
Gcp
::
Kubernetes
::
FetchKubernetesTokenService
).
to
receive
(
:new
).
and_return
(
secrets_fetcher
)
end
it
'creates kubernetes namespace for the project'
do
subject
expect
(
project
.
kubernetes_namespaces
.
count
).
to
eq
(
1
)
kubernetes_namespace
=
group_cluster
.
kubernetes_namespaces
.
first
expect
(
kubernetes_namespace
).
to
be_present
expect
(
kubernetes_namespace
.
project
).
to
eq
(
project
)
end
end
end
context
'when transfer fails'
do
...
...
spec/workers/cluster_configure_worker_spec.rb
View file @
b9a3438b
...
...
@@ -4,11 +4,6 @@ require 'spec_helper'
describe
ClusterConfigureWorker
,
'#perform'
do
let
(
:worker
)
{
described_class
.
new
}
let
(
:ci_preparing_state_enabled
)
{
false
}
before
do
stub_feature_flags
(
ci_preparing_state:
ci_preparing_state_enabled
)
end
shared_examples
'configured cluster'
do
it
'creates a namespace'
do
...
...
@@ -33,28 +28,16 @@ describe ClusterConfigureWorker, '#perform' do
context
'when group has a project'
do
let!
(
:project
)
{
create
(
:project
,
group:
group
)
}
it_behaves_like
'configured cluster'
context
'ci_preparing_state feature is enabled'
do
let
(
:ci_preparing_state_enabled
)
{
true
}
it_behaves_like
'unconfigured cluster'
end
end
context
'when group has project in a sub-group'
do
let!
(
:subgroup
)
{
create
(
:group
,
parent:
group
)
}
let!
(
:project
)
{
create
(
:project
,
group:
subgroup
)
}
it_behaves_like
'configured cluster'
context
'ci_preparing_state feature is enabled'
do
let
(
:ci_preparing_state_enabled
)
{
true
}
it_behaves_like
'unconfigured cluster'
end
end
end
context
'when provider type is gcp'
do
let!
(
:cluster
)
{
create
(
:cluster
,
:project
,
:provided_by_gcp
)
}
...
...
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