From 011d24df4a590eaa5aeb2e88b874ce41298ad6045febe40ca379828e62f1614f Mon Sep 17 00:00:00 2001 From: Marcus Schaefer Date: Fri, 2 Oct 2020 12:35:15 +0000 Subject: [PATCH 1/2] =?UTF-8?q?-=20Bump=20version:=209.21.14=20=E2=86=92?= =?UTF-8?q?=209.21.15?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Align dracut-kiwi-lib version with packages requiring it This commit enforces dracut-kiwi-oem-repart and dracut-kiwi-oem-dump to require dracut-kiwi-lib of the same exact version. This prevents dracut-kiwi-lib and the packages dependent on it being installed on a image with inconsistent versions. Fixes #1529 - Allow to configure .changes creation and bundling Provide config option has_package_changes in the runtime config file and set a useful default. For building outside obs the default for the .changes creation is switched on, for building in obs it's switched off because obs creates its own info file - Fix compat link for rpmdb location This commit fixes the symlink creation for `/var/lib/rpm`. More specific for derived container images in which the base root tree already included the `/var/lib/rpm` the link, the `ln` command was creating a symlink inside the `/var/lib/rpm` folder givent that it was following the already existing symlink. Adding the `--no-target-directory` force `ln` command to treat `/var/lib/rpm` path as the fully qualified symlink name. Fixes bsc#1176977 - Report download URL on failed request In case a network request to a given URL failed the report message should include the URL This Fixes #1572 - Use pragma: no cover to skip non reachable code Instead of placing the file into .coveragerc use the OBS-URL: https://build.opensuse.org/package/show/Virtualization:Appliances:Builder/python-kiwi?expand=0&rev=183 --- PKGBUILD | 8 +-- python-kiwi.changes | 144 ++++++++++++++++++++++++++++++++++++++++++++ python-kiwi.spec | 6 +- python-kiwi.tar.gz | 4 +- 4 files changed, 153 insertions(+), 9 deletions(-) diff --git a/PKGBUILD b/PKGBUILD index 843d066..d6b52f1 100644 --- a/PKGBUILD +++ b/PKGBUILD @@ -3,7 +3,7 @@ pkgname=('python-kiwi' 'kiwi-man-pages' 'dracut-kiwi-lib' 'dracut-kiwi-oem-repart' 'dracut-kiwi-oem-dump' 'dracut-kiwi-live' 'dracut-kiwi-overlay') arch=(x86_64) -pkgver=9.21.14 +pkgver=9.21.15 pkgrel=0 pkgdesc="KIWI - Appliance Builder Next Generation" url="https://github.com/SUSE/kiwi/tarball/master" @@ -12,7 +12,7 @@ makedepends=(python-setuptools gcc shadow grep) provides=(kiwi-ng kiwi) source=("${pkgname}.tar.gz") changelog="${pkgname}.changes" -md5sums=('fefbad94106141392d967912d4ba4084') +md5sums=('a11f21fa0785c3615c54933e6c753341') build() { @@ -42,14 +42,14 @@ package_dracut-kiwi-lib(){ } package_dracut-kiwi-oem-repart(){ - depends=(dracut-kiwi-lib) + depends=(dracut-kiwi-lib=${pkgver}) cd kiwi-${pkgver} install -d -m 755 ${pkgdir}/usr/lib/dracut/modules.d/90kiwi-repart cp -a dracut/modules.d/90kiwi-repart ${pkgdir}/usr/lib/dracut/modules.d/ } package_dracut-kiwi-oem-dump(){ - depends=(dracut-kiwi-lib multipath-tools) + depends=(dracut-kiwi-lib=${pkgver} multipath-tools) cd kiwi-${pkgver} install -d -m 755 ${pkgdir}/usr/lib/dracut/modules.d/90kiwi-dump cp -a dracut/modules.d/90kiwi-dump ${pkgdir}/usr/lib/dracut/modules.d/ diff --git a/python-kiwi.changes b/python-kiwi.changes index 6c02bc8..ad6f3ac 100644 --- a/python-kiwi.changes +++ b/python-kiwi.changes @@ -1,3 +1,138 @@ +------------------------------------------------------------------- +Fri Oct 02 14:04:51 CEST 2020 - Marcus Schäfer + +- Bump version: 9.21.14 → 9.21.15 + +------------------------------------------------------------------- +Fri Oct 02 11:54:25 CEST 2020 - David Cassany + +- Align dracut-kiwi-lib version with packages requiring it + + This commit enforces dracut-kiwi-oem-repart and + dracut-kiwi-oem-dump to require dracut-kiwi-lib of the same exact + version. This prevents dracut-kiwi-lib and the packages + dependent on it being installed on a image with inconsistent versions. + + Fixes #1529 + +------------------------------------------------------------------- +Fri Oct 02 11:15:36 CEST 2020 - Marcus Schäfer + +- Allow to configure .changes creation and bundling + + Provide config option has_package_changes in the runtime config + file and set a useful default. For building outside obs the + default for the .changes creation is switched on, for building + in obs it's switched off because obs creates its own info file + +------------------------------------------------------------------- +Tue Sep 29 13:37:13 CEST 2020 - David Cassany + +- Fix compat link for rpmdb location + + This commit fixes the symlink creation for `/var/lib/rpm`. More specific + for derived container images in which the base root tree already + included the `/var/lib/rpm` the link, the `ln` command was creating a + symlink inside the `/var/lib/rpm` folder givent that it was following + the already existing symlink. Adding the `--no-target-directory` force + `ln` command to treat `/var/lib/rpm` path as the fully qualified symlink name. + + Fixes bsc#1176977 + +------------------------------------------------------------------- +Tue Sep 29 10:17:55 CEST 2020 - Jim Klimov + +- Report download URL on failed request + + In case a network request to a given URL failed the report message should include the URL + This Fixes #1572 + +------------------------------------------------------------------- +Tue Sep 29 09:58:22 CEST 2020 - Marcus Schäfer + +- Use pragma: no cover to skip non reachable code + + Instead of placing the file into .coveragerc use the + no cover pragma to skip code paths that can never be + reached from being counted in the coverage report. + This affects the abstract constructors in the Factory + classes + +------------------------------------------------------------------- +Mon Sep 28 09:37:05 CEST 2020 - David Cassany + +- Refactor BootLoaderInstall + + This commit refactors BootLoaderInstall class to make it a proper + factory class. In addition type hints are added for the constructor + method. + + Related to #1498 + +------------------------------------------------------------------- +Fri Sep 25 17:13:38 CEST 2020 - David Cassany + +- Refactor BootLoaderConfig + + This commit refactors BootLoaderConfig to turn it into a proper factory + class and to also include type hints to facilitate it's use from an API + POV. + + Related to #1498 + +------------------------------------------------------------------- +Fri Sep 25 10:53:02 CEST 2020 - Marcus Schäfer + +- Fix/Refactor s390 support + + This changes the s390 support on several stages: + + 1) On s390 the boot process is based on zipl which boots into an + initrd from which a userspace grub process is started to support + the grub capabilities. The implementation of this concept is + provided via the grub2-s390x-emu package. Once installed the + setup of the bootloader is done via the grub2-mkconfig and + grub2-install commands and therefore from a caller perspective + the same as with any other grub2 setup process. For kiwi this + means no extra zipl bootloader target code is needed. Therefore + this commit deletes the zipl setup from kiwi and puts on + the standard grub2 process. This Fixes bsc#1170863 + + 2) To support different targettypes the grub2-s390x-emu provided + zipl template must be adapted. Parts of the former zipl bootloader + setup therefore now applies to an update of the zipl2grub + template file + + 3) Support for CDL/LDL DASD targets has been disabled in the schema + When testing 4k devices and a respective zipl2grub template + setup for CDL/LDL targettype it has turned out that grub2-install + is not able to run on such a device. My assumption is that + the device code in grub2-install does not work for 4k devices + with an fdasd created partition table. As this needs further + investigations and most probably adaptions on the grub toolchain + for s390, we disabled the setup of these modes for now. + emulated DASD (FBA) and SCSI targets stays supported. + +------------------------------------------------------------------- +Wed Sep 23 17:49:14 CEST 2020 - Marcus Schäfer + +- Add support for package changelog info + + In addition to the .packages file which shows details about + the installed packages in terms of version, license, etc... + we now also create a .changes file which contains the changelog + information of the installed packages. The file can be used + to compare the package changelogs between image builds. + +------------------------------------------------------------------- +Wed Sep 23 15:45:17 CEST 2020 - Marcus Schäfer + +- Refactor BootImage Factory + + This commit refactors the BootImage factory to be a real + factory and to add type hints such that its use from an api + perspective is clear and enforced. Related to Issue #1498 + ------------------------------------------------------------------- Wed Sep 23 13:06:47 CEST 2020 - Marcus Schäfer @@ -27,6 +162,15 @@ Wed Sep 23 10:21:40 CEST 2020 - Marcus Schäfer option --type vmx into --type oem if provided and prints a warning message. +------------------------------------------------------------------- +Tue Sep 22 16:28:17 CEST 2020 - Marcus Schäfer + +- Refactor ImageBuilder Factory + + This commit refactors the ImageBuilder factory to be a real + factory and to add type hints such that its use from an api + perspective is clear and enforced. Related to Issue #1498 + ------------------------------------------------------------------- Tue Sep 22 12:19:15 CEST 2020 - Marcus Schäfer diff --git a/python-kiwi.spec b/python-kiwi.spec index 0dac3f6..9c25165 100644 --- a/python-kiwi.spec +++ b/python-kiwi.spec @@ -43,7 +43,7 @@ %endif Name: python-kiwi -Version: 9.21.14 +Version: 9.21.15 Provides: kiwi-schema = 7.2 Release: 0 Url: https://github.com/OSInside/kiwi @@ -272,7 +272,7 @@ Summary: KIWI - Dracut module for oem(repart) image type # to set up the build environment... BuildRequires: dracut %endif -Requires: dracut-kiwi-lib +Requires: dracut-kiwi-lib = %{version} License: GPL-3.0-or-later Group: %{sysgroup} @@ -289,7 +289,7 @@ Summary: KIWI - Dracut module for oem(install) image type # to set up the build environment... BuildRequires: dracut %endif -Requires: dracut-kiwi-lib +Requires: dracut-kiwi-lib = %{version} Requires: kexec-tools Requires: gawk Requires: kpartx diff --git a/python-kiwi.tar.gz b/python-kiwi.tar.gz index 34f2b03..8f5c6ca 100644 --- a/python-kiwi.tar.gz +++ b/python-kiwi.tar.gz @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:52c065b2da55cc4843e49965b7ce025937d41f3e5847208470d8f5b3abf0f79c -size 1724750 +oid sha256:8c2ef81c840a5b3b3314ee920fafc81ea04d11d4310fc7ce7c831cc311008f4f +size 1720761 From d8d2c74be160662e2d490189ec710893d182bc58341bdb8e892787f340371998 Mon Sep 17 00:00:00 2001 From: Marcus Schaefer Date: Mon, 5 Oct 2020 13:27:47 +0000 Subject: [PATCH 2/2] =?UTF-8?q?-=20Bump=20version:=209.21.16=20=E2=86=92?= =?UTF-8?q?=209.21.17?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Make dependencies to dracut-kiwi-lib release specific This commit adds a dracut-kiwi-lib dependency to dracut-kiwi-oem-dump and darcut-kiwi-oem-repart to match up to the release level. This way the dependency ensures the pulled binaries they are all part of the same build. - Bump version: 9.21.15 → 9.21.16 - Delete length limitation of image id attribute For legacy reasons the attributes was limited to 10digits. The contents of /etc/ImageID are now free format and no longer strictly evaluated. Thus the limitations on the id attribute can be deleted OBS-URL: https://build.opensuse.org/package/show/Virtualization:Appliances:Builder/python-kiwi?expand=0&rev=184 --- PKGBUILD | 4 ++-- python-kiwi.changes | 29 +++++++++++++++++++++++++++++ python-kiwi.spec | 6 +++--- python-kiwi.tar.gz | 4 ++-- 4 files changed, 36 insertions(+), 7 deletions(-) diff --git a/PKGBUILD b/PKGBUILD index d6b52f1..d82bfc7 100644 --- a/PKGBUILD +++ b/PKGBUILD @@ -3,7 +3,7 @@ pkgname=('python-kiwi' 'kiwi-man-pages' 'dracut-kiwi-lib' 'dracut-kiwi-oem-repart' 'dracut-kiwi-oem-dump' 'dracut-kiwi-live' 'dracut-kiwi-overlay') arch=(x86_64) -pkgver=9.21.15 +pkgver=9.21.17 pkgrel=0 pkgdesc="KIWI - Appliance Builder Next Generation" url="https://github.com/SUSE/kiwi/tarball/master" @@ -12,7 +12,7 @@ makedepends=(python-setuptools gcc shadow grep) provides=(kiwi-ng kiwi) source=("${pkgname}.tar.gz") changelog="${pkgname}.changes" -md5sums=('a11f21fa0785c3615c54933e6c753341') +md5sums=('1823efaf3892bec7b0ea06177ae51ccf') build() { diff --git a/python-kiwi.changes b/python-kiwi.changes index ad6f3ac..b33aea2 100644 --- a/python-kiwi.changes +++ b/python-kiwi.changes @@ -1,3 +1,32 @@ +------------------------------------------------------------------- +Mon Oct 05 15:06:20 CEST 2020 - Marcus Schäfer + +- Bump version: 9.21.16 → 9.21.17 + +------------------------------------------------------------------- +Mon Oct 05 14:56:48 CEST 2020 - David Cassany + +- Make dependencies to dracut-kiwi-lib release specific + + This commit adds a dracut-kiwi-lib dependency to dracut-kiwi-oem-dump and + darcut-kiwi-oem-repart to match up to the release level. This way the + dependency ensures the pulled binaries they are all part of the same build. + +------------------------------------------------------------------- +Mon Oct 05 12:24:29 CEST 2020 - Marcus Schäfer + +- Bump version: 9.21.15 → 9.21.16 + +------------------------------------------------------------------- +Mon Oct 05 09:34:59 CEST 2020 - Marcus Schäfer + +- Delete length limitation of image id attribute + + For legacy reasons the attributes was + limited to 10digits. The contents of /etc/ImageID are now + free format and no longer strictly evaluated. Thus the + limitations on the id attribute can be deleted + ------------------------------------------------------------------- Fri Oct 02 14:04:51 CEST 2020 - Marcus Schäfer diff --git a/python-kiwi.spec b/python-kiwi.spec index 9c25165..5872c9e 100644 --- a/python-kiwi.spec +++ b/python-kiwi.spec @@ -43,7 +43,7 @@ %endif Name: python-kiwi -Version: 9.21.15 +Version: 9.21.17 Provides: kiwi-schema = 7.2 Release: 0 Url: https://github.com/OSInside/kiwi @@ -272,7 +272,7 @@ Summary: KIWI - Dracut module for oem(repart) image type # to set up the build environment... BuildRequires: dracut %endif -Requires: dracut-kiwi-lib = %{version} +Requires: dracut-kiwi-lib = %{version}-%{release} License: GPL-3.0-or-later Group: %{sysgroup} @@ -289,7 +289,7 @@ Summary: KIWI - Dracut module for oem(install) image type # to set up the build environment... BuildRequires: dracut %endif -Requires: dracut-kiwi-lib = %{version} +Requires: dracut-kiwi-lib = %{version}-%{release} Requires: kexec-tools Requires: gawk Requires: kpartx diff --git a/python-kiwi.tar.gz b/python-kiwi.tar.gz index 8f5c6ca..a60908f 100644 --- a/python-kiwi.tar.gz +++ b/python-kiwi.tar.gz @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:8c2ef81c840a5b3b3314ee920fafc81ea04d11d4310fc7ce7c831cc311008f4f -size 1720761 +oid sha256:4fd472065b6a9c09566247120458779842833a358d9938945ac58477e79e590c +size 1720818