2018-11-01 11:26:04 +01:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
import base
|
|
|
|
|
|
|
|
try:
|
|
|
|
import docker
|
|
|
|
except ImportError:
|
|
|
|
import pip
|
|
|
|
pip.main(['install', 'docker'])
|
|
|
|
import docker
|
|
|
|
|
|
|
|
class DockerAPI(object):
|
|
|
|
def __init__(self):
|
2020-01-20 04:51:03 +01:00
|
|
|
self.DCLIENT = docker.APIClient(base_url='unix://var/run/docker.sock',version='auto',timeout=30)
|
2019-09-03 09:52:41 +02:00
|
|
|
self.DCLIENT2 = docker.from_env()
|
2018-11-01 11:26:04 +01:00
|
|
|
|
2019-05-06 05:34:11 +02:00
|
|
|
def docker_login(self, registry, username, password, expected_error_message = None):
|
|
|
|
if expected_error_message is "":
|
|
|
|
expected_error_message = None
|
2018-11-01 11:26:04 +01:00
|
|
|
try:
|
|
|
|
self.DCLIENT.login(registry = registry, username=username, password=password)
|
2019-05-06 05:34:11 +02:00
|
|
|
except docker.errors.APIError, err:
|
|
|
|
if expected_error_message is not None:
|
|
|
|
print "docker login error:", str(err)
|
|
|
|
if str(err).lower().find(expected_error_message.lower()) < 0:
|
|
|
|
raise Exception(r"Docker login: Return message {} is not as expected {}".format(str(err), expected_error_message))
|
|
|
|
else:
|
2019-09-11 07:34:23 +02:00
|
|
|
raise Exception(r" Docker login failed, error is [{}]".format (err.message))
|
2018-11-01 11:26:04 +01:00
|
|
|
|
2018-11-21 05:19:28 +01:00
|
|
|
def docker_image_pull(self, image, tag = None, expected_error_message = None):
|
2018-11-01 11:26:04 +01:00
|
|
|
if tag is not None:
|
|
|
|
_tag = tag
|
2018-11-21 05:19:28 +01:00
|
|
|
else:
|
|
|
|
_tag = "latest"
|
2019-02-18 06:47:16 +01:00
|
|
|
if expected_error_message is "":
|
|
|
|
expected_error_message = None
|
|
|
|
caught_err = False
|
|
|
|
ret = ""
|
2018-11-01 11:26:04 +01:00
|
|
|
try:
|
2019-02-18 06:47:16 +01:00
|
|
|
ret = base._get_string_from_unicode(self.DCLIENT.pull(r'{}:{}'.format(image, _tag)))
|
2018-11-21 05:19:28 +01:00
|
|
|
except Exception, err:
|
2019-02-18 06:47:16 +01:00
|
|
|
caught_err = True
|
2018-11-21 05:19:28 +01:00
|
|
|
if expected_error_message is not None:
|
|
|
|
print "docker image pull error:", str(err)
|
|
|
|
if str(err).lower().find(expected_error_message.lower()) < 0:
|
2019-02-18 06:47:16 +01:00
|
|
|
raise Exception(r"Pull image: Return message {} is not as expected {}".format(str(err), expected_error_message))
|
2018-11-21 05:19:28 +01:00
|
|
|
else:
|
2019-02-18 06:47:16 +01:00
|
|
|
raise Exception(r" Docker pull image {} failed, error is [{}]".format (image, err.message))
|
|
|
|
if caught_err == False:
|
|
|
|
if expected_error_message is not None:
|
|
|
|
if str(ret).lower().find(expected_error_message.lower()) < 0:
|
2020-01-27 20:31:18 +01:00
|
|
|
raise Exception(r" Failed to catch error [{}] when pull image {}, return message: {}".format (expected_error_message, image, str(ret)))
|
2019-02-18 06:47:16 +01:00
|
|
|
else:
|
|
|
|
if str(ret).lower().find("error".lower()) >= 0:
|
|
|
|
raise Exception(r" It's was not suppose to catch error when pull image {}, return message is [{}]".format (image, ret))
|
2018-11-01 11:26:04 +01:00
|
|
|
|
|
|
|
def docker_image_tag(self, image, harbor_registry, tag = None):
|
|
|
|
_tag = base._random_name("tag")
|
|
|
|
if tag is not None:
|
|
|
|
_tag = tag
|
|
|
|
try:
|
2018-12-03 10:05:06 +01:00
|
|
|
self.DCLIENT.tag(image, harbor_registry, _tag, force=True)
|
2018-11-01 11:26:04 +01:00
|
|
|
return harbor_registry, _tag
|
|
|
|
except docker.errors.APIError, e:
|
|
|
|
raise Exception(r" Docker tag image {} failed, error is [{}]".format (image, e.message))
|
|
|
|
|
2019-02-18 06:47:16 +01:00
|
|
|
def docker_image_push(self, harbor_registry, tag, expected_error_message = None):
|
|
|
|
caught_err = False
|
|
|
|
ret = ""
|
|
|
|
if expected_error_message is "":
|
|
|
|
expected_error_message = None
|
2018-11-01 11:26:04 +01:00
|
|
|
try:
|
2019-02-18 06:47:16 +01:00
|
|
|
ret = base._get_string_from_unicode(self.DCLIENT.push(harbor_registry, tag, stream=True))
|
|
|
|
except Exception, err:
|
|
|
|
caught_err = True
|
|
|
|
if expected_error_message is not None:
|
|
|
|
print "docker image push error:", str(err)
|
|
|
|
if str(err).lower().find(expected_error_message.lower()) < 0:
|
|
|
|
raise Exception(r"Push image: Return message {} is not as expected {}".format(str(err), expected_error_message))
|
|
|
|
else:
|
|
|
|
raise Exception(r" Docker push image {} failed, error is [{}]".format (harbor_registry, err.message))
|
|
|
|
if caught_err == False:
|
|
|
|
if expected_error_message is not None:
|
|
|
|
if str(ret).lower().find(expected_error_message.lower()) < 0:
|
2020-01-27 20:31:18 +01:00
|
|
|
raise Exception(r" Failed to catch error [{}] when push image {}, return message: {}".
|
|
|
|
format (expected_error_message, harbor_registry, str(ret)))
|
2019-02-18 06:47:16 +01:00
|
|
|
else:
|
|
|
|
if str(ret).lower().find("errorDetail".lower()) >= 0:
|
2020-01-27 20:31:18 +01:00
|
|
|
raise Exception(r" It's was not suppose to catch error when push image {}, return message is [{}]".
|
|
|
|
format (harbor_registry, ret))
|
2019-09-03 09:52:41 +02:00
|
|
|
|
|
|
|
def docker_image_build(self, harbor_registry, tags=None, size=1, expected_error_message = None):
|
|
|
|
caught_err = False
|
|
|
|
ret = ""
|
|
|
|
try:
|
|
|
|
baseimage='busybox:latest'
|
|
|
|
if not self.DCLIENT.images(name=baseimage):
|
|
|
|
self.DCLIENT.pull(baseimage)
|
|
|
|
c=self.DCLIENT.create_container(image='busybox:latest',command='dd if=/dev/urandom of=test bs=1M count=%d' % size )
|
|
|
|
self.DCLIENT.start(c)
|
|
|
|
self.DCLIENT.wait(c)
|
|
|
|
if not tags:
|
|
|
|
tags=['latest']
|
|
|
|
firstrepo="%s:%s" % (harbor_registry, tags[0])
|
|
|
|
#self.DCLIENT.commit(c, firstrepo)
|
|
|
|
self.DCLIENT2.containers.get(c).commit(harbor_registry, tags[0])
|
|
|
|
for tag in tags[1:]:
|
|
|
|
repo="%s:%s" % (harbor_registry, tag)
|
|
|
|
self.DCLIENT.tag(firstrepo, repo)
|
|
|
|
for tag in tags:
|
|
|
|
repo="%s:%s" % (harbor_registry, tag)
|
|
|
|
self.DCLIENT.push(repo)
|
|
|
|
print("build image %s with size %d" % (repo, size))
|
|
|
|
self.DCLIENT.remove_image(repo)
|
|
|
|
self.DCLIENT.remove_container(c)
|
|
|
|
except Exception, err:
|
|
|
|
caught_err = True
|
|
|
|
if expected_error_message is not None:
|
|
|
|
print "docker image build error:", str(err)
|
|
|
|
if str(err).lower().find(expected_error_message.lower()) < 0:
|
|
|
|
raise Exception(r"Push image: Return message {} is not as expected {}".format(str(err), expected_error_message))
|
|
|
|
else:
|
|
|
|
raise Exception(r" Docker build image {} failed, error is [{}]".format (harbor_registry, err.message))
|
|
|
|
if caught_err == False:
|
|
|
|
if expected_error_message is not None:
|
|
|
|
if str(ret).lower().find(expected_error_message.lower()) < 0:
|
2020-01-27 20:31:18 +01:00
|
|
|
raise Exception(r" Failed to catch error [{}] when build image {}, return message: {}".
|
|
|
|
format (expected_error_message, harbor_registry, str(ret)))
|
2019-09-03 09:52:41 +02:00
|
|
|
else:
|
|
|
|
if str(ret).lower().find("errorDetail".lower()) >= 0:
|
|
|
|
raise Exception(r" It's was not suppose to catch error when push image {}, return message is [{}]".format (harbor_registry, ret))
|