Skip to content

Commit

Permalink
ci: Handle reboot for transactional update systems
Browse files Browse the repository at this point in the history
  • Loading branch information
HVSharma12 authored and spetrosi committed Aug 8, 2024
1 parent 9502951 commit 751d1ca
Show file tree
Hide file tree
Showing 5 changed files with 52 additions and 1 deletion.
8 changes: 8 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,14 @@ timesync_ntp_provider: chrony
timesync_chrony_custom_settings:
- "logdir /var/log/chrony"
- "log measurements statistics tracking"

#This variable is used to handle reboots required by transactional updates.
#If a transactional update requires a reboot, the role will proceed with the
#reboot if `timesync_transactional_update_reboot_ok` is set to `true`. If set
#to `false`, the role will notify the user that a reboot is required, allowing
#for custom handling of the reboot requirement. If this variable is not set,
#the role will fail to ensure the reboot requirement is not overlooked.
timesync_transactional_update_reboot_ok: true
```
## Example Playbooks
Expand Down
1 change: 1 addition & 0 deletions defaults/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,3 +7,4 @@ timesync_min_sources: 1
timesync_ntp_hwts_interfaces: []
timesync_ntp_provider: ""
timesync_max_distance: 0
timesync_transactional_update_reboot_ok: null
28 changes: 28 additions & 0 deletions tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@
when:
- timesync_mode != 2
- timesync_ntp_provider == 'chrony'
register: timesync_chrony_result

- name: Install ntp
package:
Expand All @@ -77,6 +78,7 @@
when:
- timesync_mode != 2
- timesync_ntp_provider == 'ntp'
register: timesync_ntp_result

- name: Install linuxptp
package:
Expand All @@ -85,6 +87,32 @@
use: "{{ (__timesync_is_ostree | d(false)) |
ternary('ansible.posix.rhel_rpm_ostree', omit) }}"
when: timesync_mode != 1
register: timesync_linuxptp_result

- name: Handle reboot for transactional update systems
when:
- __timesync_is_transactional | d(false)
- timesync_chrony_result is changed or
timesync_ntp_result is changed or
timesync_linuxptp_result is changed
block:
- name: Notify user that reboot is needed to apply changes
debug:
msg: >
Reboot required to apply changes due to transactional updates.
- name: Reboot transactional update systems
reboot:
msg: Rebooting the system to apply transactional update changes.
when: timesync_transactional_update_reboot_ok | bool

- name: Fail if reboot is needed and not set
fail:
msg: >
Reboot is required but not allowed. Please set
'timesync_transactional_update_reboot_ok' to proceed.
when:
- timesync_transactional_update_reboot_ok is none

- name: Gather package facts
package_facts:
Expand Down
12 changes: 12 additions & 0 deletions tasks/set_vars.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,18 @@
set_fact:
__timesync_is_ostree: "{{ __ostree_booted_stat.stat.exists }}"

- name: Determine if system is transactional update and set flag
when: not __timesync_is_transactional is defined
block:
- name: Check if transactional-update exists in /sbin
stat:
path: /sbin/transactional-update
register: __transactional_update_stat

- name: Set flag if transactional-update exists
set_fact:
__timesync_is_transactional: "{{ __transactional_update_stat.stat.exists }}"

- name: Set platform/version specific variables
include_vars: "{{ lookup('first_found', ffparams) }}"
vars:
Expand Down
4 changes: 3 additions & 1 deletion vars/ALP-Dolomite.yml → vars/SL-Micro.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ timesync_ntp_provider_os_default: chrony
timesync_chrony_dhcp_sourcedir: /run/chrony-dhcp
timesync_chrony_sysconfig_path: /etc/sysconfig/chronyd
timesync_chrony_conf_path: "/etc/chrony.conf"
timesync_ntp_sysconfig_path: /etc/sysconfig/ntp
timesync_ntp_sysconfig_path: /etc/sysconfig/ntpd
timesync_ptp4l_sysconfig_path: /etc/sysconfig/ptp4l
timesync_phc2sys_sysconfig_path: /etc/sysconfig/phc2sys
# wokeignore:rule=master
timesync_timemaster_config_path: /etc/timemaster.conf

0 comments on commit 751d1ca

Please sign in to comment.