Commit 9f843a82 authored by Igor Drozdov's avatar Igor Drozdov

Merge branch 'skip_factory_stubbing' into 'master'

Skip stubbing so that these factories can be used with let_it_be

See merge request gitlab-org/gitlab!59092
parents c45ca54a 455fdcff
...@@ -4,18 +4,26 @@ FactoryBot.define do ...@@ -4,18 +4,26 @@ FactoryBot.define do
factory :clusters_applications_helm, class: 'Clusters::Applications::Helm' do factory :clusters_applications_helm, class: 'Clusters::Applications::Helm' do
cluster factory: %i(cluster provided_by_gcp) cluster factory: %i(cluster provided_by_gcp)
before(:create) do transient do
allow(Gitlab::Kubernetes::Helm::V2::Certificate).to receive(:generate_root) helm_installed { true }
.and_return( end
double(
key_string: File.read(Rails.root.join('spec/fixtures/clusters/sample_key.key')), before(:create) do |_record, evaluator|
cert_string: File.read(Rails.root.join('spec/fixtures/clusters/sample_cert.pem')) if evaluator.helm_installed
allow(Gitlab::Kubernetes::Helm::V2::Certificate).to receive(:generate_root)
.and_return(
double(
key_string: File.read(Rails.root.join('spec/fixtures/clusters/sample_key.key')),
cert_string: File.read(Rails.root.join('spec/fixtures/clusters/sample_cert.pem'))
)
) )
) end
end end
after(:create) do after(:create) do |_record, evaluator|
allow(Gitlab::Kubernetes::Helm::V2::Certificate).to receive(:generate_root).and_call_original if evaluator.helm_installed
allow(Gitlab::Kubernetes::Helm::V2::Certificate).to receive(:generate_root).and_call_original
end
end end
trait :not_installable do trait :not_installable do
...@@ -78,14 +86,19 @@ FactoryBot.define do ...@@ -78,14 +86,19 @@ FactoryBot.define do
updated_at { ClusterWaitForAppInstallationWorker::TIMEOUT.ago } updated_at { ClusterWaitForAppInstallationWorker::TIMEOUT.ago }
end end
# Common trait used by the apps below
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
transient do
helm_installed { false }
end
end
factory :clusters_applications_ingress, class: 'Clusters::Applications::Ingress' do factory :clusters_applications_ingress, class: 'Clusters::Applications::Ingress' do
modsecurity_enabled { false } modsecurity_enabled { false }
cluster factory: %i(cluster with_installed_helm provided_by_gcp) cluster factory: %i(cluster with_installed_helm provided_by_gcp)
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
end
trait :modsecurity_blocking do trait :modsecurity_blocking do
modsecurity_enabled { true } modsecurity_enabled { true }
modsecurity_mode { :blocking } modsecurity_mode { :blocking }
...@@ -108,62 +121,34 @@ FactoryBot.define do ...@@ -108,62 +121,34 @@ FactoryBot.define do
factory :clusters_applications_cert_manager, class: 'Clusters::Applications::CertManager' do factory :clusters_applications_cert_manager, class: 'Clusters::Applications::CertManager' do
email { 'admin@example.com' } email { 'admin@example.com' }
cluster factory: %i(cluster with_installed_helm provided_by_gcp) cluster factory: %i(cluster with_installed_helm provided_by_gcp)
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
end
end end
factory :clusters_applications_elastic_stack, class: 'Clusters::Applications::ElasticStack' do factory :clusters_applications_elastic_stack, class: 'Clusters::Applications::ElasticStack' do
cluster factory: %i(cluster with_installed_helm provided_by_gcp) cluster factory: %i(cluster with_installed_helm provided_by_gcp)
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
end
end end
factory :clusters_applications_crossplane, class: 'Clusters::Applications::Crossplane' do factory :clusters_applications_crossplane, class: 'Clusters::Applications::Crossplane' do
stack { 'gcp' } stack { 'gcp' }
cluster factory: %i(cluster with_installed_helm provided_by_gcp) cluster factory: %i(cluster with_installed_helm provided_by_gcp)
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
end
end end
factory :clusters_applications_prometheus, class: 'Clusters::Applications::Prometheus' do factory :clusters_applications_prometheus, class: 'Clusters::Applications::Prometheus' do
cluster factory: %i(cluster with_installed_helm provided_by_gcp) cluster factory: %i(cluster with_installed_helm provided_by_gcp)
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
end
end end
factory :clusters_applications_runner, class: 'Clusters::Applications::Runner' do factory :clusters_applications_runner, class: 'Clusters::Applications::Runner' do
runner factory: %i(ci_runner) runner factory: %i(ci_runner)
cluster factory: %i(cluster with_installed_helm provided_by_gcp) cluster factory: %i(cluster with_installed_helm provided_by_gcp)
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
end
end end
factory :clusters_applications_knative, class: 'Clusters::Applications::Knative' do factory :clusters_applications_knative, class: 'Clusters::Applications::Knative' do
hostname { 'example.com' } hostname { 'example.com' }
cluster factory: %i(cluster with_installed_helm provided_by_gcp) cluster factory: %i(cluster with_installed_helm provided_by_gcp)
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
end
end end
factory :clusters_applications_jupyter, class: 'Clusters::Applications::Jupyter' do factory :clusters_applications_jupyter, class: 'Clusters::Applications::Jupyter' do
oauth_application factory: :oauth_application oauth_application factory: :oauth_application
cluster factory: %i(cluster with_installed_helm provided_by_gcp project) cluster factory: %i(cluster with_installed_helm provided_by_gcp project)
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
end
end end
factory :clusters_applications_fluentd, class: 'Clusters::Applications::Fluentd' do factory :clusters_applications_fluentd, class: 'Clusters::Applications::Fluentd' do
...@@ -171,18 +156,10 @@ FactoryBot.define do ...@@ -171,18 +156,10 @@ FactoryBot.define do
waf_log_enabled { true } waf_log_enabled { true }
cilium_log_enabled { true } cilium_log_enabled { true }
cluster factory: %i(cluster with_installed_helm provided_by_gcp) cluster factory: %i(cluster with_installed_helm provided_by_gcp)
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
end
end end
factory :clusters_applications_cilium, class: 'Clusters::Applications::Cilium' do factory :clusters_applications_cilium, class: 'Clusters::Applications::Cilium' do
cluster factory: %i(cluster with_installed_helm provided_by_gcp) cluster factory: %i(cluster with_installed_helm provided_by_gcp)
trait :no_helm_installed do
cluster factory: %i(cluster provided_by_gcp)
end
end end
end end
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