From 14b395e1ff47adc7dc346af28a9b906f901b4661 Mon Sep 17 00:00:00 2001 From: Haochen Tong Date: Sun, 22 Sep 2024 23:58:24 +0800 Subject: [PATCH] test: Add a test for EFI zboot images Closes: https://github.com/projg2/eclean-kernel/pull/53 --- test/test_file.py | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/test/test_file.py b/test/test_file.py index f96dd02..9b5eb8b 100644 --- a/test/test_file.py +++ b/test/test_file.py @@ -4,6 +4,7 @@ import gzip import hashlib import os +import struct import tempfile import unittest @@ -98,6 +99,22 @@ def write_efistub(path: Path, f.write(version_line) +def write_efi_zboot(path: Path, + version_line: bytes, + ) -> None: + """Write an EFI zboot kernel image at `path`, with `version_line`""" + # generate a compressed image as our payload + write_compress(path, version_line) + b = path.read_bytes() + + with open(path, "wb") as f: + f.write(b"MZ\0\0zimg") + f.write(struct.pack(" None: self.td = tempfile.TemporaryDirectory() @@ -147,6 +164,13 @@ def test_read_internal_version_efistub_uname_nowhitespace(self) -> None: KernelImage(path).read_internal_version(), "1.2.3") + def test_read_internal_version_efi_zboot(self) -> None: + path = Path(self.td.name) / "vmlinuz" + write_efi_zboot(path, b"Linux version 1.2.3 built on test") + self.assertEqual( + KernelImage(path).read_internal_version(), + "1.2.3") + def test_very_short(self) -> None: path = Path(self.td.name) / 'vmlinuz' with open(path, 'wb') as f: