-
Notifications
You must be signed in to change notification settings - Fork 258
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add "Testing a foreman-installer patch with Packit and forklift" post #2110
Merged
Merged
Changes from all commits
Commits
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
111 changes: 111 additions & 0 deletions
111
_posts/2023-11-03-testing-a-foreman-installer-patch-with-packit-and-forklift.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,111 @@ | ||
--- | ||
layout: post | ||
title: Testing a foreman-installer patch with Packit and forklift | ||
date: 2023-11-03 11:41:32 | ||
author: Evgeni Golov | ||
tags: | ||
- foreman | ||
- packit | ||
--- | ||
|
||
Today I was working on a potential fix for the issue that [Puppetserver doesn't start when deployed with fapolicyd in enforcing mode](https://github.com/theforeman/foreman-fapolicyd/issues/7). | ||
|
||
I knew that the potential fix is to set `PrivateTmp=true` in the systemd unit, so the [patch](https://github.com/theforeman/puppet-puppet/pull/892) was quickly written, but how would one verify it end to end? | ||
|
||
<!--more--> | ||
|
||
In Foreman, our releases (and nightlies!) are tested using [forklift](https://github.com/theforeman/foreman), a combination of [Vagrant](https://www.vagrantup.com/) for managing VMs and [Ansible](https://www.ansible.com/) for deploying Foreman in them and running [bats](https://github.com/bats-core/bats-core). | ||
|
||
We can run the installation pipeline for Foreman nightly on CentOS Stream 8 like this: | ||
|
||
```console | ||
% ansible-playbook pipelines/install_pipeline.yml -e pipeline_os=centos8-stream -e pipeline_version=nightly -e pipeline_type=foreman | ||
… | ||
TASK [bats : Run bats] ************************************************************************************************************* | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=fb-verify-packages.bats) | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=fb-test-foreman.bats) | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=fb-test-puppet.bats) | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=fb-test-backup.bats) | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=fb-verify-selinux.bats) | ||
… | ||
PLAY RECAP ************************************************************************************************************************* | ||
localhost : ok=5 changed=2 unreachable=0 failed=0 skipped=5 rescued=0 ignored=0 | ||
pipe-foreman-server-nightly-centos8-stream : ok=62 changed=19 unreachable=0 failed=0 skipped=37 rescued=0 ignored=1 | ||
pipe-foreman-smoker-nightly-centos8-stream : ok=17 changed=12 unreachable=0 failed=0 skipped=3 rescued=0 ignored=0 | ||
``` | ||
|
||
As we see, the tests pass and everyone is happy. | ||
|
||
We can destroy the setup again, and continue with our tasks: | ||
|
||
```console | ||
% ansible-playbook pipelines/install_pipeline.yml -e pipeline_os=centos8-stream -e pipeline_version=nightly -e pipeline_type=foreman -e forklift_state=destroy | ||
``` | ||
|
||
The tests passed because we do not deploy fapolicyd by default as the integration is not yet fully ready. | ||
|
||
To test the integration, there is a feature flag: [`foreman_fapolicyd`](https://github.com/theforeman/forklift/pull/1724) and if we enable it, the overall installation fails as expected: | ||
|
||
```console | ||
% ansible-playbook pipelines/install_pipeline.yml -e pipeline_os=centos8-stream -e pipeline_version=nightly -e pipeline_type=foreman -e foreman_fapolicyd=true | ||
… | ||
TASK [foreman_installer : Run installer] ******************************************************************************************* | ||
fatal: [pipe-foreman-server-nightly-centos8-stream]: FAILED! => changed=true | ||
… | ||
Error 1: Puppet Service resource 'puppetserver' failed. Logs: | ||
/Service[puppetserver] | ||
Starting to evaluate the resource (993 of 1266) | ||
Skipping restart; service is not running | ||
Triggered 'refresh' from 2 events | ||
The container Class[Puppet::Server::Service] will propagate my refresh event | ||
Evaluated in 9.75 seconds | ||
/Stage[main]/Puppet::Server::Service/Service[puppetserver]/ensure | ||
change from 'stopped' to 'running' failed: Systemd start for puppetserver failed! | ||
journalctl log for puppetserver: | ||
-- Logs begin at Fri 2023-11-03 08:53:57 UTC, end at Fri 2023-11-03 09:01:28 UTC. -- | ||
Nov 03 09:01:19 pipe-foreman-server-nightly-centos8-stream.tanso.example.com systemd[1]: Starting puppetserver Service... | ||
Nov 03 09:01:22 pipe-foreman-server-nightly-centos8-stream.tanso.example.com puppetserver[48125]: WARNING: abs already refers to: #'clojure.core/abs in namespace: medley.core, being replaced by: #'medley.core/abs | ||
Nov 03 09:01:28 pipe-foreman-server-nightly-centos8-stream.tanso.example.com puppetserver[48125]: Execution error (ClassNotFoundException) at java.net.URLClassLoader/findClass (URLClassLoader.java:387). | ||
Nov 03 09:01:28 pipe-foreman-server-nightly-centos8-stream.tanso.example.com puppetserver[48125]: org.jruby.ext.psych.PsychLibrary | ||
Nov 03 09:01:28 pipe-foreman-server-nightly-centos8-stream.tanso.example.com puppetserver[48125]: Full report at: | ||
Nov 03 09:01:28 pipe-foreman-server-nightly-centos8-stream.tanso.example.com puppetserver[48125]: /tmp/clojure-5697285534509071746.edn | ||
Nov 03 09:01:28 pipe-foreman-server-nightly-centos8-stream.tanso.example.com puppetserver[48098]: Background process 48125 exited before start had completed | ||
Nov 03 09:01:28 pipe-foreman-server-nightly-centos8-stream.tanso.example.com systemd[1]: puppetserver.service: Control process exited, code=exited status=1 | ||
Nov 03 09:01:28 pipe-foreman-server-nightly-centos8-stream.tanso.example.com systemd[1]: puppetserver.service: Failed with result 'exit-code'. | ||
Nov 03 09:01:28 pipe-foreman-server-nightly-centos8-stream.tanso.example.com systemd[1]: Failed to start puppetserver Service. | ||
|
||
1 error was detected during installation. | ||
Please address the errors and re-run the installer to ensure the system is properly configured. | ||
Failing to do so is likely to result in broken functionality. | ||
|
||
The full log is at /var/log/foreman-installer/foreman.log | ||
stdout_lines: <omitted> | ||
|
||
PLAY RECAP ************************************************************************************************************************* | ||
localhost : ok=5 changed=2 unreachable=0 failed=0 skipped=5 rescued=0 ignored=0 | ||
pipe-foreman-server-nightly-centos8-stream : ok=47 changed=12 unreachable=0 failed=1 skipped=28 rescued=0 ignored=1 | ||
``` | ||
|
||
Now that we know that we can reproduce the reported issue, let's try to deploy the fix and see if it *actually* fixes things. | ||
|
||
The [patch](https://github.com/theforeman/puppet-puppet/pull/892) is against our Puppet module that is responsible for deploying the Puppetserver, but our installation procedure doesn't call Puppet directly, it uses `foreman-installer` which under the hood uses Puppet. So to test the fix we need to build `foreman-installer` with the patched module and deploy the result during the installation pipeline, before Ansible calls the installer. | ||
|
||
This sounds tedious and error prone, but luckily we have [Packit](https://packit.dev/) integration in our `foreman-installer` repository and in `forklift`. That means that we need to create a [PR](https://github.com/theforeman/foreman-installer/pull/897) against the installer repository, temporarily pointing at the patched Puppet module and once Packit has built the package can [instruct `forklift` to use that Packit repository during deployment](https://theforeman.github.io/forklift/development/#packit-pr-builds), validating the fix: | ||
|
||
|
||
```console | ||
% ansible-playbook pipelines/install_pipeline.yml -e pipeline_os=centos8-stream -e pipeline_version=nightly -e pipeline_type=foreman -e foreman_fapolicyd=true -e '{"packit_prs":["theforeman/foreman-installer/897"]}' | ||
… | ||
TASK [packit : setup packit copr] ************************************************************************************************** | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=theforeman/foreman-installer/897) | ||
… | ||
TASK [bats : Run bats] ************************************************************************************************************* | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=fb-verify-packages.bats) | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=fb-test-foreman.bats) | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=fb-test-puppet.bats) | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=fb-test-backup.bats) | ||
changed: [pipe-foreman-server-nightly-centos8-stream] => (item=fb-verify-selinux.bats) | ||
… | ||
``` | ||
|
||
And this is the story of how I could validate the fix while drinking a coffee instead of thinking how to inject the manually built package at the right time into the automated installation test. |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Does this do anything?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
the part before more is published via RSS, the rest is not