Skip to content

Commit

Permalink
[installer] Add a unit test for read_conf_file function
Browse files Browse the repository at this point in the history
* To run this test, `cd` into the tests directory and `./test_read_conf.sh`

  If pass, it will return 0 and show "PASS".
  If fail, it will return 1 and show "[ERR] Expect value(x86_64) is not equal
  to input value()".
  • Loading branch information
kuanyu99 committed Feb 4, 2021
1 parent 72514f9 commit ec36f85
Show file tree
Hide file tree
Showing 3 changed files with 81 additions and 3 deletions.
7 changes: 4 additions & 3 deletions installer/x86_64/install.sh
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,14 @@ _trap_push true

read_conf_file() {
local conf_file=$1
while IFS='=' read -r var value
while IFS='=' read -r var value || [ -n "$var" ]
do
# remove newline character
var=$(echo $var | tr -d '\r\n')
value=$(echo $value | tr -d '\r\n')
# remove comment string
var=${var%#*}
value=${value%#*}
# trim the space
var="$(echo $var)"
# skip blank line
[ -z "$var" ] && continue
# remove double quote in the beginning
Expand Down
16 changes: 16 additions & 0 deletions installer/x86_64/tests/sample_machine.conf
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
# sample_machine.conf for onie
# A space in front of comment line
# One blank line below

onie_machine_rev=0
onie_arch=x86_64# some comment after declaration
# no value declaration
onie_config_version=
onie_build_date="2021-02-03T01:50+0800"
onie_partition_type=gpt
onie_disco_ntpsrv=192.168.0.1 192.168.0.2
onie_firmware=auto
# another blank line below

onie_skip_ethmgmt_macs=no
onie_grub_image_name=grubx64.efi
61 changes: 61 additions & 0 deletions installer/x86_64/tests/test_read_conf.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
#!/bin/sh
# This is a standalone test file to test read_conf_file function for
# some types of machine.conf file.
# The read_conf_file function is copy from the install.sh

MACHINE_CONF="sample_machine.conf"

read_conf_file() {
local conf_file=$1
while IFS='=' read -r var value || [ -n "$var" ]
do
# remove newline character
var=$(echo $var | tr -d '\r\n')
value=$(echo $value | tr -d '\r\n')
# remove comment string
var=${var%#*}
value=${value%#*}
# skip blank line
[ -z "$var" ] && continue
# remove double quote in the beginning
tmp_val=${value#\"}
# remove double quote in the end
value=${tmp_val%\"}
eval "$var=\"$value\""
done < "$conf_file"
}

TEST_CONF() {
input_value=$1
exp_value=$2
if [ "$input_value" != "$exp_value" ]; then
echo "[ERR] Expect value($exp_value) is not equal to input value($input_value)"
exit 1
fi
}

# define the expected variable value
exp_onie_machine_rev="0"
exp_onie_arch="x86_64"
exp_onie_build_date="2021-02-03T01:50+0800"
exp_onie_partition_type="gpt"
exp_onie_disco_ntpsrv="192.168.0.1 192.168.0.2"
exp_onie_firmware="auto"
exp_onie_skip_ethmgmt_macs="no"
exp_onie_grub_image_name="grubx64.efi"

# read the sample conf file
read_conf_file $MACHINE_CONF

# check each variable and its expected value
TEST_CONF "$onie_machine_rev" "$exp_onie_machine_rev"
TEST_CONF "$onie_arch" "$exp_onie_arch"
TEST_CONF "$onie_build_date" "$exp_onie_build_date"
TEST_CONF "$onie_partition_type" "$exp_onie_partition_type"
TEST_CONF "$onie_disco_ntpsrv" "$exp_onie_disco_ntpsrv"
TEST_CONF "$onie_firmware" "$exp_onie_firmware"
TEST_CONF "$onie_skip_ethmgmt_macs" "$exp_onie_skip_ethmgmt_macs"
TEST_CONF "$onie_grub_image_name" "$exp_onie_grub_image_name"

echo "PASS!!"
exit 0

0 comments on commit ec36f85

Please sign in to comment.