Avoid getting container details when listing containers
This greatly improves performances when having to list hundred of containers Change-Id: I56473105c48ff517426e542d52eab4053a3d5f9e
This commit is contained in:
parent
667155199c
commit
a09c38840b
@ -38,7 +38,9 @@ def get_docker_client(base_urls: typing.List[str] = None,
|
|||||||
|
|
||||||
def list_docker_containers(client=None, **kwargs):
|
def list_docker_containers(client=None, **kwargs):
|
||||||
try:
|
try:
|
||||||
containers = docker_client(client).containers.list(all=True, **kwargs)
|
containers = docker_client(client).containers.list(all=True,
|
||||||
|
sparse=True,
|
||||||
|
**kwargs)
|
||||||
except _exception.DockerUrlNotFoundError:
|
except _exception.DockerUrlNotFoundError:
|
||||||
return tobiko.Selection()
|
return tobiko.Selection()
|
||||||
else:
|
else:
|
||||||
|
@ -25,21 +25,42 @@ from tobiko.openstack import topology
|
|||||||
from tobiko.shell import ssh
|
from tobiko.shell import ssh
|
||||||
|
|
||||||
|
|
||||||
|
class DockerSSHClientFixture(tobiko.SharedFixture):
|
||||||
|
|
||||||
|
ssh_client: ssh.SSHClientFixture
|
||||||
|
|
||||||
|
def setup_fixture(self):
|
||||||
|
self.ssh_client = self.get_ssh_client()
|
||||||
|
|
||||||
|
def get_ssh_client(self) -> ssh.SSHClientFixture:
|
||||||
|
for ssh_client in self.iter_ssh_clients():
|
||||||
|
if docker.is_docker_running(ssh_client=ssh_client,
|
||||||
|
sudo=True):
|
||||||
|
return ssh_client
|
||||||
|
tobiko.skip_test('Docker is not running')
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def iter_ssh_clients():
|
||||||
|
ssh_client = ssh.ssh_proxy_client()
|
||||||
|
if isinstance(ssh_client, ssh.SSHClientFixture):
|
||||||
|
yield ssh_client
|
||||||
|
|
||||||
|
nodes = topology.list_openstack_nodes()
|
||||||
|
for node in nodes:
|
||||||
|
if isinstance(node.ssh_client, ssh.SSHClientFixture):
|
||||||
|
yield node.ssh_client
|
||||||
|
|
||||||
|
|
||||||
class LocalDockerClientTest(testtools.TestCase):
|
class LocalDockerClientTest(testtools.TestCase):
|
||||||
|
|
||||||
sudo = False
|
sudo = False
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def ssh_client(self) -> ssh.SSHClientType:
|
def ssh_client(self) -> ssh.SSHClientType:
|
||||||
for ssh_client in self.iter_ssh_clients():
|
if docker.is_docker_running(ssh_client=False,
|
||||||
if docker.is_docker_running(ssh_client=ssh_client,
|
|
||||||
sudo=self.sudo):
|
sudo=self.sudo):
|
||||||
return ssh_client
|
return False
|
||||||
tobiko.skip_test('Docker not installed')
|
tobiko.skip_test('Docker is not running')
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def iter_ssh_clients():
|
|
||||||
yield False
|
|
||||||
|
|
||||||
def test_get_docker_client(self):
|
def test_get_docker_client(self):
|
||||||
client = docker.get_docker_client(ssh_client=self.ssh_client,
|
client = docker.get_docker_client(ssh_client=self.ssh_client,
|
||||||
@ -60,17 +81,10 @@ class LocalDockerClientTest(testtools.TestCase):
|
|||||||
self.assertIsInstance(container, containers.Container)
|
self.assertIsInstance(container, containers.Container)
|
||||||
|
|
||||||
|
|
||||||
class SShDockerClientTest(LocalDockerClientTest):
|
class SSHDockerClientTest(LocalDockerClientTest):
|
||||||
|
|
||||||
sudo = True
|
sudo = True
|
||||||
|
|
||||||
@staticmethod
|
@property
|
||||||
def iter_ssh_clients():
|
def ssh_client(self) -> ssh.SSHClientType:
|
||||||
ssh_client = ssh.ssh_proxy_client()
|
return tobiko.setup_fixture(DockerSSHClientFixture).ssh_client
|
||||||
if isinstance(ssh_client, ssh.SSHClientFixture):
|
|
||||||
yield ssh_client
|
|
||||||
|
|
||||||
nodes = topology.list_openstack_nodes()
|
|
||||||
for node in nodes:
|
|
||||||
if isinstance(node.ssh_client, ssh.SSHClientFixture):
|
|
||||||
yield ssh_client
|
|
||||||
|
Loading…
Reference in New Issue
Block a user