From 43eae50399d583d4ebcb3139f76a85033b623318 Mon Sep 17 00:00:00 2001 From: d-w-moore Date: Mon, 30 Sep 2024 05:57:18 -0400 Subject: [PATCH] [_517] tests --- irods/test/scripts/test002.bats | 44 +++++++++++++++++++++++++++++++ irods/test/scripts/test003.bats | 46 +++++++++++++++++++++++++++++++++ 2 files changed, 90 insertions(+) create mode 100755 irods/test/scripts/test002.bats create mode 100755 irods/test/scripts/test003.bats diff --git a/irods/test/scripts/test002.bats b/irods/test/scripts/test002.bats new file mode 100755 index 00000000..273b91f2 --- /dev/null +++ b/irods/test/scripts/test002.bats @@ -0,0 +1,44 @@ +#!/usr/bin/env bats + +. "$BATS_TEST_DIRNAME"/funcs +PYTHON=python3 + +# Setup/prerequisites are same as for login_auth_test. +# Run as ubuntu user with sudo; python_irodsclient must be installed (in either ~/.local or a virtualenv) +# + +PASSWD=test123 +NEW_PAM_PASSWD="new_pass" + +setup() +{ + setup_pam_login_for_alice $PASSWD +} + +teardown() +{ + finalize_pam_login_for_alice + test_specific_cleanup +} + +@test create_secrets_file { + + sudo chpasswd <<<"alice:$NEW_PAM_PASSWD" + rm -f ~/.irods/.irodsA + $PYTHON -c "import irods.client_init; irods.client_init.write_pam_credentials_to_secrets_file('$NEW_PAM_PASSWD')" + + + # Define the core Python to be run, basically a minimal code block ensuring that we can authenticate to iRODS + # without an exception being raised. + + local SCRIPT=" +import irods.test.helpers as h +ses = h.make_session() +ses.collections.get(h.home_collection(ses)) +print ('env_auth_scheme=%s' % ses.pool.account._original_authentication_scheme) +" + OUTPUT=$($PYTHON -c "$SCRIPT") + # Assert passing value + [ $OUTPUT = env_auth_scheme=pam_password ] + +} diff --git a/irods/test/scripts/test003.bats b/irods/test/scripts/test003.bats new file mode 100755 index 00000000..9e031f5f --- /dev/null +++ b/irods/test/scripts/test003.bats @@ -0,0 +1,46 @@ +#!/usr/bin/env bats + +. "$BATS_TEST_DIRNAME"/funcs +PYTHON=python3 + +# Setup/prerequisites are same as for login_auth_test. +# Run as ubuntu user with sudo; python_irodsclient must be installed (in either ~/.local or a virtualenv) +# + +setup() +{ + : +} + +teardown() +{ + : +} + +@test create_irods_secrets_file { + + rm -fr ~/.irods + mkdir ~/.irods + cat > ~/.irods/irods_environment.json <<-EOF + { "irods_host":"$(hostname)", + "irods_port":1247, + "irods_user_name":"rods", + "irods_zone_name":"tempZone" + } + EOF + $PYTHON -c "import irods.client_init; irods.client_init.write_native_credentials_to_secrets_file('rods')" + + + # Define the core Python to be run, basically a minimal code block ensuring that we can authenticate to iRODS + # without an exception being raised. + + local SCRIPT=" +import irods.test.helpers as h +ses = h.make_session() +ses.collections.get(h.home_collection(ses)) +print ('env_auth_scheme=%s' % ses.pool.account._original_authentication_scheme) +" + OUTPUT=$($PYTHON -c "$SCRIPT") + # Assert passing value + [ $OUTPUT = env_auth_scheme=native ] +}