From 91396dff40932289b77eade0ac06b5b401947437 Mon Sep 17 00:00:00 2001 From: Diego Tapia <64498901+dtapia-IT@users.noreply.github.com> Date: Mon, 13 May 2024 11:14:46 -0400 Subject: [PATCH] (node/lsstcam-rebps.cp.lsst.org) add network config (spec) add tests --- hieradata/node/lsstcam-rebps.cp.lsst.org.yaml | 32 +++++++++++ .../nodes/lsstcam-rebps.cp.lsst.org_spec.rb | 55 +++++++++++++++++++ 2 files changed, 87 insertions(+) create mode 100644 hieradata/node/lsstcam-rebps.cp.lsst.org.yaml create mode 100644 spec/hosts/nodes/lsstcam-rebps.cp.lsst.org_spec.rb diff --git a/hieradata/node/lsstcam-rebps.cp.lsst.org.yaml b/hieradata/node/lsstcam-rebps.cp.lsst.org.yaml new file mode 100644 index 0000000000..c28e9b3f73 --- /dev/null +++ b/hieradata/node/lsstcam-rebps.cp.lsst.org.yaml @@ -0,0 +1,32 @@ +--- +nm::connections: + enp0s31f6: + content: + connection: + id: "enp0s31f6" + uuid: "03da7500-2101-c722-2438-d0d006c28c73" + type: "ethernet" + interface-name: "enp0s31f6" + ethernet: {} + ipv4: + address1: "139.229.175.78/26,139.229.175.126" + dns: "139.229.160.53;139.229.160.54;139.229.160.55;" + dns-search: "cp.lsst.org;" + method: "manual" + ipv6: + method: "disabled" + proxy: {} + enp3s0: + content: + connection: + id: "enp3s0" + uuid: "edb4ebb1-6d05-427b-b6ea-d483bdf32ec7" + type: "ethernet" + interface-name: "enp3s0" + ethernet: {} + ipv4: + method: "manual" + address1: "192.168.1.121/24" + ipv6: + method: "disabled" + proxy: {} diff --git a/spec/hosts/nodes/lsstcam-rebps.cp.lsst.org_spec.rb b/spec/hosts/nodes/lsstcam-rebps.cp.lsst.org_spec.rb new file mode 100644 index 0000000000..046474ac6a --- /dev/null +++ b/spec/hosts/nodes/lsstcam-rebps.cp.lsst.org_spec.rb @@ -0,0 +1,55 @@ +# frozen_string_literal: true + +require 'spec_helper' + +describe 'lsstcam-rebps.cp.lsst.org', :sitepp do + on_supported_os.each do |os, os_facts| + next unless os =~ %r{almalinux-9-x86_64} + + context "on #{os}" do + let(:facts) do + override_facts(os_facts, + fqdn: 'lsstcam-rebps.cp.lsst.org', + is_virtual: false, + virtual: 'physical', + dmi: { + 'product' => { + 'name' => 'EPMe-42', + }, + }) + end + let(:node_params) do + { + role: 'ccs-hcu', + site: 'cp', + } + end + + it { is_expected.to compile.with_all_deps } + + include_examples 'baremetal no bmc' + include_context 'with nm interface' + it { is_expected.to have_nm__connection_resource_count(2) } + + context 'with enp0s31f6' do + let(:interface) { 'enp0s31f6' } + + it_behaves_like 'nm enabled interface' + it_behaves_like 'nm ethernet interface' + it_behaves_like 'nm manual interface' + it { expect(nm_keyfile['ipv4']['address1']).to eq('139.229.175.78/26,139.229.175.126') } + it { expect(nm_keyfile['ipv4']['dns']).to eq('139.229.160.53;139.229.160.54;139.229.160.55;') } + it { expect(nm_keyfile['ipv4']['dns-search']).to eq('cp.lsst.org;') } + end + + context 'with enp3s0' do + let(:interface) { 'enp3s0' } + + it_behaves_like 'nm enabled interface' + it_behaves_like 'nm ethernet interface' + it_behaves_like 'nm manual interface' + it { expect(nm_keyfile['ipv4']['address1']).to eq('192.168.1.121/24') } + end + end # on os + end # on_supported_os +end