Use the new kwargs_from_env so that we can test with boot2docker and fix the issue with the .history call.
This commit is contained in:
		
							parent
							
								
									716d7a737b
								
							
						
					
					
						commit
						b2a0e58756
					
				
					 1 changed files with 15 additions and 6 deletions
				
			
		|  | @ -13,6 +13,7 @@ import shutil | ||||||
| import tarfile | import tarfile | ||||||
| 
 | 
 | ||||||
| from docker import Client | from docker import Client | ||||||
|  | from docker.utils import kwargs_from_env | ||||||
| from docker.errors import APIError | from docker.errors import APIError | ||||||
| from tempfile import TemporaryFile, mkdtemp | from tempfile import TemporaryFile, mkdtemp | ||||||
| from zipfile import ZipFile | from zipfile import ZipFile | ||||||
|  | @ -38,7 +39,12 @@ TIMEOUT_PERIOD_MINUTES = 20 | ||||||
| CACHE_EXPIRATION_PERIOD_HOURS = 24 | CACHE_EXPIRATION_PERIOD_HOURS = 24 | ||||||
| NO_TAGS = ['<none>:<none>'] | NO_TAGS = ['<none>:<none>'] | ||||||
| RESERVATION_TIME = (TIMEOUT_PERIOD_MINUTES + 5) * 60 | RESERVATION_TIME = (TIMEOUT_PERIOD_MINUTES + 5) * 60 | ||||||
| DOCKER_BASE_URL = os.environ.get('DOCKER_HOST', None) | 
 | ||||||
|  | def build_docker_args(): | ||||||
|  |   args = kwargs_from_env() | ||||||
|  |   if 'tls' in args and os.environ.get('IGNORE_TLS_ISSUES', False): | ||||||
|  |     args['tls'].verify = False | ||||||
|  |   return args | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def matches_system_error(status_str): | def matches_system_error(status_str): | ||||||
|  | @ -130,8 +136,8 @@ class DockerfileBuildContext(object): | ||||||
|     # Note: We have two different clients here because we (potentially) login |     # Note: We have two different clients here because we (potentially) login | ||||||
|     # with both, but with different credentials that we do not want shared between |     # with both, but with different credentials that we do not want shared between | ||||||
|     # the build and push operations. |     # the build and push operations. | ||||||
|     self._push_cl = StreamingDockerClient(timeout=1200, base_url=DOCKER_BASE_URL) |     self._push_cl = StreamingDockerClient(timeout=1200, **build_docker_args()) | ||||||
|     self._build_cl = StreamingDockerClient(timeout=1200, base_url=DOCKER_BASE_URL) |     self._build_cl = StreamingDockerClient(timeout=1200, **build_docker_args()) | ||||||
| 
 | 
 | ||||||
|     dockerfile_path = os.path.join(self._build_dir, dockerfile_subdir, |     dockerfile_path = os.path.join(self._build_dir, dockerfile_subdir, | ||||||
|                                    'Dockerfile') |                                    'Dockerfile') | ||||||
|  | @ -337,7 +343,7 @@ class DockerfileBuildContext(object): | ||||||
|       logger.debug('Tagging image %s as %s:%s', built_image, self._repo, tag) |       logger.debug('Tagging image %s as %s:%s', built_image, self._repo, tag) | ||||||
|       self._push_cl.tag(built_image, self._repo, tag) |       self._push_cl.tag(built_image, self._repo, tag) | ||||||
| 
 | 
 | ||||||
|     history = json.loads(self._push_cl.history(built_image)) |     history = self._push_cl.history(built_image) | ||||||
|     num_images = len(history) |     num_images = len(history) | ||||||
| 
 | 
 | ||||||
|     logger.debug('Pushing to repo %s', self._repo) |     logger.debug('Pushing to repo %s', self._repo) | ||||||
|  | @ -480,7 +486,7 @@ class DockerfileBuildWorker(Worker): | ||||||
|   def watchdog(self): |   def watchdog(self): | ||||||
|     logger.debug('Running build watchdog code.') |     logger.debug('Running build watchdog code.') | ||||||
|     try: |     try: | ||||||
|       docker_cl = Client(base_url=DOCKER_BASE_URL) |       docker_cl = Client(**build_docker_args()) | ||||||
| 
 | 
 | ||||||
|       # Iterate the running containers and kill ones that have been running more than 20 minutes |       # Iterate the running containers and kill ones that have been running more than 20 minutes | ||||||
|       for container in docker_cl.containers(): |       for container in docker_cl.containers(): | ||||||
|  | @ -493,6 +499,7 @@ class DockerfileBuildWorker(Worker): | ||||||
|           self._timeout.set() |           self._timeout.set() | ||||||
| 
 | 
 | ||||||
|     except ConnectionError as exc: |     except ConnectionError as exc: | ||||||
|  |       logger.exception('Watchdog exception') | ||||||
|       raise WorkerUnhealthyException(exc.message) |       raise WorkerUnhealthyException(exc.message) | ||||||
| 
 | 
 | ||||||
|   def process_queue_item(self, job_details): |   def process_queue_item(self, job_details): | ||||||
|  | @ -525,9 +532,10 @@ class DockerfileBuildWorker(Worker): | ||||||
| 
 | 
 | ||||||
|     # Lookup and save the version of docker being used. |     # Lookup and save the version of docker being used. | ||||||
|     try: |     try: | ||||||
|       docker_cl = Client(base_url=DOCKER_BASE_URL) |       docker_cl = Client(**build_docker_args()) | ||||||
|       docker_version = docker_cl.version().get('Version', '') |       docker_version = docker_cl.version().get('Version', '') | ||||||
|     except ConnectionError as exc: |     except ConnectionError as exc: | ||||||
|  |       logger.exception('Initial connection exception') | ||||||
|       raise WorkerUnhealthyException(exc.message) |       raise WorkerUnhealthyException(exc.message) | ||||||
| 
 | 
 | ||||||
|     dash = docker_version.find('-') |     dash = docker_version.find('-') | ||||||
|  | @ -664,6 +672,7 @@ class DockerfileBuildWorker(Worker): | ||||||
|     except ConnectionError as exc: |     except ConnectionError as exc: | ||||||
|       # A connection exception means the worker has become unhealthy (Docker is down) |       # A connection exception means the worker has become unhealthy (Docker is down) | ||||||
|       # so we re-raise as that exception. |       # so we re-raise as that exception. | ||||||
|  |       logger.exception('Build connection exception') | ||||||
|       log_appender('Docker daemon has gone away. Will retry shortly.', build_logs.ERROR) |       log_appender('Docker daemon has gone away. Will retry shortly.', build_logs.ERROR) | ||||||
|       raise WorkerUnhealthyException(exc.message) |       raise WorkerUnhealthyException(exc.message) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Reference in a new issue