internal/pipewire: additional Client::Info test case
Some checks failed
Test / Create distribution (push) Successful in 35s
Test / Flake checks (push) Has been cancelled
Test / Hpkg (push) Has started running
Test / Sandbox (push) Has been cancelled
Test / Hakurei (push) Has been cancelled
Test / Sandbox (race detector) (push) Has been cancelled
Test / Hakurei (race detector) (push) Has been cancelled

This appears to add *one single entry* compared to the message before it. The inefficiency of this protocol is beyond imagination.

Signed-off-by: Ophestra <cat@gensokyo.uk>
This commit is contained in:
Ophestra 2025-11-26 16:27:46 +09:00
parent 10ff276da1
commit 80980d82fc
Signed by: cat
SSH Key Fingerprint: SHA256:wr6yH7sDDbUFi81k/GsIGwpM3O2QrwqYlLF26CcJa4w
3 changed files with 56 additions and 0 deletions

View File

@ -68,6 +68,51 @@ func TestClientInfo(t *testing.T) {
{Key: "settings.check-rate", Value: "false"}, {Key: "settings.check-rate", Value: "false"},
{Key: "core.version", Value: "1.4.7"}, {Key: "core.version", Value: "1.4.7"},
}}}, nil}, }}}, nil},
{"sample**", []byte(recvmsg00Message04POD), pipewire.ClientInfo{
ID: 34,
ChangeMask: pipewire.PW_CLIENT_CHANGE_MASK_PROPS,
Props: &pipewire.SPADict{NItems: 39, Items: []pipewire.SPADictItem{
{Key: "pipewire.protocol", Value: "protocol-native"},
{Key: "core.name", Value: "pipewire-alice-1443"},
{Key: "pipewire.sec.socket", Value: "pipewire-0-manager"},
{Key: "pipewire.sec.pid", Value: "1443"},
{Key: "pipewire.sec.uid", Value: "1000"},
{Key: "pipewire.sec.gid", Value: "100"},
{Key: "module.id", Value: "2"},
{Key: "object.id", Value: "34"},
{Key: "object.serial", Value: "34"},
{Key: "remote.intention", Value: "manager"},
{Key: "application.name", Value: "pw-container"},
{Key: "application.process.binary", Value: "pw-container"},
{Key: "application.language", Value: "en_US.UTF-8"},
{Key: "application.process.id", Value: "1443"},
{Key: "application.process.user", Value: "alice"},
{Key: "application.process.host", Value: "nixos"},
{Key: "application.process.session-id", Value: "1"},
{Key: "window.x11.display", Value: ":0"},
{Key: "cpu.vm.name", Value: "qemu"},
{Key: "log.level", Value: "0"},
{Key: "cpu.max-align", Value: "32"},
{Key: "default.clock.rate", Value: "48000"},
{Key: "default.clock.quantum", Value: "1024"},
{Key: "default.clock.min-quantum", Value: "32"},
{Key: "default.clock.max-quantum", Value: "2048"},
{Key: "default.clock.quantum-limit", Value: "8192"},
{Key: "default.clock.quantum-floor", Value: "4"},
{Key: "default.video.width", Value: "640"},
{Key: "default.video.height", Value: "480"},
{Key: "default.video.rate.num", Value: "25"},
{Key: "default.video.rate.denom", Value: "1"},
{Key: "clock.power-of-two-quantum", Value: "true"},
{Key: "link.max-buffers", Value: "64"},
{Key: "mem.warn-mlock", Value: "false"},
{Key: "mem.allow-mlock", Value: "true"},
{Key: "settings.check-quantum", Value: "false"},
{Key: "settings.check-rate", Value: "false"},
{Key: "core.version", Value: "1.4.7"},
{Key: "pipewire.access", Value: "unrestricted"},
}}}, nil},
}.run(t) }.run(t)
} }

View File

@ -59,6 +59,12 @@ func TestHeader(t *testing.T) {
Size: 0x7a0, Sequence: 3, FileCount: 0, Size: 0x7a0, Sequence: 3, FileCount: 0,
}, nil}, }, nil},
{"PW_CLIENT_EVENT_INFO**", []byte(recvmsg00Message04Header), pipewire.Header{
ID: pipewire.PW_ID_CLIENT,
Opcode: pipewire.PW_CLIENT_EVENT_INFO,
Size: 0x7d0, Sequence: 4, FileCount: 0,
}, nil},
{"PW_SECURITY_CONTEXT_METHOD_CREATE", []byte{ {"PW_SECURITY_CONTEXT_METHOD_CREATE", []byte{
// Id // Id
3, 0, 0, 0, 3, 0, 0, 0,

View File

@ -46,4 +46,9 @@ var (
recvmsg00Message03Header string recvmsg00Message03Header string
//go:embed testdata/16-recvmsg00-message03-POD //go:embed testdata/16-recvmsg00-message03-POD
recvmsg00Message03POD string recvmsg00Message03POD string
//go:embed testdata/17-recvmsg00-message04-header
recvmsg00Message04Header string
//go:embed testdata/18-recvmsg00-message04-POD
recvmsg00Message04POD string
) )