浏览代码

Fix 'finalize' command on release script

Signed-off-by: Ulysses Souza <[email protected]>
Ulysses Souza 6 年之前
父节点
当前提交
2d2b0bd9a8
共有 3 个文件被更改,包括 47 次插入24 次删除
  1. 2 7
      script/release/release.py
  2. 1 0
      script/release/release/const.py
  3. 44 17
      script/release/release/images.py

+ 2 - 7
script/release/release.py

@@ -17,6 +17,7 @@ from release.downloader import BinaryDownloader
 from release.images import ImageManager
 from release.images import ImageManager
 from release.pypi import check_pypirc
 from release.pypi import check_pypirc
 from release.pypi import pypi_upload
 from release.pypi import pypi_upload
+from release.images import is_tag_latest
 from release.repository import delete_assets
 from release.repository import delete_assets
 from release.repository import get_contributors
 from release.repository import get_contributors
 from release.repository import Repository
 from release.repository import Repository
@@ -258,7 +259,7 @@ def finalize(args):
     try:
     try:
         check_pypirc()
         check_pypirc()
         repository = Repository(REPO_ROOT, args.repo)
         repository = Repository(REPO_ROOT, args.repo)
-        tag_as_latest = _check_if_tag_latest(args.release)
+        tag_as_latest = is_tag_latest(args.release)
         img_manager = ImageManager(args.release, tag_as_latest)
         img_manager = ImageManager(args.release, tag_as_latest)
         pr_data = repository.find_release_pr(args.release)
         pr_data = repository.find_release_pr(args.release)
         if not pr_data:
         if not pr_data:
@@ -315,12 +316,6 @@ EPILOG = '''Example uses:
 '''
 '''
 
 
 
 
-# Checks if this version respects the GA version format ('x.y.z') and not an RC
-def _check_if_tag_latest(version):
-    ga_version = all(n.isdigit() for n in version.split('.')) and version.count('.') == 2
-    return ga_version and yesno('Should this release be tagged as \"latest\"? Y/n', default=True)
-
-
 def main():
 def main():
     if 'GITHUB_TOKEN' not in os.environ:
     if 'GITHUB_TOKEN' not in os.environ:
         print('GITHUB_TOKEN environment variable must be set')
         print('GITHUB_TOKEN environment variable must be set')

+ 1 - 0
script/release/release/const.py

@@ -6,4 +6,5 @@ import os
 
 
 REPO_ROOT = os.path.join(os.path.dirname(__file__), '..', '..', '..')
 REPO_ROOT = os.path.join(os.path.dirname(__file__), '..', '..', '..')
 NAME = 'docker/compose'
 NAME = 'docker/compose'
+COMPOSE_TESTS_IMAGE_BASE_NAME = NAME + '-tests'
 BINTRAY_ORG = 'docker-compose'
 BINTRAY_ORG = 'docker-compose'

+ 44 - 17
script/release/release/images.py

@@ -9,9 +9,12 @@ import os
 import docker
 import docker
 from enum import Enum
 from enum import Enum
 
 
+from script.release.release.const import COMPOSE_TESTS_IMAGE_BASE_NAME
+
 from .const import NAME
 from .const import NAME
 from .const import REPO_ROOT
 from .const import REPO_ROOT
 from .utils import ScriptError
 from .utils import ScriptError
+from .utils import yesno
 
 
 
 
 class Platform(Enum):
 class Platform(Enum):
@@ -22,9 +25,14 @@ class Platform(Enum):
         return self.value
         return self.value
 
 
 
 
+# Checks if this version respects the GA version format ('x.y.z') and not an RC
+def is_tag_latest(version):
+    ga_version = all(n.isdigit() for n in version.split('.')) and version.count('.') == 2
+    return ga_version and yesno('Should this release be tagged as \"latest\"? [Y/n]: ', default=True)
+
+
 class ImageManager(object):
 class ImageManager(object):
     def __init__(self, version, latest=False):
     def __init__(self, version, latest=False):
-        self.built_tags = []
         self.docker_client = docker.APIClient(**docker.utils.kwargs_from_env())
         self.docker_client = docker.APIClient(**docker.utils.kwargs_from_env())
         self.version = version
         self.version = version
         self.latest = latest
         self.latest = latest
@@ -39,7 +47,15 @@ class ImageManager(object):
         existing_repo_tag = '{image}:{tag}'.format(image=image, tag=existing_tag)
         existing_repo_tag = '{image}:{tag}'.format(image=image, tag=existing_tag)
         new_repo_tag = '{image}:{tag}'.format(image=image, tag=new_tag)
         new_repo_tag = '{image}:{tag}'.format(image=image, tag=new_tag)
         self.docker_client.tag(existing_repo_tag, new_repo_tag)
         self.docker_client.tag(existing_repo_tag, new_repo_tag)
-        self.built_tags.append(new_repo_tag)
+
+    def get_full_version(self, platform=None):
+        return self.version + '-' + platform.__str__() if platform else self.version
+
+    def get_runtime_image_tag(self, tag):
+        return '{image_base_image}:{tag}'.format(
+            image_base_image=NAME,
+            tag=self.get_full_version(tag)
+        )
 
 
     def build_runtime_image(self, repository, platform):
     def build_runtime_image(self, repository, platform):
         git_sha = repository.write_git_sha()
         git_sha = repository.write_git_sha()
@@ -48,11 +64,8 @@ class ImageManager(object):
             image=compose_image_base_name,
             image=compose_image_base_name,
             platform=platform
             platform=platform
         ))
         ))
-        full_version = '{version}-{platform}'.format(version=self.version, platform=platform)
-        build_tag = '{image_base_image}:{full_version}'.format(
-            image_base_image=compose_image_base_name,
-            full_version=full_version
-        )
+        full_version = self.get_full_version(self, platform)
+        build_tag = self.get_runtime_image_tag(platform)
         logstream = self.docker_client.build(
         logstream = self.docker_client.build(
             REPO_ROOT,
             REPO_ROOT,
             tag=build_tag,
             tag=build_tag,
@@ -68,7 +81,6 @@ class ImageManager(object):
             if 'stream' in chunk:
             if 'stream' in chunk:
                 print(chunk['stream'], end='')
                 print(chunk['stream'], end='')
 
 
-        self.built_tags.append(build_tag)
         if platform == Platform.ALPINE:
         if platform == Platform.ALPINE:
             self._tag(compose_image_base_name, full_version, self.version)
             self._tag(compose_image_base_name, full_version, self.version)
         if self.latest:
         if self.latest:
@@ -76,15 +88,17 @@ class ImageManager(object):
             if platform == Platform.ALPINE:
             if platform == Platform.ALPINE:
                 self._tag(compose_image_base_name, full_version, 'latest')
                 self._tag(compose_image_base_name, full_version, 'latest')
 
 
+    def get_ucp_test_image_tag(self, tag=None):
+        return '{image}:{tag}'.format(
+            image=COMPOSE_TESTS_IMAGE_BASE_NAME,
+            tag=tag or self.version
+        )
+
     # Used for producing a test image for UCP
     # Used for producing a test image for UCP
     def build_ucp_test_image(self, repository):
     def build_ucp_test_image(self, repository):
         print('Building test image (debian based for UCP e2e)')
         print('Building test image (debian based for UCP e2e)')
         git_sha = repository.write_git_sha()
         git_sha = repository.write_git_sha()
-        compose_tests_image_base_name = NAME + '-tests'
-        ucp_test_image_tag = '{image}:{tag}'.format(
-            image=compose_tests_image_base_name,
-            tag=self.version
-        )
+        ucp_test_image_tag = self.get_ucp_test_image_tag()
         logstream = self.docker_client.build(
         logstream = self.docker_client.build(
             REPO_ROOT,
             REPO_ROOT,
             tag=ucp_test_image_tag,
             tag=ucp_test_image_tag,
@@ -101,8 +115,7 @@ class ImageManager(object):
             if 'stream' in chunk:
             if 'stream' in chunk:
                 print(chunk['stream'], end='')
                 print(chunk['stream'], end='')
 
 
-        self.built_tags.append(ucp_test_image_tag)
-        self._tag(compose_tests_image_base_name, self.version, 'latest')
+        self._tag(COMPOSE_TESTS_IMAGE_BASE_NAME, self.version, 'latest')
 
 
     def build_images(self, repository):
     def build_images(self, repository):
         self.build_runtime_image(repository, Platform.ALPINE)
         self.build_runtime_image(repository, Platform.ALPINE)
@@ -110,7 +123,7 @@ class ImageManager(object):
         self.build_ucp_test_image(repository)
         self.build_ucp_test_image(repository)
 
 
     def check_images(self):
     def check_images(self):
-        for name in self.built_tags:
+        for name in self.get_images_to_push():
             try:
             try:
                 self.docker_client.inspect_image(name)
                 self.docker_client.inspect_image(name)
             except docker.errors.ImageNotFound:
             except docker.errors.ImageNotFound:
@@ -118,8 +131,22 @@ class ImageManager(object):
                 return False
                 return False
         return True
         return True
 
 
+    def get_images_to_push(self):
+        tags_to_push = {
+            "{}:{}".format(NAME, self.version),
+            self.get_runtime_image_tag(Platform.ALPINE),
+            self.get_runtime_image_tag(Platform.DEBIAN),
+            self.get_ucp_test_image_tag(),
+            self.get_ucp_test_image_tag('latest'),
+        }
+        if is_tag_latest(self.version):
+            tags_to_push.add("{}:latest".format(NAME))
+        return tags_to_push
+
     def push_images(self):
     def push_images(self):
-        for name in self.built_tags:
+        tags_to_push = self.get_images_to_push()
+        print('Build tags to push {}'.format(tags_to_push))
+        for name in tags_to_push:
             print('Pushing {} to Docker Hub'.format(name))
             print('Pushing {} to Docker Hub'.format(name))
             logstream = self.docker_client.push(name, stream=True, decode=True)
             logstream = self.docker_client.push(name, stream=True, decode=True)
             for chunk in logstream:
             for chunk in logstream: