mirror of
https://github.com/containers/podman.git
synced 2025-10-25 18:25:59 +08:00
Add volume filters to system prune
This change was missed in pull/8689. Now that volume pruneing supports filters system pruneing can pass its filters down to the volume pruneing. Additionally this change adds tests for the following components * podman system prune subcommand with `--volumes` & `--filter` options * apiv2 api tests for `/system/` and `/libpod/system` endpoints Relates to #8453, #8672 Signed-off-by: Baron Lenardson <lenardson.baron@gmail.com>
This commit is contained in:
67
test/apiv2/45-system.at
Normal file
67
test/apiv2/45-system.at
Normal file
@ -0,0 +1,67 @@
|
||||
# -*- sh -*-
|
||||
#
|
||||
# system related tests
|
||||
#
|
||||
|
||||
## ensure system is clean
|
||||
t POST 'libpod/system/prune?volumes=true&all=true' params='' 200
|
||||
|
||||
## podman system df
|
||||
t GET system/df 200 '{"LayersSize":0,"Images":[],"Containers":[],"Volumes":[],"BuildCache":[],"BuilderSize":0}'
|
||||
t GET libpod/system/df 200 '{"Images":[],"Containers":[],"Volumes":[]}'
|
||||
|
||||
# Create volume. We expect df to report this volume next invocation of system/df
|
||||
t GET libpod/info 200
|
||||
volumepath=$(jq -r ".store.volumePath" <<<"$output")
|
||||
t POST libpod/volumes/create name=foo1 201 \
|
||||
.Name=foo1 \
|
||||
.Driver=local \
|
||||
.Mountpoint=$volumepath/foo1/_data \
|
||||
.CreatedAt~[0-9]\\{4\\}-[0-9]\\{2\\}-[0-9]\\{2\\}.* \
|
||||
.Labels={} \
|
||||
.Options=null
|
||||
|
||||
t GET system/df 200 '.Volumes[0].Name=foo1'
|
||||
|
||||
t GET libpod/system/df 200 '.Volumes[0].VolumeName=foo1'
|
||||
|
||||
# Create two more volumes to test pruneing
|
||||
t POST libpod/volumes/create \
|
||||
'"Name":"foo2","Label":{"testlabel1":""},"Options":{"type":"tmpfs","o":"nodev,noexec"}}' 201 \
|
||||
.Name=foo2 \
|
||||
.Driver=local \
|
||||
.Mountpoint=$volumepath/foo2/_data \
|
||||
.CreatedAt~[0-9]\\{4\\}-[0-9]\\{2\\}-[0-9]\\{2\\}.* \
|
||||
.Labels.testlabel1="" \
|
||||
.Options.o=nodev,noexec
|
||||
|
||||
t POST libpod/volumes/create \
|
||||
'"Name":"foo3","Label":{"testlabel1":"testonly"},"Options":{"type":"tmpfs","o":"nodev,noexec"}}' 201 \
|
||||
.Name=foo3 \
|
||||
.Driver=local \
|
||||
.Mountpoint=$volumepath/foo3/_data \
|
||||
.CreatedAt~[0-9]\\{4\\}-[0-9]\\{2\\}-[0-9]\\{2\\}.* \
|
||||
.Labels.testlabel1=testonly \
|
||||
.Options.o=nodev,noexec
|
||||
|
||||
t GET system/df 200 '.Volumes | length=3'
|
||||
t GET libpod/system/df 200 '.Volumes | length=3'
|
||||
|
||||
# Prune volumes
|
||||
|
||||
# -G --data-urlencode 'volumes=true&filters={"label":["testlabel1=idontmatch"]}'
|
||||
t POST 'libpod/system/prune?volumes=true&filters=%7B%22label%22:%5B%22testlabel1=idontmatch%22%5D%7D' params='' 200
|
||||
|
||||
# nothing should have been pruned
|
||||
t GET system/df 200 '.Volumes | length=3'
|
||||
t GET libpod/system/df 200 '.Volumes | length=3'
|
||||
|
||||
# -G --data-urlencode 'volumes=true&filters={"label":["testlabel1=testonly"]}'
|
||||
# only foo3 should be pruned because of filter
|
||||
t POST 'libpod/system/prune?volumes=true&filters=%7B%22label%22:%5B%22testlabel1=testonly%22%5D%7D' params='' 200 .VolumePruneReport[0].Id=foo3
|
||||
# only foo2 should be pruned because of filter
|
||||
t POST 'libpod/system/prune?volumes=true&filters=%7B%22label%22:%5B%22testlabel1%22%5D%7D' params='' 200 .VolumePruneReport[0].Id=foo2
|
||||
# foo1, the last remaining volume should be pruned without any filters applied
|
||||
t POST 'libpod/system/prune?volumes=true' params='' 200 .VolumePruneReport[0].Id=foo1
|
||||
|
||||
# TODO add other system prune tests for pods / images
|
||||
@ -349,4 +349,64 @@ var _ = Describe("Podman prune", func() {
|
||||
// all images are unused, so they all should be deleted!
|
||||
Expect(len(images.OutputToStringArray())).To(Equal(len(CACHE_IMAGES)))
|
||||
})
|
||||
|
||||
It("podman system prune --volumes --filter", func() {
|
||||
session := podmanTest.Podman([]string{"volume", "create", "--label", "label1=value1", "myvol1"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"volume", "create", "--label", "sharedlabel1=slv1", "myvol2"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"volume", "create", "--label", "sharedlabel1=slv2", "myvol3"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"volume", "create", "--label", "sharedlabel1", "myvol4"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"create", "-v", "myvol5:/myvol5", ALPINE, "ls"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"create", "-v", "myvol6:/myvol6", ALPINE, "ls"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"volume", "ls"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
Expect(len(session.OutputToStringArray())).To(Equal(7))
|
||||
|
||||
session = podmanTest.Podman([]string{"system", "prune", "--force", "--volumes", "--filter", "label=label1=value1"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"volume", "ls"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
Expect(len(session.OutputToStringArray())).To(Equal(6))
|
||||
|
||||
session = podmanTest.Podman([]string{"system", "prune", "--force", "--volumes", "--filter", "label=sharedlabel1=slv1"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"volume", "ls"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
Expect(len(session.OutputToStringArray())).To(Equal(5))
|
||||
|
||||
session = podmanTest.Podman([]string{"system", "prune", "--force", "--volumes", "--filter", "label=sharedlabel1"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"volume", "ls"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session.ExitCode()).To(Equal(0))
|
||||
Expect(len(session.OutputToStringArray())).To(Equal(3))
|
||||
|
||||
podmanTest.Cleanup()
|
||||
})
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user