Skip to content

Commit

Permalink
Add function to check if nodes are reachable via bolt
Browse files Browse the repository at this point in the history
At the moment the plans assume that all nodes are available. I had a few
customer setups where one of the compilers wasn't reachable during a
convert/upgrade. To not put the PE infra into an undefined state, it
makes sense to check the availability before running the plans.
  • Loading branch information
bastelfreak committed Apr 25, 2024
1 parent a99cb66 commit 45e9f27
Show file tree
Hide file tree
Showing 6 changed files with 67 additions and 0 deletions.
25 changes: 25 additions & 0 deletions REFERENCE.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
* [`peadm::assert_supported_pe_version`](#peadm--assert_supported_pe_version): Assert that the PE version given is supported by PEAdm
* [`peadm::bolt_version`](#peadm--bolt_version)
* [`peadm::certname`](#peadm--certname): Return the certname of the given target-like input
* [`peadm::check_availability`](#peadm--check_availability): check if a group of targets are reachable for bolt
* [`peadm::check_version_and_known_hosts`](#peadm--check_version_and_known_hosts): Checks PE verison and warns about setting r10k_known_hosts
* [`peadm::convert_hash`](#peadm--convert_hash): converts two arrays into hash
* [`peadm::convert_status`](#peadm--convert_status): Transforms a value in a human readable status with or without colors
Expand Down Expand Up @@ -266,6 +267,30 @@ Variant[Target,



### <a name="peadm--check_availability"></a>`peadm::check_availability`

Type: Puppet Language

check if a group of targets are reachable for bolt

#### `peadm::check_availability(TargetSpec $targets, Boolean $output_details = true)`

The peadm::check_availability function.

Returns: `Integer` counter for unavailable nodes

##### `targets`

Data type: `TargetSpec`

list of targets that are going to be checked

##### `output_details`

Data type: `Boolean`

flag to enable/disable error output for failed nodes

### <a name="peadm--check_version_and_known_hosts"></a>`peadm::check_version_and_known_hosts`

Type: Puppet Language
Expand Down
30 changes: 30 additions & 0 deletions functions/check_availability.pp
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
#
# @summary check if a group of targets are reachable for bolt
#
# @param targets list of targets that are going to be checked
# @param output_details flag to enable/disable error output for failed nodes
#
# @return counter for unavailable nodes
#
# @author Tim Meusel <[email protected]>
#
function peadm::check_availability(
TargetSpec $targets,
Boolean $output_details = true
) >> Integer {
$check_result = wait_until_available($targets, wait_time => 2, _catch_errors => true)
if $check_result.ok {
} else {
$messages = $check_result.error_set.map |$result| {
"## node ${result.target} has connection error '${result.error.kind}' with message '${result.error.msg}'"
}
$end_message = "${check_result.error_set.count} targets are not reachable, stopping plan"
$fail_message = $output_details ? {
true => "${messages.join("\n")}\n${end_message}",
false => $end_message,
}
fail_plan($fail_message)
}

return $check_result.error_set.count
}
1 change: 1 addition & 0 deletions plans/convert.pp
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@
)

out::message('# Gathering information')
peadm::check_availability($all_targets)

# Get trusted fact information for all compilers. Use peadm::certname() as
# the hash key because the apply block below will break trying to parse the
Expand Down
9 changes: 9 additions & 0 deletions plans/install.pp
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,15 @@
) {
peadm::assert_supported_bolt_version()

out::message('# Gathering information')
$all_targets = peadm::flatten_compact([
$primary_host,
$replica_host,
$replica_postgresql_host,
$compiler_hosts,
$primary_postgresql_host,
])
peadm::check_availability($all_targets)
peadm::assert_supported_pe_version($version, $permit_unsafe_versions)

$install_result = run_plan('peadm::subplans::install',
Expand Down
1 change: 1 addition & 0 deletions plans/upgrade.pp
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@
])

out::message('# Gathering information')
peadm::check_availability($all_targets)

# lint:ignore:strict_indent
$primary_target.peadm::fail_on_transport('pcp', @(HEREDOC/n))
Expand Down
1 change: 1 addition & 0 deletions spec/plans/install_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

describe 'basic functionality' do
it 'runs successfully with the minimum required parameters' do
allow_out_message
expect_plan('peadm::subplans::install')
expect_plan('peadm::subplans::configure')
expect(run_plan('peadm::install', 'primary_host' => 'primary', 'console_password' => 'puppetlabs', 'version' => '2021.7.7')).to be_ok
Expand Down

0 comments on commit 45e9f27

Please sign in to comment.