On Wed, Nov 20, 2019 at 12:11 AM Jim Fehlig <jfehlig@xxxxxxxx> wrote: > > On 11/19/19 6:52 AM, Fabiano Fidêncio wrote: > > On Tue, Nov 19, 2019 at 11:33 AM Andrea Bolognani <abologna@xxxxxxxxxx> wrote: > >> > >> On Tue, 2019-11-19 at 00:21 +0000, Jim Fehlig wrote: > >>> Signed-off-by: Jim Fehlig <jfehlig@xxxxxxxx> > >>> --- > >>> guests/configs/autoinst.xml | 86 +++++++++++++++++++ > >>> .../libvirt-opensuse-15.1/docker.yml | 2 + > >>> .../libvirt-opensuse-15.1/install.yml | 2 + > >>> .../host_vars/libvirt-opensuse-15.1/main.yml | 22 +++++ > >>> guests/inventory | 1 + > >>> guests/lcitool | 2 + > >>> guests/vars/mappings.yml | 38 +++++++- > >>> 7 files changed, 151 insertions(+), 2 deletions(-) > >> > >> First of all, thank you for following through with your promise of > >> looking into this! I'm looking forward to being able to merge your > >> changes and finally have proper openSUSE support in our CI :) > >> > >> [...] > >>> +++ b/guests/configs/autoinst.xml > >>> + <partitioning config:type="list"> > >>> + <drive> > >>> + <device>/dev/vda</device> > >>> + <use>all</use> > >>> + <partitions config:type="list"> > >>> + <partition> > >>> + <filesystem config:type="symbol">swap</filesystem> > >>> + <size>500M</size> > >>> + <mount>swap</mount> > >> > >> We give other guests only 256 MiB of swap, so do the same here to > >> be consistent. Building libvirt and friends is CPU-bound rather than > >> memory-bound anyway, so more than that leeway is not necessary. > >> > >> [...] > >>> + <add-on> > >>> + <add_on_products config:type="list"> > >>> + <listentry> > >>> + <media_url>http://download.opensuse.org/distribution/leap/15.1/repo/oss/</media_url> > >>> + <name>repo-oss</name> > >>> + </listentry> > >>> + <listentry> > >>> + <media_url>http://download.opensuse.org/update/leap/15.1/oss</media_url> > >>> + <name>repo-update</name> > >>> + </listentry> > >>> + <listentry> > >>> + <media_url>http://download.opensuse.org/distribution/leap/15.1/repo/non-oss/</media_url> > >>> + <name>repo-non-oss</name> > >>> + </listentry> > >>> + <listentry> > >>> + <media_url>http://download.opensuse.org/update/leap/15.1/non-oss/</media_url> > >>> + <name>repo-update-non-oss</name> > >>> + </listentry> > >> > >> Do we actually need the non-OSS repositories to be updated? I would > >> hope not! But I'm not familiar with how openSUSE organizes its > >> repositories, so I'm going by name only :) > >> > >> [...] > >>> + <firewall> > >>> + <enable_firewall>true</enable_firewall> > >>> + </firewall> > >> > >> As you mention somewhere else, we probably don't need this. > >> > >> [...] > >>> +++ b/guests/host_vars/libvirt-opensuse-15.1/main.yml > >>> +package_format: 'rpm' > >>> +package_manager: 'zypper' > >>> +os_name: 'openSUSE' > >>> +os_version: '15.1' > >> > >> So, about the naming. > >> > >> What I would have done here is > >> > >> os_name: 'OpenSUSE' > >> os_version: '15' > >> > >> The intial capital letter in os_name goes against the actual branding > >> for openSUSE so I'm not perfectly happy with it, but on the other > >> hand it's very useful when defining mappings because package formats > >> all start with a lowercase letter and all OS names start with an > >> uppercase letter. So I would try to stick with that convention. > >> > >> As for os_version, if you look at all existing entries we use the > >> major version number only: eg. we have CentOS7 instead of CentOS7.7 > >> and FreeBSD12 instead of FreeBSD12.1: this makes sense because, as > >> the guest gets updated over time, it will naturally pick up the > >> latest minor release. Will this work for openSUSE too? > >> > >> (Ubuntu is a slight exception in that the major version itself > >> contains a dot, so we just shortened 18.04 to 18 because we know > >> that there's never going to be two LTS releases per year.) > >> > >>> +++ b/guests/host_vars/libvirt-opensuse-15.1/docker.yml > >>> @@ -0,0 +1,2 @@ > >>> +--- > >>> +docker_base: openSUSE:15.1 > >> > >> I believe these images are now deprecated, and opensuse/leap > >> should be used instead. > >> > >> Looking at > >> > >> https://hub.docker.com/r/opensuse/leap/tags > >> > >> I see that the '15.1', '15' and 'latest' tags point to the same set > >> of digests, so that seems to confirm that we can use just 15 as the > >> version number and have > >> > >> docker_base: opensuse/leap:15 > >> > >> in this file. > >> > >> [...] > >>> +++ b/guests/inventory > >>> @@ -8,5 +8,6 @@ libvirt-fedora-rawhide > >>> libvirt-freebsd-11 > >>> libvirt-freebsd-12 > >>> libvirt-freebsd-current > >>> +libvirt-opensuse-15.1 > >> > >> Based on the points above, I think this could and should be > >> > >> libvirt-opensuse-15 > >> > >> [...] > >>> @@ -127,6 +129,7 @@ mappings: > >>> dbus-daemon: > >>> default: dbus > >>> Fedora: dbus-daemon > >>> + openSUSE: dbus-1 > >> > >> You see how weird this looks, due to the first letter being > >> lower case? :) > >> > >> I'm not going to review the mappings in detail right now because I > >> simply lack the time. Once 'lcitool update' works for you without > >> errors, I'll look into it. > >> > >> > >> Fabiano already pointed out where you need to look to sort out the > >> issues you've been experiencing, so I'll leave you to it now :) > > > > Apart from what I pointed out, I've also faced a few issues when > > trying out your patch: > > - grub stays in a loop, forever; > > - I've worked this around by not setting "--graphics none --console > > pty" and removing "console=ttyS0" from the extra_arg line; > > - It really has to be solved in a better way ;-) > > I've wasted way too much time trying to debug this problem. It definitely seems > like an issue in our grub 2.02 package. I've reached out to the maintainer for help. Aha! Yes, that's possible. I've tried to tweak the <append/> part of the general config in the autoyast, but also didn't make it work. :-/ > > > - Update installed packages: > > - I've added: > > ``` > > +- name: Update installed packages > > + command: '{{ package_manager }} update -y' > > + args: > > + warn: no > > + when: > > + - os_name == 'openSUSE' > > ``` > > > > - Clean up packages after update: > > - I've added: > > ``` > > - name: Clean up packages after update > > shell: '{{ package_manager }} clean packages -y && {{ > > package_manager }} autoremove -y' > > args: > > warn: no > > when: > > - package_format == 'rpm' > > + - not os_name == "openSUSE" > > + > > +- name: Clean up packages after update > > + shell: '{{ package_manager }} clean -y' > > + args: > > + warn: no > > + when: > > + - os_name = "openSUSE" > > + > > ``` > > > > - Missing mappings: > > - qemu-img: > > - Seems that the package doesn't exist in openSUSE. So, please, > > just do something like: > > It is included in the qemu-tools package. > > > ``` > > qemu-img: > > default: qemu-utils > > rpm: qemu-img > > + openSUSE: > > So this should be > > OpenSUSE: qemu-tools > > (using the uppercase 'O' as Andreas suggested :-)) ? Yes! > > > ``` > > - zfs: > > - Same as above > > - yajl: > > - It seems to be called libyajl-devel for openSUSE > > > > - Look for files > > - There's a "Look for files" rule (in > > guests/playbooks/update/tasks/paths.yml) which will just bail out as > > /usr/local/etc doesn't exist in openSUSE. It has to be tweaked as > > well; > > > > - Configure ccache: > > - This is a rule in guests/playbooks/update/tasks/users.yml, which > > takes into consideration that when the test user is created, we'll > > have a test group created as well, which doesn't happen on openSUSE. > > So, it also need some tweak; > > > > I didn't write a patch for those, sorry, but I hope it gives you some > > idea on the problems I faced (and that you'll face) and how to solve > > then. > > > > Once those are solved/worked around, you'll be able to run the > > "update" command and then, finally, you'll be able to expand > > guests/playbooks/build/projects/ in order to add openSUSE there and > > check whether we can successfully build the projects using openSUSE. > > Thanks for all this info! I'll work on incorporating your comments as I have > some time slices. It may take a few days. No problem. Feel free to reach me out either here or on IRC in case you need some help / pair debugging / rubber duck session! :-) > > > Here I'm assuming your main goal is libvirt. Once that's done, I can > > do the work for libosinfo, osinfo-db-tools, and osinfo-db. > > I assumed libvirt would be the harder one since it has a lot of build > dependencies, so I started with it first. I'm guessing the other projects will > be easy once the libvirt one is working. For sure libvirt is the harder one. The other should be fairly easy to add, indeed. I just don't see a reason for you to spend time adding packages that you don't work directly with (although, I will *not* complain if you do so ;-)). Best Regards, -- Fabiano Fidêncio -- libvir-list mailing list libvir-list@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/libvir-list