mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
Drone: Upload artifacts for release branch builds (#29297)
Signed-off-by: Arve Knudsen <arve.knudsen@gmail.com>
This commit is contained in:
parent
e4f465929d
commit
5cec4095b2
48
.drone.yml
48
.drone.yml
@ -2240,7 +2240,7 @@ depends_on:
|
|||||||
---
|
---
|
||||||
kind: pipeline
|
kind: pipeline
|
||||||
type: docker
|
type: docker
|
||||||
name: oss-build-version-branch
|
name: oss-build-release-branch
|
||||||
|
|
||||||
platform:
|
platform:
|
||||||
os: linux
|
os: linux
|
||||||
@ -2459,6 +2459,19 @@ steps:
|
|||||||
- test-backend
|
- test-backend
|
||||||
- test-frontend
|
- test-frontend
|
||||||
|
|
||||||
|
- name: upload-packages
|
||||||
|
image: grafana/grafana-ci-deploy:1.2.7
|
||||||
|
commands:
|
||||||
|
- ./bin/grabpl upload-packages --edition oss
|
||||||
|
environment:
|
||||||
|
GCP_GRAFANA_UPLOAD_KEY:
|
||||||
|
from_secret: gcp_key
|
||||||
|
depends_on:
|
||||||
|
- package
|
||||||
|
- end-to-end-tests
|
||||||
|
- mysql-integration-tests
|
||||||
|
- postgres-integration-tests
|
||||||
|
|
||||||
services:
|
services:
|
||||||
- name: postgres
|
- name: postgres
|
||||||
image: postgres:12.3-alpine
|
image: postgres:12.3-alpine
|
||||||
@ -2482,7 +2495,7 @@ trigger:
|
|||||||
---
|
---
|
||||||
kind: pipeline
|
kind: pipeline
|
||||||
type: docker
|
type: docker
|
||||||
name: oss-windows-version-branch
|
name: oss-windows-release-branch
|
||||||
|
|
||||||
platform:
|
platform:
|
||||||
os: windows
|
os: windows
|
||||||
@ -2522,12 +2535,12 @@ trigger:
|
|||||||
- refs/heads/v*
|
- refs/heads/v*
|
||||||
|
|
||||||
depends_on:
|
depends_on:
|
||||||
- oss-build-version-branch
|
- oss-build-release-branch
|
||||||
|
|
||||||
---
|
---
|
||||||
kind: pipeline
|
kind: pipeline
|
||||||
type: docker
|
type: docker
|
||||||
name: enterprise-build-version-branch
|
name: enterprise-build-release-branch
|
||||||
|
|
||||||
platform:
|
platform:
|
||||||
os: linux
|
os: linux
|
||||||
@ -2767,6 +2780,19 @@ steps:
|
|||||||
- test-backend
|
- test-backend
|
||||||
- test-frontend
|
- test-frontend
|
||||||
|
|
||||||
|
- name: upload-packages
|
||||||
|
image: grafana/grafana-ci-deploy:1.2.7
|
||||||
|
commands:
|
||||||
|
- ./bin/grabpl upload-packages --edition enterprise
|
||||||
|
environment:
|
||||||
|
GCP_GRAFANA_UPLOAD_KEY:
|
||||||
|
from_secret: gcp_key
|
||||||
|
depends_on:
|
||||||
|
- package
|
||||||
|
- end-to-end-tests
|
||||||
|
- mysql-integration-tests
|
||||||
|
- postgres-integration-tests
|
||||||
|
|
||||||
services:
|
services:
|
||||||
- name: postgres
|
- name: postgres
|
||||||
image: postgres:12.3-alpine
|
image: postgres:12.3-alpine
|
||||||
@ -2790,7 +2816,7 @@ trigger:
|
|||||||
---
|
---
|
||||||
kind: pipeline
|
kind: pipeline
|
||||||
type: docker
|
type: docker
|
||||||
name: enterprise-windows-version-branch
|
name: enterprise-windows-release-branch
|
||||||
|
|
||||||
platform:
|
platform:
|
||||||
os: windows
|
os: windows
|
||||||
@ -2851,12 +2877,12 @@ trigger:
|
|||||||
- refs/heads/v*
|
- refs/heads/v*
|
||||||
|
|
||||||
depends_on:
|
depends_on:
|
||||||
- enterprise-build-version-branch
|
- enterprise-build-release-branch
|
||||||
|
|
||||||
---
|
---
|
||||||
kind: pipeline
|
kind: pipeline
|
||||||
type: docker
|
type: docker
|
||||||
name: notify-version-branch
|
name: notify-release-branch
|
||||||
|
|
||||||
platform:
|
platform:
|
||||||
os: linux
|
os: linux
|
||||||
@ -2878,9 +2904,9 @@ trigger:
|
|||||||
- failure
|
- failure
|
||||||
|
|
||||||
depends_on:
|
depends_on:
|
||||||
- oss-build-version-branch
|
- oss-build-release-branch
|
||||||
- oss-windows-version-branch
|
- oss-windows-release-branch
|
||||||
- enterprise-build-version-branch
|
- enterprise-build-release-branch
|
||||||
- enterprise-windows-version-branch
|
- enterprise-windows-release-branch
|
||||||
|
|
||||||
...
|
...
|
||||||
|
@ -125,7 +125,7 @@ def init_steps(edition, platform, ver_mode, is_downstream=False, install_deps=Tr
|
|||||||
source_commit = ' ${DRONE_TAG}'
|
source_commit = ' ${DRONE_TAG}'
|
||||||
elif ver_mode == 'test-release':
|
elif ver_mode == 'test-release':
|
||||||
committish = 'master'
|
committish = 'master'
|
||||||
elif ver_mode == 'version-branch':
|
elif ver_mode == 'release-branch':
|
||||||
committish = '${DRONE_BRANCH}'
|
committish = '${DRONE_BRANCH}'
|
||||||
else:
|
else:
|
||||||
if is_downstream:
|
if is_downstream:
|
||||||
@ -532,7 +532,7 @@ def package_step(edition, ver_mode, variants=None, is_downstream=False):
|
|||||||
variants_str = ' --variants {}'.format(','.join(variants))
|
variants_str = ' --variants {}'.format(','.join(variants))
|
||||||
else:
|
else:
|
||||||
variants_str = ''
|
variants_str = ''
|
||||||
if ver_mode in ('master', 'release', 'test-release', 'version-branch'):
|
if ver_mode in ('master', 'release', 'test-release', 'release-branch'):
|
||||||
sign_args = ' --sign'
|
sign_args = ' --sign'
|
||||||
env = {
|
env = {
|
||||||
'GRAFANA_API_KEY': {
|
'GRAFANA_API_KEY': {
|
||||||
@ -870,7 +870,7 @@ def get_windows_steps(edition, ver_mode, is_downstream=False):
|
|||||||
},
|
},
|
||||||
]
|
]
|
||||||
if (ver_mode == 'master' and (edition != 'enterprise' or is_downstream)) or ver_mode in (
|
if (ver_mode == 'master' and (edition != 'enterprise' or is_downstream)) or ver_mode in (
|
||||||
'release', 'test-release', 'version-branch',
|
'release', 'test-release', 'release-branch',
|
||||||
):
|
):
|
||||||
bucket_part = ''
|
bucket_part = ''
|
||||||
bucket = 'grafana-downloads'
|
bucket = 'grafana-downloads'
|
||||||
@ -926,7 +926,7 @@ def get_windows_steps(edition, ver_mode, is_downstream=False):
|
|||||||
committish = '${DRONE_TAG}'
|
committish = '${DRONE_TAG}'
|
||||||
elif ver_mode == 'test-release':
|
elif ver_mode == 'test-release':
|
||||||
committish = 'master'
|
committish = 'master'
|
||||||
elif ver_mode == 'version-branch':
|
elif ver_mode == 'release-branch':
|
||||||
committish = '$$env:DRONE_BRANCH'
|
committish = '$$env:DRONE_BRANCH'
|
||||||
else:
|
else:
|
||||||
committish = '$$env:DRONE_COMMIT'
|
committish = '$$env:DRONE_COMMIT'
|
||||||
|
@ -57,7 +57,10 @@ def release_npm_packages_step(edition, ver_mode):
|
|||||||
'commands': commands,
|
'commands': commands,
|
||||||
}
|
}
|
||||||
|
|
||||||
def get_steps(edition, ver_mode, publish):
|
def get_steps(edition, ver_mode):
|
||||||
|
should_publish = ver_mode in ('release', 'test-release',)
|
||||||
|
should_upload = should_publish or ver_mode in ('release-branch',)
|
||||||
|
|
||||||
steps = [
|
steps = [
|
||||||
lint_backend_step(edition),
|
lint_backend_step(edition),
|
||||||
codespell_step(),
|
codespell_step(),
|
||||||
@ -73,14 +76,15 @@ def get_steps(edition, ver_mode, publish):
|
|||||||
e2e_tests_step(),
|
e2e_tests_step(),
|
||||||
build_storybook_step(edition=edition, ver_mode=ver_mode),
|
build_storybook_step(edition=edition, ver_mode=ver_mode),
|
||||||
copy_packages_for_docker_step(),
|
copy_packages_for_docker_step(),
|
||||||
build_docker_images_step(edition=edition, ver_mode=ver_mode, publish=publish),
|
build_docker_images_step(edition=edition, ver_mode=ver_mode, publish=should_publish),
|
||||||
build_docker_images_step(edition=edition, ver_mode=ver_mode, ubuntu=True, publish=publish),
|
build_docker_images_step(edition=edition, ver_mode=ver_mode, ubuntu=True, publish=should_publish),
|
||||||
postgres_integration_tests_step(),
|
postgres_integration_tests_step(),
|
||||||
mysql_integration_tests_step(),
|
mysql_integration_tests_step(),
|
||||||
]
|
]
|
||||||
if publish:
|
if should_upload:
|
||||||
|
steps.append(upload_packages_step(edition=edition, ver_mode=ver_mode))
|
||||||
|
if should_publish:
|
||||||
steps.extend([
|
steps.extend([
|
||||||
upload_packages_step(edition=edition, ver_mode=ver_mode),
|
|
||||||
publish_storybook_step(edition=edition, ver_mode=ver_mode),
|
publish_storybook_step(edition=edition, ver_mode=ver_mode),
|
||||||
release_npm_packages_step(edition=edition, ver_mode=ver_mode),
|
release_npm_packages_step(edition=edition, ver_mode=ver_mode),
|
||||||
])
|
])
|
||||||
@ -88,9 +92,9 @@ def get_steps(edition, ver_mode, publish):
|
|||||||
|
|
||||||
return steps, windows_steps
|
return steps, windows_steps
|
||||||
|
|
||||||
def get_oss_pipelines(trigger, ver_mode, publish):
|
def get_oss_pipelines(trigger, ver_mode):
|
||||||
services = integration_test_services()
|
services = integration_test_services()
|
||||||
steps, windows_steps = get_steps(edition='oss', ver_mode=ver_mode, publish=publish)
|
steps, windows_steps = get_steps(edition='oss', ver_mode=ver_mode)
|
||||||
return [
|
return [
|
||||||
pipeline(
|
pipeline(
|
||||||
name='oss-build-{}'.format(ver_mode), edition='oss', trigger=trigger, services=services, steps=steps,
|
name='oss-build-{}'.format(ver_mode), edition='oss', trigger=trigger, services=services, steps=steps,
|
||||||
@ -102,9 +106,9 @@ def get_oss_pipelines(trigger, ver_mode, publish):
|
|||||||
),
|
),
|
||||||
]
|
]
|
||||||
|
|
||||||
def get_enterprise_pipelines(trigger, ver_mode, publish):
|
def get_enterprise_pipelines(trigger, ver_mode):
|
||||||
services = integration_test_services()
|
services = integration_test_services()
|
||||||
steps, windows_steps = get_steps(edition='enterprise', ver_mode=ver_mode, publish=publish)
|
steps, windows_steps = get_steps(edition='enterprise', ver_mode=ver_mode)
|
||||||
return [
|
return [
|
||||||
pipeline(
|
pipeline(
|
||||||
name='enterprise-build-{}'.format(ver_mode), edition='enterprise', trigger=trigger, services=services,
|
name='enterprise-build-{}'.format(ver_mode), edition='enterprise', trigger=trigger, services=services,
|
||||||
@ -155,16 +159,16 @@ def release_pipelines(ver_mode='release', trigger=None):
|
|||||||
'ref': ['refs/tags/v*',],
|
'ref': ['refs/tags/v*',],
|
||||||
}
|
}
|
||||||
|
|
||||||
publish = ver_mode in ('release', 'test-release',)
|
should_publish = ver_mode in ('release', 'test-release',)
|
||||||
|
|
||||||
# The release pipelines include also enterprise ones, so both editions are built for a release.
|
# The release pipelines include also enterprise ones, so both editions are built for a release.
|
||||||
# We could also solve this by triggering a downstream build for the enterprise repo, but by including enterprise
|
# We could also solve this by triggering a downstream build for the enterprise repo, but by including enterprise
|
||||||
# in OSS release builds, we simplify the UX for the release engineer.
|
# in OSS release builds, we simplify the UX for the release engineer.
|
||||||
oss_pipelines = get_oss_pipelines(ver_mode=ver_mode, trigger=trigger, publish=publish)
|
oss_pipelines = get_oss_pipelines(ver_mode=ver_mode, trigger=trigger)
|
||||||
enterprise_pipelines = get_enterprise_pipelines(ver_mode=ver_mode, trigger=trigger, publish=publish)
|
enterprise_pipelines = get_enterprise_pipelines(ver_mode=ver_mode, trigger=trigger)
|
||||||
|
|
||||||
pipelines = oss_pipelines + enterprise_pipelines
|
pipelines = oss_pipelines + enterprise_pipelines
|
||||||
if publish:
|
if should_publish:
|
||||||
publish_pipeline = pipeline(
|
publish_pipeline = pipeline(
|
||||||
name='publish-{}'.format(ver_mode), trigger=trigger, edition='oss', steps=[
|
name='publish-{}'.format(ver_mode), trigger=trigger, edition='oss', steps=[
|
||||||
publish_packages_step(edition='oss'),
|
publish_packages_step(edition='oss'),
|
||||||
@ -189,8 +193,8 @@ def test_release_pipelines():
|
|||||||
'event': ['custom',],
|
'event': ['custom',],
|
||||||
}
|
}
|
||||||
|
|
||||||
oss_pipelines = get_oss_pipelines(ver_mode=ver_mode, trigger=trigger, publish=True)
|
oss_pipelines = get_oss_pipelines(ver_mode=ver_mode, trigger=trigger)
|
||||||
enterprise_pipelines = get_enterprise_pipelines(ver_mode=ver_mode, trigger=trigger, publish=True)
|
enterprise_pipelines = get_enterprise_pipelines(ver_mode=ver_mode, trigger=trigger)
|
||||||
|
|
||||||
publish_cmd = './bin/grabpl publish-packages --edition {{}} --dry-run {}'.format(test_release_ver)
|
publish_cmd = './bin/grabpl publish-packages --edition {{}} --dry-run {}'.format(test_release_ver)
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@ load(
|
|||||||
'release_pipelines',
|
'release_pipelines',
|
||||||
)
|
)
|
||||||
|
|
||||||
ver_mode = 'version-branch'
|
ver_mode = 'release-branch'
|
||||||
|
|
||||||
def version_branch_pipelines():
|
def version_branch_pipelines():
|
||||||
return release_pipelines(ver_mode=ver_mode, trigger={
|
return release_pipelines(ver_mode=ver_mode, trigger={
|
||||||
|
Loading…
Reference in New Issue
Block a user