Merge "Add dev-env-integration test to prow"
diff --git a/jjb/metal3/job_dev_env_integration_tests_prow.yml b/jjb/metal3/job_dev_env_integration_tests_prow.yml
new file mode 100644
index 0000000..ab0ef79
--- /dev/null
+++ b/jjb/metal3/job_dev_env_integration_tests_prow.yml
@@ -0,0 +1,120 @@
+---
+#
+# ============LICENSE_START=======================================================
+# Copyright (C) 2024 Nordix Foundation.
+# ================================================================================
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# SPDX-License-Identifier: Apache-2.0
+# ============LICENSE_END=========================================================
+
+# Description:
+# ============
+# This file contains job template definition for Cluster API Provider Metal3 (CAPM3) integration tests.
+# This job can be triggered manually or through a Github pull request. It creates a
+# pipeline job. The pipeline scripts are maintained in Metal3 CI project infra repository.
+
+- job-template:
+ id: dev_env_integration_tests_prow
+ name: 'dev_env_integration_test_{image_os}_{capm3_target_branch}_{name_postfix}'
+ description: "CAPM3 {capm3_version} integration tests on {image_os} with ironic installed from {ironic_install_type}."
+ project-type: pipeline
+ defaults: integration-default-values
+ disabled: False
+ concurrent: True
+ parameters:
+ # Parameters set by Prow
+ - string:
+ name: BUILD_ID
+ description: 'Used by Prow when triggering jobs'
+ - string:
+ name: PROW_JOB_ID
+ description: 'Used by Prow when triggering jobs'
+ - string:
+ name: REPO_OWNER
+ default: 'metal3-io'
+ description: 'Project github repo org name'
+ - string:
+ name: REPO_NAME
+ default: 'metal3-dev-env'
+ description: 'Project github repo name'
+ - string:
+ name: PULL_BASE_REF
+ default: '{capm3_release_branch}'
+ description: 'Ref name of the base branch'
+ - string:
+ name: PULL_PULL_SHA
+ default: '{capm3_release_branch}'
+ description: 'Pull request head SHA'
+ - string:
+ name: PULL_NUMBER
+ description: 'Pull request number'
+ # End of Prow parameters
+ - string:
+ name: capm3_release_branch
+ default: '{capm3_release_branch}'
+ description: 'The target branch of CAPM3 to be used for this test'
+ - string:
+ name: bmo_release_branch
+ default: '{bmo_release_branch}'
+ description: 'The target branch of BMO to be used for this test'
+ - string:
+ name: IMAGE_OS
+ default: '{image_os}'
+ description: 'Distribution to use for the target host as well as source and target cluster. Can be ubuntu or centos'
+ - string:
+ name: CAPI_VERSION
+ default: '{capi_version}'
+ description: 'Cluster API version.'
+ - string:
+ name: CAPM3_VERSION
+ default: '{capm3_version}'
+ description: 'Cluster API provider Metal3 version.'
+ - string:
+ name: TARGET_NODE_MEMORY
+ default: 4096
+ description: 'RAM size of the target host.'
+ - string:
+ name: IRONIC_INSTALL_TYPE
+ default: '{ironic_install_type}'
+ description: 'Sets the installation type of ironic during ironic-image build of the BMO deployment'
+ - string:
+ name: IRONIC_USE_MARIADB
+ default: '{ironic_use_mariadb}'
+ description: 'If Ironic should use MariaDB or not.'
+ - string:
+ name: BUILD_MARIADB_IMAGE_LOCALLY
+ default: '{build_mariadb_image_locally}'
+ properties:
+ - build-discarder:
+ days-to-keep: 30
+ num-to-keep: 300
+ artifact-days-to-keep: -1
+ artifact-num-to-keep: -1
+
+ triggers: []
+
+ pipeline-scm:
+ scm:
+ - git:
+ url: "{ci_github_repo}"
+ credentials-id: "{ci_github_jenkins_credentials_id}"
+ branches:
+ - '{branch|main}'
+ name: 'origin'
+ refspec: '+refs/heads/*:refs/remotes/origin/*'
+ wipe-workspace: True
+ honor-refspec: True
+ shallow-clone: False
+ script-path: "{dev_env_integration_test_pipeline}"
+ lightweight-checkout: False
diff --git a/jjb/metal3/job_dev_env_main_integration_tests_prow.yaml b/jjb/metal3/job_dev_env_main_integration_tests_prow.yaml
new file mode 100644
index 0000000..0113fc9
--- /dev/null
+++ b/jjb/metal3/job_dev_env_main_integration_tests_prow.yaml
@@ -0,0 +1,121 @@
+---
+#
+# ============LICENSE_START=======================================================
+# Copyright (C) 2024 Nordix Foundation.
+# ================================================================================
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# SPDX-License-Identifier: Apache-2.0
+# ============LICENSE_END=========================================================
+
+# Description:
+# ============
+# This file contains job template definition for Cluster API Provider Metal3 (CAPM3) integration tests.
+# This job runs periodically by timer or it can be triggered manually through Jenkins. It creates a
+# pipeline job. The pipeline scripts are maintained in Metal3 CI project infra repository.
+
+- job-template:
+ id: dev_env_periodic_integration_tests_prow
+ name: 'dev_env_periodic_integration_test_{image_os}_{capm3_target_branch}_{name_postfix}'
+ description: "CAPM3 {capm3_version} integration tests on {image_os} with ironic installed from {ironic_install_type}."
+ project-type: pipeline
+ defaults: integration-default-values
+ disabled: False
+ concurrent: True
+ parameters:
+ # Parameters set by Prow
+ - string:
+ name: BUILD_ID
+ description: 'Used by Prow when triggering jobs'
+ - string:
+ name: PROW_JOB_ID
+ description: 'Used by Prow when triggering jobs'
+ - string:
+ name: REPO_OWNER
+ default: 'metal3-io'
+ description: 'Project github repo org name'
+ - string:
+ name: REPO_NAME
+ default: 'metal3-dev-env'
+ description: 'Project github repo name'
+ - string:
+ name: PULL_BASE_REF
+ default: '{capm3_release_branch}'
+ description: 'Ref name of the base branch'
+ - string:
+ name: PULL_PULL_SHA
+ default: '{capm3_release_branch}'
+ description: 'Pull request head SHA'
+ - string:
+ name: PULL_NUMBER
+ description: 'Pull request number'
+ # End of Prow parameters
+ - string:
+ name: capm3_release_branch
+ default: '{capm3_release_branch}'
+ description: 'The target branch of CAPM3 to be used for this test'
+ - string:
+ name: bmo_release_branch
+ default: '{bmo_release_branch}'
+ description: 'The target branch of BMO to be used for this test'
+ - string:
+ name: IMAGE_OS
+ default: '{image_os}'
+ description: 'Distribution to use for the target host as well as source and target cluster. Can be ubuntu or centos'
+ - string:
+ name: CAPI_VERSION
+ default: '{capi_version}'
+ description: 'Cluster API version.'
+ - string:
+ name: CAPM3_VERSION
+ default: '{capm3_version}'
+ description: 'Cluster API provider Metal3 version.'
+ - string:
+ name: TARGET_NODE_MEMORY
+ default: 4096
+ description: 'RAM size of the target host.'
+ - string:
+ name: IRONIC_INSTALL_TYPE
+ default: '{ironic_install_type}'
+ description: 'Sets the installation type of ironic during ironic-image build of the BMO deployment'
+ - string:
+ name: IRONIC_USE_MARIADB
+ default: '{ironic_use_mariadb}'
+ description: 'If Ironic should use MariaDB or not.'
+ - string:
+ name: BUILD_MARIADB_IMAGE_LOCALLY
+ default: '{build_mariadb_image_locally}'
+ properties:
+ - build-discarder:
+ days-to-keep: 30
+ num-to-keep: 300
+ artifact-days-to-keep: -1
+ artifact-num-to-keep: -1
+
+ triggers:
+ - timed: "{schedule}"
+
+ pipeline-scm:
+ scm:
+ - git:
+ url: "{ci_github_repo}"
+ credentials-id: "{ci_github_jenkins_credentials_id}"
+ branches:
+ - '{branch|main}'
+ name: 'origin'
+ refspec: '+refs/heads/*:refs/remotes/origin/*'
+ wipe-workspace: True
+ honor-refspec: True
+ shallow-clone: False
+ script-path: "{dev_env_integration_test_pipeline}"
+ lightweight-checkout: False
diff --git a/jjb/metal3/projects.yml b/jjb/metal3/projects.yml
index f8c4abf..edd1133 100644
--- a/jjb/metal3/projects.yml
+++ b/jjb/metal3/projects.yml
@@ -1075,3 +1075,83 @@
- 'release-0.3'
jobs:
- dev_env_integration_tests
+
+- project:
+ name: dev-env-integration-tests-prow
+ org: metal3-io
+ proj:
+ - metal3_dev_env:
+ repo: metal3-dev-env
+ - project_infra:
+ repo: project-infra
+ - capm3:
+ repo: cluster-api-provider-metal3
+ - bmo:
+ repo: baremetal-operator
+ - ipam:
+ repo: ip-address-manager
+ - ironic_image:
+ repo: ironic-image
+ name_postfix: '_ironic_from_source'
+ trigger_postfix: '-ironic-source'
+ ironic_install_type: 'source'
+ - ironic_ipa_downloader:
+ repo: ironic-ipa-downloader
+ - mariadb_image:
+ repo: mariadb-image
+ build_mariadb_image_locally: 'true'
+ ironic_use_mariadb: 'true'
+ image_os:
+ - ubuntu
+ - centos
+ jobs:
+ - dev_env_integration_tests_prow:
+ capm3_target_branch:
+ - main:
+ capi_version: v1beta1
+ capm3_version: v1beta1
+ capm3_release_branch: main
+ bmo_release_branch: main
+ target_branches:
+ - 'main'
+ - release-1-6:
+ capi_version: v1beta1
+ capm3_version: v1beta1
+ capm3_release_branch: release-1.6
+ bmo_release_branch: release-0.5
+ target_branches:
+ - 'main'
+ - 'release-1.6'
+ - 'release-0.5'
+ - release-1-5:
+ capi_version: v1beta1
+ capm3_version: v1beta1
+ capm3_release_branch: release-1.5
+ bmo_release_branch: release-0.4
+ target_branches:
+ - 'main'
+ - 'release-1.5'
+ - 'release-0.4'
+ - release-1-4:
+ capi_version: v1beta1
+ capm3_version: v1beta1
+ capm3_release_branch: release-1.4
+ bmo_release_branch: release-0.3
+ target_branches:
+ - 'main'
+ - 'release-1.4'
+ - 'release-0.3'
+ - dev_env_periodic_integration_tests_prow:
+ capm3_target_branch:
+ - main:
+ capi_version: v1beta1
+ capm3_version: v1beta1
+ capm3_release_branch: main
+ bmo_release_branch: main
+ schedule: "H 4 * * *"
+ - release-1-6:
+ capi_version: v1beta1
+ capm3_version: v1beta1
+ capm3_release_branch: release-1.6
+ bmo_release_branch: release-0.5
+ schedule: "30 4 * * *"