From 99138717d48770f5d3cf880191f83f195acaafa8 Mon Sep 17 00:00:00 2001 From: Florent BENOIT Date: Mon, 14 Aug 2023 16:48:54 +0200 Subject: [PATCH] =?UTF-8?q?chore:=20allow=20to=20use=20{all:=20true}=C2=A0?= =?UTF-8?q?option=20in=20listContainers=20for=20Podman=20API=20(#3488)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit chore: allow to use {all: true} option there was a missing ? that was not passing the parameters Signed-off-by: Florent Benoit --- .../plugin/dockerode/libpod-dockerode.spec.ts | 46 +++++++++++++++++++ .../src/plugin/dockerode/libpod-dockerode.ts | 2 +- 2 files changed, 47 insertions(+), 1 deletion(-) diff --git a/packages/main/src/plugin/dockerode/libpod-dockerode.spec.ts b/packages/main/src/plugin/dockerode/libpod-dockerode.spec.ts index 6c82ae70e24c2..94e117bf46208 100644 --- a/packages/main/src/plugin/dockerode/libpod-dockerode.spec.ts +++ b/packages/main/src/plugin/dockerode/libpod-dockerode.spec.ts @@ -91,3 +91,49 @@ test('Check list of containers using Podman API', async () => { const firstContainer = listOfContainers[0]; expect(firstContainer.Id).toBe('37a54a845ef27a212634ef00c994c0793b5f19ec16853d606beb1c929461c1cd'); }); + +test('Check list of containers using Podman API and all true options', async () => { + const jsonContainers = [ + { + AutoRemove: false, + Command: ['httpd-foreground'], + Created: '2023-08-09T13:49:31.12068064+02:00', + CreatedAt: '', + Exited: false, + ExitedAt: 1691582587, + ExitCode: 0, + Id: '37a54a845ef27a212634ef00c994c0793b5f19ec16853d606beb1c929461c1cd', + Image: 'docker.io/library/httpd:latest', + ImageID: '911d72fc5020723f0c003a134a8d2f062b4aea884474a11d1db7dcd28ce61d6a', + IsInfra: false, + Labels: null, + Mounts: [], + Names: ['gallant_solomon'], + Namespaces: {}, + Networks: ['podman'], + Pid: 1738, + Pod: '', + PodName: '', + Ports: [ + { + host_ip: '', + container_port: 80, + host_port: 9090, + range: 1, + protocol: 'tcp', + }, + ], + Size: null, + StartedAt: 1691585124, + State: 'running', + Status: '', + }, + ]; + + nock('http://localhost').get('/v4.2.0/libpod/containers/json?all=true').reply(200, jsonContainers); + const api = new Dockerode({ protocol: 'http', host: 'localhost' }); + const listOfContainers = await (api as unknown as LibPod).listPodmanContainers({ all: true }); + expect(listOfContainers.length).toBe(1); + const firstContainer = listOfContainers[0]; + expect(firstContainer.Id).toBe('37a54a845ef27a212634ef00c994c0793b5f19ec16853d606beb1c929461c1cd'); +}); diff --git a/packages/main/src/plugin/dockerode/libpod-dockerode.ts b/packages/main/src/plugin/dockerode/libpod-dockerode.ts index 16cdb3630f506..c7c707e80715f 100644 --- a/packages/main/src/plugin/dockerode/libpod-dockerode.ts +++ b/packages/main/src/plugin/dockerode/libpod-dockerode.ts @@ -139,7 +139,7 @@ export class LibpodDockerode { // add listPodmanContainers prototypeOfDockerode.listPodmanContainers = function (opts?: { all: boolean }) { const optsf = { - path: '/v4.2.0/libpod/containers/json', + path: '/v4.2.0/libpod/containers/json?', method: 'GET', options: opts, statusCodes: {