Skip to content

Commit

Permalink
Address code review comments
Browse files Browse the repository at this point in the history
Simplify unit test for generation of Slurm accounting configuration files.

Remove commented parameters in slurm kitchen test configuration file.

Modify copyright year in one file.

Signed-off-by: Jacopo De Amicis <[email protected]>
  • Loading branch information
jdeamicis committed Sep 27, 2023
1 parent 255a986 commit aa61edb
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 18 deletions.
3 changes: 0 additions & 3 deletions cookbooks/aws-parallelcluster-slurm/kitchen.slurm-config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -207,9 +207,6 @@ suites:
cluster:
node_type: HeadNode
scheduler: 'slurm'
#slurm:
# user: 'slurm'
# group: 'slurm'
config:
Scheduling:
SlurmSettings:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
# Cookbook:: aws-parallelcluster-slurm
# Recipe:: install_slurm
#
# Copyright:: 2013-2021 Amazon.com, Inc. or its affiliates. All Rights Reserved.
# Copyright:: 2013-2023 Amazon.com, Inc. or 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
Expand Down
49 changes: 35 additions & 14 deletions test/unit/slurm/test_slurm_config_generator.py
Original file line number Diff line number Diff line change
Expand Up @@ -102,17 +102,36 @@ def test_generate_slurm_config_files_memory_scheduling(


@pytest.mark.parametrize(
"slurm_accounting, dbname_passed",
[(False, False), (True, False), (True, True)],
"input_config, expected_outputs",
[
pytest.param(
"sample_input.yaml",
[
"slurm_parallelcluster.conf",
"slurm_parallelcluster_slurmdbd.conf",
],
id="Case without Slurm Accounting",
),
pytest.param(
"sample_input_slurm_accounting.yaml",
[
"slurm_parallelcluster_slurm_accounting.conf",
"slurm_parallelcluster_slurmdbd_slurm_accounting.conf",
],
id="Case with Slurm Accounting",
),
pytest.param(
"sample_input_slurm_accounting_dbname.yaml",
[
"slurm_parallelcluster_slurm_accounting_dbname.conf",
"slurm_parallelcluster_slurmdbd_slurm_accounting_dbname.conf",
],
id="Case with Slurm Accounting passing DatabaseName",
),
],
)
def test_generate_slurm_config_files_slurm_accounting(mocker, test_datadir, tmpdir, slurm_accounting, dbname_passed):
input_base_name = "sample_input"
postfix = ""
if slurm_accounting:
postfix += "_slurm_accounting"
if dbname_passed:
postfix += "_dbname"
input_file = str(test_datadir / (input_base_name + postfix + ".yaml"))
def test_generate_slurm_config_files_slurm_accounting(mocker, test_datadir, tmpdir, input_config, expected_outputs):
input_file = str(test_datadir / input_config)
instance_types_data = str(test_datadir / "sample_instance_types_data.json")

_mock_head_node_config(mocker)
Expand All @@ -130,10 +149,12 @@ def test_generate_slurm_config_files_slurm_accounting(mocker, test_datadir, tmpd
cluster_name="test-cluster",
)

for file_type in ["", "_slurmdbd"]:
file_name = f"slurm_parallelcluster{file_type}.conf"
output_file_name = f"slurm_parallelcluster{file_type}{postfix}.conf"
_assert_files_are_equal(tmpdir / file_name, test_datadir / "expected_outputs" / output_file_name)
generated_outputs = ["slurm_parallelcluster.conf", "slurm_parallelcluster_slurmdbd.conf"]

for item in zip(generated_outputs, expected_outputs):
generated_file = str(tmpdir / item[0])
expected_file = str(test_datadir / "expected_outputs" / item[1])
_assert_files_are_equal(generated_file, expected_file)


def test_generating_slurm_config_flexible_instance_types(mocker, test_datadir, tmpdir):
Expand Down

0 comments on commit aa61edb

Please sign in to comment.