From 0fa66c332ae2a3ba5efd7ddad6191ea672f1d320 Mon Sep 17 00:00:00 2001 From: James Adams Date: Fri, 18 Aug 2023 12:26:10 +0100 Subject: [PATCH] ncm-nfs: Allow daemon to reload to be specified The name of the service/daemon is OS dependent, default to the more modern name. For example in EL6 it was `nfs`, in EL7 `nfs` was a symlink to `nfs-server`, in EL8 only `nfs-server` exists and in Ubuntu it is `nfs-kernel-server`. --- ncm-nfs/src/main/pan/components/nfs/schema.pan | 2 ++ ncm-nfs/src/main/perl/nfs.pm | 4 ++-- ncm-nfs/src/test/perl/configure.t | 16 ++++++++++++---- ncm-nfs/src/test/resources/configure_daemon.pan | 5 +++++ 4 files changed, 21 insertions(+), 6 deletions(-) create mode 100644 ncm-nfs/src/test/resources/configure_daemon.pan diff --git a/ncm-nfs/src/main/pan/components/nfs/schema.pan b/ncm-nfs/src/main/pan/components/nfs/schema.pan index 99eda4cb32..1dc5cdbd8e 100755 --- a/ncm-nfs/src/main/pan/components/nfs/schema.pan +++ b/ncm-nfs/src/main/pan/components/nfs/schema.pan @@ -29,6 +29,8 @@ type ${project.artifactId}_component = { If true, missing exports forces an empty exports file and a NFS service reload. If false, missing exports has no effect.} 'server' : boolean = true + @{ Daemon to reload when changes are made } + 'daemon' : string_trimmed = 'nfs-server' @{This is a list of dicts with "path" giving the export path and "hosts" being a dict of host/option entries where the key is the escaped host name and the value the export options(e.g. for "nfsclient.example.org(rw)", diff --git a/ncm-nfs/src/main/perl/nfs.pm b/ncm-nfs/src/main/perl/nfs.pm index 439a504e59..10c58339e1 100755 --- a/ncm-nfs/src/main/perl/nfs.pm +++ b/ncm-nfs/src/main/perl/nfs.pm @@ -477,9 +477,9 @@ sub Configure if (! exists($tree->{server}) || $tree->{server}) { if ($self->exports($tree)) { # Force a reload of the nfs daemon. - $self->info("Forcing nfs reload"); + $self->info("Forcing ", $tree->{daemon}, " reload"); # report error on failure - CAF::Service->new(["nfs"], log => $self)->reload(); + CAF::Service->new([$tree->{daemon}], log => $self)->reload(); }; } else { $self->verbose("Not a NFS server configuration"); diff --git a/ncm-nfs/src/test/perl/configure.t b/ncm-nfs/src/test/perl/configure.t index ca9c7adbcb..f6ad7c29b2 100644 --- a/ncm-nfs/src/test/perl/configure.t +++ b/ncm-nfs/src/test/perl/configure.t @@ -2,7 +2,7 @@ use strict; use warnings; use Test::More; -use Test::Quattor qw(configure configure_noserver configure_nomounts); +use Test::Quattor qw(configure configure_noserver configure_nomounts configure_daemon); use Test::MockModule; use Test::Quattor::RegexpTest; @@ -42,14 +42,14 @@ foreach my $change (qw(exports)){ command_history_reset(); $res = {$change => 1}; is($cmp->Configure($cfg), 1, "Configure returns 1 (change $change)"); - ok(command_history_ok([qr{service nfs reload}]), "nfs service reload when $change changed"); + ok(command_history_ok([qr{service nfs-server reload}]), "nfs service reload when $change changed"); }; foreach my $change (qw(fstab_changed action)){ command_history_reset(); $res = {$change => 1}; is($cmp->Configure($cfg), 1, "Configure returns 1 (change $change)"); - ok(command_history_ok(undef, [qr{service nfs reload}]), "no nfs service reload when $change changed"); + ok(command_history_ok(undef, [qr{service nfs-server reload}]), "no nfs service reload when $change changed"); }; # noserver config @@ -58,7 +58,7 @@ foreach my $change (qw(exports fstab_changed action)){ command_history_reset(); $res = {$change => 1}; is($cmp->Configure($nosrvcfg), 1, "Configure returns 1 (change $change) with server=false"); - ok(command_history_ok(undef, [qr{service nfs reload}]), "no nfs service reload when $change changed with server=false"); + ok(command_history_ok(undef, [qr{service nfs-server reload}]), "no nfs service reload when $change changed with server=false"); }; # noserver config @@ -68,5 +68,13 @@ $process_mounts_arg = undef; is($cmp->Configure($nomounts), 1, "Configure returns 1 without mounts"); ok(!defined($process_mounts_arg), "no nfs process_mounts without mounts"); +# configure with alternative daemon set +my $cfgdaemon = get_config_for_profile('configure_daemon'); +foreach my $change (qw(exports)){ + command_history_reset(); + $res = {$change => 1}; + is($cmp->Configure($cfgdaemon), 1, "Configure returns 1 (change $change)"); + ok(command_history_ok([qr{service nfs-kernel-server reload}]), "nfs-server service reload when $change changed"); +}; done_testing(); diff --git a/ncm-nfs/src/test/resources/configure_daemon.pan b/ncm-nfs/src/test/resources/configure_daemon.pan new file mode 100644 index 0000000000..67f3410188 --- /dev/null +++ b/ncm-nfs/src/test/resources/configure_daemon.pan @@ -0,0 +1,5 @@ +object template configure_daemon; + +include 'fstab_simple'; + +"/software/components/nfs/daemon" = 'nfs-kernel-server';