|  | @@ -49,7 +49,6 @@ const (
 | 
											
												
													
														|  |  	singleContainerTag        = "docker-single-container"
 |  |  	singleContainerTag        = "docker-single-container"
 | 
											
												
													
														|  |  	composeContainerTag       = "docker-compose-application"
 |  |  	composeContainerTag       = "docker-compose-application"
 | 
											
												
													
														|  |  	composeContainerSeparator = "_"
 |  |  	composeContainerSeparator = "_"
 | 
											
												
													
														|  | -	statusUnknown             = "Unknown"
 |  | 
 | 
											
												
													
														|  |  	statusRunning             = "Running"
 |  |  	statusRunning             = "Running"
 | 
											
												
													
														|  |  )
 |  |  )
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -166,38 +165,20 @@ func (cs *aciContainerService) List(ctx context.Context, all bool) ([]containers
 | 
											
												
													
														|  |  			if *container.Name == convert.ComposeDNSSidecarName {
 |  |  			if *container.Name == convert.ComposeDNSSidecarName {
 | 
											
												
													
														|  |  				continue
 |  |  				continue
 | 
											
												
													
														|  |  			}
 |  |  			}
 | 
											
												
													
														|  | -			if !all && getStatus(container) != statusRunning {
 |  | 
 | 
											
												
													
														|  | 
 |  | +			if !all && convert.GetStatus(container, group) != statusRunning {
 | 
											
												
													
														|  |  				continue
 |  |  				continue
 | 
											
												
													
														|  |  			}
 |  |  			}
 | 
											
												
													
														|  |  			containerID := *containerGroup.Name + composeContainerSeparator + *container.Name
 |  |  			containerID := *containerGroup.Name + composeContainerSeparator + *container.Name
 | 
											
												
													
														|  |  			if _, ok := group.Tags[singleContainerTag]; ok {
 |  |  			if _, ok := group.Tags[singleContainerTag]; ok {
 | 
											
												
													
														|  |  				containerID = *containerGroup.Name
 |  |  				containerID = *containerGroup.Name
 | 
											
												
													
														|  |  			}
 |  |  			}
 | 
											
												
													
														|  | -			c := getContainer(containerID, group.IPAddress, container)
 |  | 
 | 
											
												
													
														|  | 
 |  | +			c := convert.ContainerGroupToContainer(containerID, group, container)
 | 
											
												
													
														|  |  			res = append(res, c)
 |  |  			res = append(res, c)
 | 
											
												
													
														|  |  		}
 |  |  		}
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	return res, nil
 |  |  	return res, nil
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -func getContainer(containerID string, ipAddress *containerinstance.IPAddress, container containerinstance.Container) containers.Container {
 |  | 
 | 
											
												
													
														|  | -	status := getStatus(container)
 |  | 
 | 
											
												
													
														|  | -	return containers.Container{
 |  | 
 | 
											
												
													
														|  | -		ID:     containerID,
 |  | 
 | 
											
												
													
														|  | -		Image:  *container.Image,
 |  | 
 | 
											
												
													
														|  | -		Status: status,
 |  | 
 | 
											
												
													
														|  | -		Ports:  convert.ToPorts(ipAddress, *container.Ports),
 |  | 
 | 
											
												
													
														|  | -	}
 |  | 
 | 
											
												
													
														|  | -}
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -func getStatus(container containerinstance.Container) string {
 |  | 
 | 
											
												
													
														|  | -	status := statusUnknown
 |  | 
 | 
											
												
													
														|  | -	if container.InstanceView != nil && container.InstanceView.CurrentState != nil {
 |  | 
 | 
											
												
													
														|  | -		status = *container.InstanceView.CurrentState.State
 |  | 
 | 
											
												
													
														|  | -	}
 |  | 
 | 
											
												
													
														|  | -	return status
 |  | 
 | 
											
												
													
														|  | -}
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |  func (cs *aciContainerService) Run(ctx context.Context, r containers.ContainerConfig) error {
 |  |  func (cs *aciContainerService) Run(ctx context.Context, r containers.ContainerConfig) error {
 | 
											
												
													
														|  |  	if strings.Contains(r.ID, composeContainerSeparator) {
 |  |  	if strings.Contains(r.ID, composeContainerSeparator) {
 | 
											
												
													
														|  |  		return errors.New(fmt.Sprintf("invalid container name. ACI container name cannot include %q", composeContainerSeparator))
 |  |  		return errors.New(fmt.Sprintf("invalid container name. ACI container name cannot include %q", composeContainerSeparator))
 | 
											
										
											
												
													
														|  | @@ -350,10 +331,7 @@ func (cs *aciContainerService) Delete(ctx context.Context, containerID string, r
 | 
											
												
													
														|  |  		}
 |  |  		}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		for _, container := range *cg.Containers {
 |  |  		for _, container := range *cg.Containers {
 | 
											
												
													
														|  | -			status := statusUnknown
 |  | 
 | 
											
												
													
														|  | -			if container.InstanceView != nil && container.InstanceView.CurrentState != nil {
 |  | 
 | 
											
												
													
														|  | -				status = *container.InstanceView.CurrentState.State
 |  | 
 | 
											
												
													
														|  | -			}
 |  | 
 | 
											
												
													
														|  | 
 |  | +			status := convert.GetStatus(container, cg)
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  			if status == statusRunning {
 |  |  			if status == statusRunning {
 | 
											
												
													
														|  |  				return errdefs.ErrForbidden
 |  |  				return errdefs.ErrForbidden
 | 
											
										
											
												
													
														|  | @@ -397,7 +375,7 @@ func (cs *aciContainerService) Inspect(ctx context.Context, containerID string)
 | 
											
												
													
														|  |  		return containers.Container{}, errdefs.ErrNotFound
 |  |  		return containers.Container{}, errdefs.ErrNotFound
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	return convert.ContainerGroupToContainer(containerID, cg, cc)
 |  | 
 | 
											
												
													
														|  | 
 |  | +	return convert.ContainerGroupToContainer(containerID, cg, cc), nil
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  type aciComposeService struct {
 |  |  type aciComposeService struct {
 |