cookbooks/aws-parallelcluster-slurm/spec/unit/recipes/install_pyxis_spec.rb (84 lines of code) (raw):

# frozen_string_literal: true # Copyright:: 2024 Amazon.com, Inc. and its affiliates. All Rights Reserved. # # Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with the # License. A copy of the License is located at # # http://aws.amazon.com/apache2.0/ # # or in the "LICENSE.txt" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES # OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions and # limitations under the License. require 'spec_helper' describe 'aws-parallelcluster-slurm::install_pyxis' do for_all_oses do |platform, version| context "on #{platform}#{version}" do cached(:cluster_artifacts_s3_url) { 'https://REGION-aws-parallelcluster.s3.REGION.AWS_DOMAIN' } cached(:cluster_sources_dir) { '/path/to/cluster/sources/dir' } cached(:cluster_examples_dir) { '/path/to/cluster/examples/dir' } cached(:slurm_install_dir) { '/path/to/slurm/install/dir' } cached(:pyxis_version) { '1.2.3' } cached(:pyxis_runtime_dir) { '/path/to/pyxis/runtime/dir' } cached(:chef_run) do runner = runner(platform: platform, version: version) do |node| RSpec::Mocks.configuration.allow_message_expectations_on_nil = true node.override['cluster']['artifacts_s3_url'] = cluster_artifacts_s3_url node.override['cluster']['sources_dir'] = cluster_sources_dir node.override['cluster']['examples_dir'] = cluster_examples_dir node.override['cluster']['slurm']['install_dir'] = slurm_install_dir node.override['cluster']['pyxis']['version'] = pyxis_version node.override['cluster']['pyxis']['runtime_path'] = pyxis_runtime_dir end allow_any_instance_of(Object).to receive(:nvidia_enabled?).and_return(true) allow_any_instance_of(Object).to receive(:pyxis_installed?).and_return(false) runner.converge(described_recipe) end it 'downloads Pyxis tarball' do is_expected.to create_if_missing_remote_file("#{cluster_sources_dir}/pyxis-#{pyxis_version}.tar.gz").with( source: "#{cluster_artifacts_s3_url}/dependencies/pyxis/v#{pyxis_version}.tar.gz", mode: '0644', retries: 3, retry_delay: 5 ) end it 'install Pyxis' do is_expected.to run_bash('Install pyxis').with( user: 'root', retries: 3, retry_delay: 5, code: <<-CODE set -e tar xf #{cluster_sources_dir}/pyxis-#{pyxis_version}.tar.gz -C /tmp cd /tmp/pyxis-#{pyxis_version} CPPFLAGS='-I #{slurm_install_dir}/include/' make CPPFLAGS='-I #{slurm_install_dir}/include/' make install CODE ) end it 'creates the Spank examples directory' do is_expected.to create_directory("#{cluster_examples_dir}/spank") end it 'creates the Spank example configuration' do is_expected.to create_template("#{cluster_examples_dir}/spank/plugstack.conf").with( source: 'pyxis/plugstack.conf.erb', owner: 'root', group: 'root', mode: '0644' ) end it 'creates the Pyxis examples directory' do is_expected.to create_directory("#{cluster_examples_dir}/pyxis") end it 'creates the Pyxis example configuration' do is_expected.to create_template("#{cluster_examples_dir}/pyxis/pyxis.conf").with( source: 'pyxis/pyxis.conf.erb', owner: 'root', group: 'root', mode: '0644' ) end context "when Pyxis is already installed" do cached(:chef_run) do runner = runner(platform: platform, version: version) do |_node| RSpec::Mocks.configuration.allow_message_expectations_on_nil = true end allow_any_instance_of(Object).to receive(:nvidia_enabled?).and_return(true) allow_any_instance_of(Object).to receive(:pyxis_installed?).and_return(true) runner.converge(described_recipe) end it 'does not install Pyxis' do is_expected.not_to run_bash('Install pyxis') end end end end end