summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorNiranjan Mallapadi <mrniranjan@redhat.com>2015-02-24 10:38:31 +0530
committerNiranjan Mallapadi <mrniranjan@redhat.com>2015-02-24 10:39:02 +0530
commite5f4b484c518cc507bd314a2b654a049023a46ae (patch)
tree8f84c5a81264a10d9a5da745fe6366df46dbff68 /tests
parent57e90f62dd46ba26d855a19208ee426340184d3b (diff)
downloadpki-e5f4b484c518cc507bd314a2b654a049023a46ae.tar.gz
pki-e5f4b484c518cc507bd314a2b654a049023a46ae.tar.xz
pki-e5f4b484c518cc507bd314a2b654a049023a46ae.zip
Port TKS legacy tests to beaker
Diffstat (limited to 'tests')
-rwxr-xr-xtests/dogtag/Makefile8
-rwxr-xr-xtests/dogtag/acceptance/legacy/tks-tests/acls/tks-ad-acls.sh91
-rwxr-xr-xtests/dogtag/acceptance/legacy/tks-tests/internaldb/tks-ad-internaldb.sh140
-rwxr-xr-xtests/dogtag/acceptance/legacy/tks-tests/logs/tks-ad-logs.sh192
-rwxr-xr-xtests/dogtag/acceptance/legacy/tks-tests/usergroups/tks-ad-usergroups.sh769
-rwxr-xr-xtests/dogtag/runtest.sh24
6 files changed, 1222 insertions, 2 deletions
diff --git a/tests/dogtag/Makefile b/tests/dogtag/Makefile
index 73fa2213f..f13cd66c2 100755
--- a/tests/dogtag/Makefile
+++ b/tests/dogtag/Makefile
@@ -260,8 +260,8 @@ build: $(BUILT_FILES)
chmod a+x ./acceptance/legacy/ca-tests/cert-enrollment/ca-ag-certificates.sh
chmod a+x ./acceptance/legacy/ca-tests/ocsp/ca-ee-ocsp.sh
chmod a+x ./acceptance/legacy/ca-tests/renewal/renew_manual.sh
- chmod a+x ./acceptance/legacy/ca-tests/renewal/renew_DirAuthUserCert.sh
- chmod a+x ./acceptance/legacy/ca-tests/renewal/renew_caSSLClientCert.sh
+ chmod a+x ./acceptance/legacy/ca-tests/renewal/renew_DirAuthUserCert.sh
+ chmod a+x ./acceptance/legacy/ca-tests/renewal/renew_caSSLClientCert.sh
chmod a+x ./acceptance/legacy/drm-tests/acls/drm-ad-acls.sh
chmod a+x ./acceptance/legacy/drm-tests/agent/drm-ag-tests.sh
chmod a+x ./acceptance/legacy/drm-tests/internaldb/drm-ad-internaldb.sh
@@ -285,6 +285,10 @@ build: $(BUILT_FILES)
chmod a+x ./acceptance/legacy/ocsp-tests/acls/ocsp-ad-acls.sh
chmod a+x ./acceptance/legacy/ocsp-tests/logs/ocsp-ad-logs.sh
chmod a+x ./acceptance/legacy/ocsp-tests/internaldb/ocsp-ad-internaldb.sh
+ chmod a+x ./acceptance/legacy/tks-tests/acls/tks-ad-acls.sh
+ chmod a+x ./acceptance/legacy/tks-tests/internaldb/tks-ad-internaldb.sh
+ chmod a+x ./acceptance/legacy/tks-tests/logs/tks-ad-logs.sh
+ chmod a+x ./acceptance/legacy/tks-tests/usergroups/tks-ad-usergroups.sh
# bug verifications
chmod a+x ./acceptance/bugzilla/tomcatjss-bugs/bug-1058366.sh
chmod a+x ./acceptance/bugzilla/tomcatjss-bugs/bug-1084224.sh
diff --git a/tests/dogtag/acceptance/legacy/tks-tests/acls/tks-ad-acls.sh b/tests/dogtag/acceptance/legacy/tks-tests/acls/tks-ad-acls.sh
new file mode 100755
index 000000000..1d3307c37
--- /dev/null
+++ b/tests/dogtag/acceptance/legacy/tks-tests/acls/tks-ad-acls.sh
@@ -0,0 +1,91 @@
+#!/bin/bash
+# vim: dict=/usr/share/beakerlib/dictionary.vim cpt=.,w,b,u,t,i,k
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# runtest.sh of /CoreOS/rhcs/acceptance/legacy/tks-tests/tks-ad-acls.sh
+# Description: TKS Admin ACL tests
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+# The following legacy test is being tested:
+# TKS Admin ACL tests
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# Author: Niranjan Mallapadi <mniranja@redhat.com>
+#
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# Copyright (c) 2013 Red Hat, Inc. All rights reserved.
+#
+# This copyrighted material is made available to anyone wishing
+# to use, modify, copy, or redistribute it subject to the terms
+# and conditions of the GNU General Public License version 2.
+#
+# This program is distributed in the hope that it will be
+# useful, but WITHOUT ANY WARRANTY; without even the implied
+# warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+# PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public
+# License along with this program; if not, write to the Free
+# Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+# Boston, MA 02110-1301, USA.
+#
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+# Include rhts environment
+. /usr/bin/rhts-environment.sh
+. /usr/share/beakerlib/beakerlib.sh
+. /opt/rhqa_pki/rhcs-shared.sh
+. /opt/rhqa_pki/pki-cert-cli-lib.sh
+. /opt/rhqa_pki/pki-auth-plugin-lib.sh
+. /opt/rhqa_pki/env.sh
+
+run_admin-tks-acl_tests()
+{
+ local cs_Type=$1
+ local cs_Role=$2
+
+ # Creating Temporary Directory for legacy test
+ rlPhaseStartSetup "Create Temporary Directory"
+ rlRun "TmpDir=\`mktemp -d\`" 0 "Creating tmp directory"
+ rlRun "pushd $TmpDir"
+ rlPhaseEnd
+
+ # Local Variables
+ get_topo_stack $cs_Role $TmpDir/topo_file
+ local CA_INST=$(cat $TmpDir/topo_file | grep MY_CA | cut -d= -f2)
+ local TKS_INST=$(cat $TmpDir/topo_file | grep MY_TKS | cut -d= -f2)
+ local tomcat_name=$(eval echo \$${TKS_INST}_TOMCAT_INSTANCE_NAME)
+ local target_unsecure_port=$(eval echo \$${TKS_INST}_UNSECURE_PORT)
+ local target_secure_port=$(eval echo \$${TKS_INST}_SECURE_PORT)
+ local tmp_ca_port=$(eval echo \$${CA_INST}_UNSECURE_PORT)
+ local tmp_tks_host=$(eval echo \$${cs_Role})
+ local tmp_ca_host=$(eval echo \$${cs_Role})
+ local valid_admin=$TKS_INST\_adminV
+ local valid_admin_pwd=$TKS_INST\_adminV_password
+ local admin_out="$TmpDir/admin_out"
+
+ rlPhaseStartTest "pki_tks_ad-acl-001: DRM Console: List Acls"
+ local acls=("actions" "certServer.acl.configuration" "certServer.admin.certificate" "certServer.auth.configuration" "certServer.clone.configuration" "certServer.general.configuration" "certServer.log.configuration" "certServer.log.configuration.fileName" "certServer.log.content.signedAudit" "certServer.log.content.system" "certServer.log.content.transactions" "certServer.registry.configuration" "certServer.tks.account" "certServer.tks.encrypteddata" "certServer.tks.group" "certServer.tks.groups" "certServer.tks.keysetdata" "certServer.tks.randomdata" "certServer.tks.selftests" "certServer.tks.sessionkey" "certServer.tks.systemstatus" "certServer.tks.users")
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='acls'
+ local test_out=acls.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/acl\" > $TmpDir/$test_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/acl\" > $TmpDir/$test_out"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ for i in "${acls[@]}"; do
+ rlAssertGrep "$i" "$TmpDir/$test_out"
+ done
+ rlPhaseEnd
+
+ rlPhaseStartCleanup "Delete temporary dir"
+ rlRun "popd"
+ rlRun "rm -r $TmpDir" 0 "Removing tmp directory"
+ rlPhaseEnd
+}
diff --git a/tests/dogtag/acceptance/legacy/tks-tests/internaldb/tks-ad-internaldb.sh b/tests/dogtag/acceptance/legacy/tks-tests/internaldb/tks-ad-internaldb.sh
new file mode 100755
index 000000000..a8c38f25d
--- /dev/null
+++ b/tests/dogtag/acceptance/legacy/tks-tests/internaldb/tks-ad-internaldb.sh
@@ -0,0 +1,140 @@
+#!/bin/bash
+# vim: dict=/usr/share/beakerlib/dictionary.vim cpt=.,w,b,u,t,i,k
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# runtest.sh of /CoreOS/rhcs/acceptance/legacy/ocsp-tests/tks-ad-internaldb.sh
+# Description: TKS Admin internaldb tests
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+# The following legacy test is being tested:
+# TKS Admin Internaldb tests
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# Author: Niranjan Mallapadi <mniranja@redhat.com>
+#
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# Copyright (c) 2013 Red Hat, Inc. All rights reserved.
+#
+# This copyrighted material is made available to anyone wishing
+# to use, modify, copy, or redistribute it subject to the terms
+# and conditions of the GNU General Public License version 2.
+#
+# This program is distributed in the hope that it will be
+# useful, but WITHOUT ANY WARRANTY; without even the implied
+# warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+# PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public
+# License along with this program; if not, write to the Free
+# Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+# Boston, MA 02110-1301, USA.
+#
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+# Include rhts environment
+. /usr/bin/rhts-environment.sh
+. /usr/share/beakerlib/beakerlib.sh
+. /opt/rhqa_pki/rhcs-shared.sh
+. /opt/rhqa_pki/pki-cert-cli-lib.sh
+. /opt/rhqa_pki/pki-auth-plugin-lib.sh
+. /opt/rhqa_pki/env.sh
+
+run_admin-tks-internaldb_tests()
+{
+ local cs_Type=$1
+ local cs_Role=$2
+
+ # Creating Temporary Directory for legacy test
+ rlPhaseStartSetup "Create Temporary Directory"
+ rlRun "TmpDir=\`mktemp -d\`" 0 "Creating tmp directory"
+ rlRun "pushd $TmpDir"
+ rlPhaseEnd
+
+ # Local Variables
+ get_topo_stack $cs_Role $TmpDir/topo_file
+ local CA_INST=$(cat $TmpDir/topo_file | grep MY_CA | cut -d= -f2)
+ local TKS_INST=$(cat $TmpDir/topo_file | grep MY_TKS | cut -d= -f2)
+ local tomcat_name=$(eval echo \$${TKS_INST}_TOMCAT_INSTANCE_NAME)
+ local target_unsecure_port=$(eval echo \$${TKS_INST}_UNSECURE_PORT)
+ local target_secure_port=$(eval echo \$${TKS_INST}_SECURE_PORT)
+ local tmp_ca_port=$(eval echo \$${CA_INST}_UNSECURE_PORT)
+ local tmp_tks_host=$(eval echo \$${cs_Role})
+ local tmp_ca_host=$(eval echo \$${cs_Role})
+ local valid_ca_agent_cert=$CA_INST\_agentV
+ local valid_agent=$TKS_INST\_agentV
+ local valid_agent_pwd=$TKS_INST\_agentV_password
+ local valid_audit=$TKS_INST\_auditV
+ local valid_audit_pwd=$TKS_INST\_auditV_password
+ local valid_operator=$TKS_INST\_operatorV
+ local valid_operator_pwd=$TKS_INST\_operatorV_password
+ local valid_admin=$TKS_INST\_adminV
+ local valid_admin_pwd=$TKS_INST\_adminV_password
+ local revoked_agent=$TKS_INST\_agentR
+ local revoked_admin=$TKS_INST\_adminR
+ local expired_admin=$TKS_INST\_adminE
+ local expired_agent=$TKS_INST\_agentE
+ local admin_out="$TmpDir/admin_out"
+ local TEMP_NSS_DB="$TmpDir/nssdb"
+ local TEMP_NSS_DB_PWD="redhat"
+
+ rlPhaseStartTest "pki_tks_ad-internaldb-001: TKS Console: List Internaldb"
+ local OP_TYPE='OP_READ'
+ local OP_SCOPE='ldap'
+ local RS_ID='RS_ID_CONFIG'
+ local test_out=internaldb.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&ldapconn.host=&ldapconn.port=&ldapauth.bindDN=&ldapconn.version=&\" -k \"https://$tmp_tks_host:$target_secure_port/tks/server\" > $TmpDir/$test_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&ldapconn.host=&ldapconn.port=&ldapauth.bindDN=&ldapconn.version=&\" -k \"https://$tmp_tks_host:$target_secure_port/tks/server\" > $TmpDir/$test_out"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertGrep "ldapconn.host=localhost" "$TmpDir/$test_out"
+ rlAssertGrep "ldapconn.port=$(eval echo \$${TKS_INST}_LDAP_PORT)" "$TmpDir/$test_out"
+ rlAssertGrep "ldapauth.bindDN=cn=DirectoryManager" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad-internaldb-002: TKS Console: Edit Internaldb"
+ rlLog "Edit Internal DB"
+ local OP_TYPE='OP_MODIFY'
+ local OP_SCOPE='ldap'
+ local RS_ID='RS_ID_CONFIG'
+ local ldaphost="$(hostname)"
+ local ldapport=$(eval echo \$${TKS_INST}_LDAP_PORT)
+ local ldapbindDN='cn=Directory Manager'
+ local ldapversion='3'
+ local maxConns='15'
+ local minConns='3'
+ local test_out=internaldb.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&ldapconn.host=$ldaphost&ldapconn.port=$ldapport&ldapauth.bindDN=$ldapbindDN&ldapconn.version=$ldapversion&maxConns=$maxConns&minConns=$minConns\" -k \"https://$tmp_tks_host:$target_secure_port/tks/server\" > $TmpDir/$test_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&ldapconn.host=$ldaphost&ldapconn.port=$ldapport&ldapauth.bindDN=$ldapbindDN&ldapconn.version=$ldapversion&maxConns=$maxConns&minConns=$minConns\" -k \"https://$tmp_tks_host:$target_secure_port/tks/server\" > $TmpDir/$test_out"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=OP_READ&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&ldapconn.host=&ldapconn.port=&ldapauth.bindDN=&ldapconn.version=&\" -k \"https://$tmp_tks_host:$target_secure_port/tks/server\" > $TmpDir/$test_out"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertGrep "ldapconn.host=$ldaphost" "$TmpDir/$test_out"
+ rlAssertGrep "ldapconn.port=$ldapport" "$TmpDir/$test_out"
+ rlAssertGrep "ldapauth.bindDN=cn=DirectoryManager" "$TmpDir/$test_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=OP_MODIFY&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&ldapconn.host=localhost&ldapconn.port=$ldapport&ldapauth.bindDN=$ldapbindDN&ldapconn.version=$ldapversion&maxConns=$maxConns&minConns=$minConns\" -k \"https://$tmp_tks_host:$target_secure_port/tks/server\" > $TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartCleanup "Delete temporary dir"
+ rlRun "popd"
+ rlRun "rm -r $TmpDir" 0 "Removing tmp directory"
+ rlPhaseEnd
+}
diff --git a/tests/dogtag/acceptance/legacy/tks-tests/logs/tks-ad-logs.sh b/tests/dogtag/acceptance/legacy/tks-tests/logs/tks-ad-logs.sh
new file mode 100755
index 000000000..d66905ddf
--- /dev/null
+++ b/tests/dogtag/acceptance/legacy/tks-tests/logs/tks-ad-logs.sh
@@ -0,0 +1,192 @@
+#!/bin/bash
+# vim: dict=/usr/share/beakerlib/dictionary.vim cpt=.,w,b,u,t,i,k
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# runtest.sh of /CoreOS/rhcs/acceptance/legacy/tks-tests/tks-ad-logs.sh
+# Description: TKS Admin logs tests
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+# The following pki key cli commands needs to be tested:
+# TKS Admin logs test
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# Author: Niranjan Mallapadi <mniranja@redhat.com>
+#
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# Copyright (c) 2013 Red Hat, Inc. All rights reserved.
+#
+# This copyrighted material is made available to anyone wishing
+# to use, modify, copy, or redistribute it subject to the terms
+# and conditions of the GNU General Public License version 2.
+#
+# This program is distributed in the hope that it will be
+# useful, but WITHOUT ANY WARRANTY; without even the implied
+# warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+# PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public
+# License along with this program; if not, write to the Free
+# Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+# Boston, MA 02110-1301, USA.
+#
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+# Include rhts environment
+. /usr/bin/rhts-environment.sh
+. /usr/share/beakerlib/beakerlib.sh
+. /opt/rhqa_pki/rhcs-shared.sh
+. /opt/rhqa_pki/pki-cert-cli-lib.sh
+. /opt/rhqa_pki/env.sh
+
+run_admin-tks-log_tests()
+{
+ local cs_Type=$1
+ local cs_Role=$2
+
+ # Creating Temporary Directory for legacy test
+ rlPhaseStartSetup "Create Temporary Directory"
+ rlRun "TmpDir=\`mktemp -d\`" 0 "Creating tmp directory"
+ rlRun "pushd $TmpDir"
+ rlPhaseEnd
+
+ # Local Variables
+ get_topo_stack $cs_Role $TmpDir/topo_file
+ local CA_INST=$(cat $TmpDir/topo_file | grep MY_CA | cut -d= -f2)
+ local TKS_INST=$(cat $TmpDir/topo_file | grep MY_TKS | cut -d= -f2)
+ local tomcat_name=$(eval echo \$${TKS_INST}_TOMCAT_INSTANCE_NAME)
+ local target_unsecure_port=$(eval echo \$${TKS_INST}_UNSECURE_PORT)
+ local target_secure_port=$(eval echo \$${TKS_INST}_SECURE_PORT)
+ local tmp_ca_port=$(eval echo \$${CA_INST}_UNSECURE_PORT)
+ local tmp_tks_host=$(eval echo \$${cs_Role})
+ local tmp_ca_host=$(eval echo \$${cs_Role})
+ local valid_ca_agent_cert=$CA_INST\_agentV
+ local valid_agent=$TKS_INST\_agentV
+ local valid_agent_pwd=$TKS_INST\_agentV_password
+ local valid_audit=$TKS_INST\_auditV
+ local valid_audit_pwd=$TKS_INST\_auditV_password
+ local valid_operator=$TKS_INST\_operatorV
+ local valid_operator_pwd=$TKS_INST\_operatorV_password
+ local valid_admin=$TKS_INST\_adminV
+ local valid_admin_pwd=$TKS_INST\_adminV_password
+ local revoked_agent=$TKS_INST\_agentR
+ local revoked_admin=$TKS_INST\_adminR
+ local expired_admin=$TKS_INST\_adminE
+ local expired_agent=$TKS_INST\_agentE
+ local admin_out="$TmpDir/admin_out"
+ local TEMP_NSS_DB="$TmpDir/nssdb"
+ local TEMP_NSS_DB_PWD="redhat"
+
+
+ rlPhaseStartTest "pki_console_log-001: TKS Admin Interface - Add a new log file"
+ rlLog "Create a new log of type system"
+ local logfile=log$RANDOM
+ local level=0
+ local rolloverinterval=1
+ local logtype="system"
+ local flushinterval=5
+ local filename=/tmp/$logfile
+ local logenable="True"
+ local signedAuditCertNickname="kraauditsigningcert"
+ rlRun "curl --capath "$CERTDB_DIR" --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=OP_ADD&OP_SCOPE=logRule&RS_ID=$logfile&unselected.events=&level=$level&rolloverInterval=$rolloverinterval&flushInterval=$flushinterval&mandatory.events=&bufferSize=512&maxFileSize=2000&fileName=$filename&enable=$logenable&signedAuditCertNickname=$signedAuditCertNickname&implName=file&type=$logtype&logSigning=true&events=&RULENAME=$logfile\" -k https://$tmp_tks_host:$target_secure_port/tks/log >> $admin_out" 0 "Create $logfile file of type $logtype"
+ rlLog "List all logs"
+ rlRun "curl --capath "$CERTDB_DIR" --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=OP_SEARCH&OP_SCOPE=logRule\" -k https://$tmp_tks_host:$target_secure_port/tks/log > $admin_out" 0 "List all logs configured"
+ rlRun "process_curl_output $admin_out" 0 "Process curl output file"
+ rlAssertGrep "$logfile=file:visible" "$admin_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_console_log-002: TKS Admin Interface - List all logs"
+ rlLog "List all logs"
+ rlRun "curl --capath "$CERTDB_DIR" --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=OP_SEARCH&OP_SCOPE=logRule\" -k https://$tmp_tks_host:$target_secure_port/tks/log > $admin_out" 0 "List all logs configured"
+ rlRun "process_curl_output $admin_out" 0 "Process curl output file"
+ rlAssertGrep "Transactions=file:visible" "$admin_out"
+ rlAssertGrep "SignedAudit=file:visible" "$admin_out"
+ rlAssertGrep "System=file:visible" "$admin_out"
+ rlAssertGrep "$logfile=file:visible" "$admin_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_console_log-003: TKS Admin Interface - Edit log file configuration"
+ local level=0
+ local rolloverinterval=1
+ local logtype="system"
+ local flushinterval=5
+ local filename=/tmp/$logfile
+ local logenable="false"
+ local maxfilesize=3000
+ local buffersize=512
+ rlRun "curl --capath "$CERTDB_DIR" --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=OP_MODIFY&OP_SCOPE=logRule&RS_ID=$logfile&level=$level&rolloverInterval=$rolloverinterval&flushInterval=$flushinterval&bufferSize=$buffersize&maxFileSize=$maxfilesize&fileName=$filename&enable=$logenable&implName=file&type=$logtype&RULENAME=$logfile\" -k https://$tmp_tks_host:$target_secure_port/tks/log >> $admin_out" 0 "Modify $logfile file"
+ rlLog "Changes require restart of CA instance"
+ rlRun "rhcs_stop_instance $tomcat_name"
+ rlRun "rhcs_start_instance $tomcat_name"
+ rlLog "Read $logfile and verify values are updated"
+ rlRun "curl --capath "$CERTDB_DIR" --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=OP_READ&OP_SCOPE=logRule&RS_ID=$logfile\" -k https://$tmp_tks_host:$target_secure_port/tks/log > $admin_out" 0 "Read $logfile file"
+ rlRun "process_curl_output $admin_out" 0 "Process curl output file"
+ rlAssertGrep "maxFileSize=$maxfilesize" "$admin_out"
+ rlAssertGrep "enable=$logenable" "$admin_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_console_log-004: TKS Admin Interface - View log file"
+ rlLog "Read $logfile"
+ rlRun "curl --capath "$CERTDB_DIR" --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=OP_READ&OP_SCOPE=logRule&RS_ID=$logfile\" -k https://$tmp_tks_host:$target_secure_port/tks/log > $admin_out" 0 "Read $logfile file"
+ rlRun "process_curl_output $admin_out" 0 "Process curl output file"
+ rlAssertGrep "implName=file" "$admin_out"
+ rlAssertGrep "type=$logtype" "$admin_out"
+ rlAssertGrep "enable=$logenable" "$admin_out"
+ rlAssertGrep "level=Debug" "$admin_out"
+ rlAssertGrep "bufferSize=$buffersize" "$admin_out"
+ rlAssertGrep "maxFileSize=$maxfilesize" "$admin_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_console_log-005: TKS Admin Interface - Delete log file"
+ rlLog "Delete log $logfile file"
+ rlRun "curl --capath "$CERTDB_DIR" --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=OP_DELETE&OP_SCOPE=logRule&RS_ID=$logfile\" -k https://$tmp_tks_host:$target_secure_port/tks/log > $admin_out" 0 "Delete $logfile file"
+ rlRun "process_curl_output $admin_out" 0 "Process curl output file"
+ rlLog "List all logs"
+ rlRun "curl --capath "$CERTDB_DIR" --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=OP_SEARCH&OP_SCOPE=logRule\" -k https://$tmp_tks_host:$target_secure_port/tks/log > $admin_out" 0 "List all logs configured"
+ rlRun "process_curl_output $admin_out" 0 "Process curl output file"
+ rlAssertGrep "Transactions=file:visible" "$admin_out"
+ rlAssertGrep "SignedAudit=file:visible" "$admin_out"
+ rlAssertGrep "System=file:visible" "$admin_out"
+ rlAssertNotGrep "$logfile=file:visible" "$admin_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_console_log-006: TKS Admin Interface - Adding a log file with agent privileges should fail"
+ local logfile=log$RANDOM
+ local level=0
+ local rolloverinterval=1
+ local logtype="system"
+ local flushinterval=5
+ local filename=/tmp/$logfile
+ local logenable="True"
+ local signedAuditCertNickname="caauditsigningcert"
+ rlRun "curl --capath "$CERTDB_DIR" --basic --user "$valid_agent:$valid_agent_pwd" \
+ -d \"OP_TYPE=OP_ADD&OP_SCOPE=logRule&RS_ID=$logfile&unselected.events=&level=$level&rolloverInterval=$rolloverinterval&flushInterval=$flushinterval&mandatory.events=&bufferSize=512&maxFileSize=2000&fileName=$filename&enable=$logenable&signedAuditCertNickname=$signedAuditCertNickname&implName=file&type=$logtype&logSigning=true&events=&RULENAME=$logfile\" -k https://$tmp_tks_host:$target_secure_port/tks/log > $admin_out" 0 "Create $logfile file of type $logtype"
+ rlAssertGrep "You are not authorized to perform this operation" "$admin_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_console_log-007: TKS Admin Interface - Adding a log file with audit privileges should fail"
+ local logfile=log$RANDOM
+ local level=0
+ local rolloverinterval=1
+ local logtype="system"
+ local flushinterval=5
+ local filename=/tmp/$logfile
+ local logenable="True"
+ local signedAuditCertNickname="caauditsigningcert"
+ rlRun "curl --capath "$CERTDB_DIR" --basic --user "$valid_audit:$valid_audit_pwd" \
+ -d \"OP_TYPE=OP_ADD&OP_SCOPE=logRule&RS_ID=$logfile&unselected.events=&level=$level&rolloverInterval=$rolloverinterval&flushInterval=$flushinterval&mandatory.events=&bufferSize=512&maxFileSize=2000&fileName=$filename&enable=$logenable&signedAuditCertNickname=$signedAuditCertNickname&implName=file&type=$logtype&logSigning=true&events=&RULENAME=$logfile\" -k https://$tmp_tks_host:$target_secure_port/tks/log > $admin_out" 0 "Create $logfile file of type $logtype"
+ rlAssertGrep "You are not authorized to perform this operation" "$admin_out"
+ rlPhaseEnd
+
+ rlPhaseStartCleanup "Delete temporary dir"
+ rlRun "popd"
+ rlRun "rm -r $TmpDir" 0 "Removing tmp directory"
+ rlPhaseEnd
+}
diff --git a/tests/dogtag/acceptance/legacy/tks-tests/usergroups/tks-ad-usergroups.sh b/tests/dogtag/acceptance/legacy/tks-tests/usergroups/tks-ad-usergroups.sh
new file mode 100755
index 000000000..fb9436ee6
--- /dev/null
+++ b/tests/dogtag/acceptance/legacy/tks-tests/usergroups/tks-ad-usergroups.sh
@@ -0,0 +1,769 @@
+#!/bin/bash
+# vim: dict=/usr/share/beakerlib/dictionary.vim cpt=.,w,b,u,t,i,k
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# runtest.sh of /CoreOS/rhcs/acceptance/legacy/tks-tests/tks-ad-usergroups
+# Description: TKS Admin Console User groups tests
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+# The following legacy test is being tested:
+# TKS Admin Console Usergroups tests
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# Author: Niranjan Mallapadi <mniranja@redhat.com>
+#
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#
+# Copyright (c) 2013 Red Hat, Inc. All rights reserved.
+#
+# This copyrighted material is made available to anyone wishing
+# to use, modify, copy, or redistribute it subject to the terms
+# and conditions of the GNU General Public License version 2.
+#
+# This program is distributed in the hope that it will be
+# useful, but WITHOUT ANY WARRANTY; without even the implied
+# warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+# PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public
+# License along with this program; if not, write to the Free
+# Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+# Boston, MA 02110-1301, USA.
+#
+# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+# Include rhts environment
+. /usr/bin/rhts-environment.sh
+. /usr/share/beakerlib/beakerlib.sh
+. /opt/rhqa_pki/rhcs-shared.sh
+. /opt/rhqa_pki/pki-cert-cli-lib.sh
+. /opt/rhqa_pki/pki-auth-plugin-lib.sh
+. /opt/rhqa_pki/env.sh
+
+run_tks-ad_usergroups()
+{
+ local cs_Type=$1
+ local cs_Role=$2
+
+ # Creating Temporary Directory for legacy test
+ rlPhaseStartSetup "Create Temporary Directory"
+ rlRun "TmpDir=\`mktemp -d\`" 0 "Creating tmp directory"
+ rlRun "pushd $TmpDir"
+ get_topo_stack $cs_Role $TmpDir/topo_file
+ local CA_INST=$(cat $TmpDir/topo_file | grep MY_CA | cut -d= -f2)
+ local TKS_INST=$(cat $TmpDir/topo_file | grep MY_TKS | cut -d= -f2)
+ local tomcat_name=$(eval echo \$${TKS_INST}_TOMCAT_INSTANCE_NAME)
+ disable_ca_nonce $tomcat_name
+ rlPhaseEnd
+
+ # Local Variables
+ local target_unsecure_port=$(eval echo \$${TKS_INST}_UNSECURE_PORT)
+ local target_secure_port=$(eval echo \$${TKS_INST}_SECURE_PORT)
+ local tmp_ca_port=$(eval echo \$${CA_INST}_UNSECURE_PORT)
+ local tmp_tks_host=$(eval echo \$${cs_Role})
+ local tmp_ca_host=$(eval echo \$${cs_Role})
+ local valid_ca_agent_cert=$CA_INST\_agentV
+ local valid_agent=$TKS_INST\_agentV
+ local valid_agent_pwd=$TKS_INST\_agentV_password
+ local valid_audit=$TKS_INST\_auditV
+ local valid_audit_pwd=$TKS_INST\_auditV_password
+ local valid_operator=$TKS_INST\_operatorV
+ local valid_operator_pwd=$TKS_INST\_operatorV_password
+ local valid_admin=$TKS_INST\_adminV
+ local valid_admin_pwd=$TKS_INST\_adminV_password
+ local revoked_agent=$TKS_INST\_agentR
+ local revoked_admin=$TKS_INST\_adminR
+ local expired_admin=$TKS_INST\_adminE
+ local expired_agent=$TKS_INST\_agentE
+ local admin_out="$TmpDir/admin_out"
+ local TEMP_NSS_DB="$TmpDir/nssdb"
+ local TEMP_NSS_DB_PWD="redhat"
+ local cert_info="$TmpDir/cert_info"
+ local ca_profile_out="$TmpDir/ca-profile-out"
+ local cert_out="$TmpDir/cert-show.out"
+ local cert_show_out="$TmpDir/cert_show.out"
+ local rand=$RANDOM
+ local tmp_junk_data=$(openssl rand -base64 50 | perl -p -e 's/\n//')
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-001: TKS Console: List Users"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='users'
+ local test_out=$OP_TYPE\.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" >> $TmpDir/$test_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" >> $TmpDir/$test_out" 0 "List Users"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertGrep "$valid_admin" "$TmpDir/$test_out"
+ rlAssertGrep "$valid_agent" "$TmpDir/$test_out"
+ rlAssertGrep "$valid_audit" "$TmpDir/$test_out"
+ rlAssertGrep "$valid_operator" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-002: TKS Console: Add Users"
+ local user1=$TKS_INST-$RANDOM
+ local OP_TYPE='OP_ADD'
+ local OP_SCOPE='users'
+ local RS_ID=$user1
+ local fullname=$user1
+ local password=$user1
+ local email=$user1@example.org
+ local phone=''
+ local state=''
+ local groups='Online Certificate Status Manager Agents'
+ local userType=''
+ local test_out=add.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&fullname=$fullname&password=$password&email=$email&phone=$phone&state=$state&groups=$groups&userType=$userType\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&fullname=$fullname&password=$password&email=$email&phone=$phone&state=$state&groups=$groups&userType=$userType\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlLog "List users"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='users'
+ local test_out=$OP_TYPE\.out
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "List Users"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertGrep "$user1" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-003: TKS Console: Edit Users"
+ local OP_TYPE='OP_MODIFY'
+ local OP_SCOPE='users'
+ local RS_ID=$user1
+ local fullname=$user1-01
+ local password=$user1
+ local email=$user1@example.org
+ local phone=''
+ local state=''
+ local userType=''
+ local test_out=modify.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&fullname=$fullname&password=$password&email=$email&phone=$phone&state=$state&userType=$userType\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&fullname=$fullname&password=$password&email=$email&phone=$phone&state=$state&userType=$userType\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlLog "List users"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='users'
+ local test_out=$OP_TYPE\.out
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "List Users"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertGrep "$user1:$fullname" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartSetup "Generate certificate"
+ local request_type=pkcs10
+ local request_key_type=rsa
+ local request_key_size=1024
+ local profile=caUserCert
+ local cert_ext_exKeyUsageOIDs="1.3.6.1.5.5.7.3.2,1.3.6.1.5.5.7.3.4"
+ local userid="$user1"
+ local usercn="$fullname"
+ local phone="1234-$RANDOM"
+ local usermail="$userid@example.org"
+ local test_out=ca-$profile-test.txt
+ rlRun "export SSL_DIR=$CERTDB_DIR"
+ rlLog "Create a new certificate request of type $request_type with key size $request_key_size"
+ rlRun "create_new_cert_request \
+ tmp_nss_db:$TEMP_NSS_DB \
+ tmp_nss_db_password:$TEMP_NSS_DB_PWD \
+ request_type:$request_type \
+ request_algo:$request_key_type \
+ request_size:$request_key_size \
+ subject_cn:\"$usercn\" \
+ subject_uid:$userid \
+ subject_email:$usermail \
+ subject_ou:IDM \
+ subject_organization:RedHat \
+ subject_country:US \
+ subject_archive:false \
+ cert_request_file:$TEMP_NSS_DB/$rand-request.pem \
+ cert_subject_file:$TEMP_NSS_DB/$rand-subject.out" 0 "Create $request_type request for $profile"
+ local cert_requestdn=$(cat $TEMP_NSS_DB/$rand-subject.out | grep Request_DN | cut -d ":" -f2)
+ rlLog "cert_requestdn=cert_requestdn"
+ rlRun "cat $TEMP_NSS_DB/$rand-request.pem | python -c 'import sys, urllib as ul; print ul.quote(sys.stdin.read());' > $TEMP_NSS_DB/$rand-encoded-request.pem"
+ rlLog "curl --basic \
+ --dump-header $admin_out \
+ -d \"profileId=$profile&cert_request_type=$request_type&sn_uid=$userid&sn_cn=$usercn&sn_e=$usermail&sn_ou=IDM&sn_o=Redhat&sn_C=US&requestor_email=$useremail&requestor_phone=$phone&cert_request=$(cat -v $TEMP_NSS_DB/$rand-encoded-request.pem)\" \
+ -k \"https://$tmp_ca_host:$target_secure_port/ca/ee/ca/profileSubmit\""
+ rlRun "curl --basic \
+ --dump-header $admin_out \
+ -d \"profileId=$profile&cert_request_type=$request_type&sn_uid=$userid&sn_cn=$usercn&sn_e=$usermail&sn_ou=IDM&sn_o=Redhat&sn_C=US&requestor_email=$useremail&requestor_phone=$phone&cert_request=$(cat -v $TEMP_NSS_DB/$rand-encoded-request.pem)\" \
+ -k \"https://$tmp_ca_host:$target_secure_port/ca/ee/ca/profileSubmit\" > $TmpDir/$test_out" 0 "Submit Certificate request to $profile"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertNotGrep "Sorry, your request has been rejected" "$admin_out"
+ local request_id=$(cat -v $TmpDir/$test_out | grep 'requestList.requestId' | awk -F '=\"' '{print $2}' | awk -F '\";' '{print $1}')
+ rlLog "request_id=$request_id"
+ rlLog "Approve $request_id using $valid_agent_cert"
+ local Second=`date +'%S' -d now`
+ local Minute=`date +'%M' -d now`
+ local Hour=`date +'%H' -d now`
+ local Day=`date +'%d' -d now`
+ local Month=`date +'%m' -d now`
+ local Year=`date +'%Y' -d now`
+ local start_year=$Year
+ let end_year=$Year+1
+ local end_day="1"
+ local notBefore="$start_year-$Month-$Day $Hour:$Minute:$Second"
+ local notAfter="$end_year-$Month-$end_day $Hour:$Minute:$Second"
+ rlLog "curl --cacert $CERTDB_DIR/ca_cert.pem \
+ --dump-header $admin_out \
+ -E $valid_ca_agent_cert:$CERTDB_DIR_PASSWORD \
+ -d \"requestId=$request_id&op=approve&submit=submit&name=$cert_requestdn&notBefore=$notBefore&notAfter=$notAfter&authInfoAccessCritical=false&authInfoAccessGeneralNames=&keyUsageCritical=true&keyUsageDigitalSignature=true&keyUsageNonRepudiation=true&keyUsageKeyEncipherment=true&keyUsageDataEncipherment=false&keyUsageKeyAgreement=false&keyUsageKeyCertSign=false&keyUsageCrlSign=false&keyUsageEncipherOnly=false&keyUsageDecipherOnly=false&exKeyUsageCritical=false&exKeyUsageOIDs=$cert_ext_exKeyUsageOIDs&&subjAltNameExtCritical=false&subjAltNames=$cert_ext_subjAltNames&signingAlg=SHA1withRSA&requestNotes=submittingcertfor$userid\" \
+ -k \"https://$tmp_ca_host:$target_secure_port/ca/agent/ca/profileProcess\""
+ rlRun "curl --cacert $CERTDB_DIR/ca_cert.pem \
+ --dump-header $admin_out \
+ -E $valid_ca_agent_cert:$CERTDB_DIR_PASSWORD \
+ -d \"requestId=$request_id&op=approve&submit=submit&name=$cert_requestdn&notBefore=$notBefore&notAfter=$notAfter&authInfoAccessCritical=false&authInfoAccessGeneralNames=&keyUsageCritical=true&keyUsageDigitalSignature=true&keyUsageNonRepudiation=true&keyUsageKeyEncipherment=true&keyUsageDataEncipherment=false&keyUsageKeyAgreement=false&keyUsageKeyCertSign=false&keyUsageCrlSign=false&keyUsageEncipherOnly=false&keyUsageDecipherOnly=false&exKeyUsageCritical=false&exKeyUsageOIDs=$cert_ext_exKeyUsageOIDs&&subjAltNameExtCritical=false&subjAltNames=$cert_ext_subjAltNames&signingAlg=SHA1withRSA&requestNotes=submittingcertfor$userid\" \
+ -k \"https://$tmp_ca_host:$target_secure_port/ca/agent/ca/profileProcess\" > $TmpDir/$test_out" 0 "Submit certificate request"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ local serial_number=$(cat -v $TmpDir/$test_out | tr '\\n' '\n' | grep 'Serial Number' | awk -F 'Serial Number: ' '{print $2}')
+ local certificate_in_base64=$(cat -v $TmpDir/$test_out | grep 'outputList.outputVal' | awk -F 'outputList.outputVal=\"' '{print $2}' | awk -F '-----BEGIN CERTIFICATE-----' '{print $2}' | sed '/^$/d' | sed 's/^\\n//'|sed -e 's/^/-----BEGIN CERTIFICATE-----/' | sed 's/-----END CERTIFICATE-----\\n\";/-----END CERTIFICATE-----/' | sed 's/\\r\\n//g')
+ rlRun "verify_cert \"$serial_number\" \"$cert_requestdn\"" 0 "Verify cert"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-004: TKS Console: Import Cert to the user"
+ local OP_TYPE='OP_ADD'
+ local OP_SCOPE='certs'
+ local RS_ID="$user1"
+ local cert=$certificate_in_base64
+ local test_out=addcert.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" --data-urlencode \"cert=$certificate_in_base64\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Import cert to $user1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" --data-urlencode \"cert=$certificate_in_base64\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Import cert to $user1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlLog "Verify if cert is added"
+ local OP_TYPE='OP_READ'
+ local OP_SCOPE='certs'
+ local RS_ID="$userid"
+ local test_out=search.out
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search certificate"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertGrep "-----BEGIN+CERTIFICATE-----" "$TmpDir/$test_out"
+ rlAssertGrep "-----END+CERTIFICATE-----" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-005: TKS Console: Add Group"
+ local group1=$TKS_INST-group-$RANDOM
+ local OP_TYPE='OP_ADD'
+ local OP_SCOPE='groups'
+ local RS_ID=$group1
+ local desc=$group1
+ local user=$user1
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Add Group $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Add Group $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlLog "Verify group is added"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='groups'
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertGrep "$group1" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-006: TKS Console: Edit Group"
+ local OP_TYPE='OP_MODIFY'
+ local OP_SCOPE='groups'
+ local RS_ID=$group1
+ local desc=$group1
+ local user=$valid_admin,$valid_agent,$valid_audit
+ local test_out=edit.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&desc=$desc&user=$user\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Edit $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&desc=$desc&user=$user\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Edit $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-007: TKS Console: Delete Group"
+ local OP_TYPE='OP_DELETE'
+ local OP_SCOPE='groups'
+ local RS_ID=$group1
+ local test_out=groupdelete.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlLog "Verify group is deleted"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='groups'
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertNotGrep "$group1" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-008: TKS Console: Delete User"
+ local OP_TYPE='OP_DELETE'
+ local OP_SCOPE='users'
+ local RS_ID="$user1:true"
+ rlLog "Delete $user1"
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $user1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $user1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlLog "List users"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='users'
+ local test_out=$OP_TYPE\.out
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "List Users"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertNotGrep "$user1" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-009: TKS Console: Verify Agent user cannot add new user"
+ local user2=$TKS_INST-$RANDOM
+ local OP_TYPE='OP_ADD'
+ local OP_SCOPE='users'
+ local RS_ID=$user2
+ local fullname=$user2
+ local password=$user2
+ local email=$user2@example.org
+ local phone=''
+ local state=''
+ local groups='Data Recovery Manager Agents'
+ local userType=''
+ local test_out=add.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_agent:$valid_agent_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&fullname=$fullname&password=$password&email=$email&phone=$phone&state=$state&groups=$groups&userType=$userType\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_agent:$valid_agent_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&fullname=$fullname&password=$password&email=$email&phone=$phone&state=$state&groups=$groups&userType=$userType\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertGrep "You are not authorized to perform this operation" "$TmpDir/$test_out"
+ rlLog "List users"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='users'
+ local test_out=$OP_TYPE\.out
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "List Users"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertNotGrep "$user2" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-0010: TKS Console: Verify Audit user cannot add new user"
+ local user2=$TKS_INST-$RANDOM
+ local OP_TYPE='OP_ADD'
+ local OP_SCOPE='users'
+ local RS_ID=$user2
+ local fullname=$user2
+ local password=$user2
+ local email=$user2@example.org
+ local phone=''
+ local state=''
+ local groups='Data Recovery Manager Agents'
+ local userType=''
+ local test_out=add.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_audit:$valid_audit_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&fullname=$fullname&password=$password&email=$email&phone=$phone&state=$state&groups=$groups&userType=$userType\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_audit:$valid_audit_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&fullname=$fullname&password=$password&email=$email&phone=$phone&state=$state&groups=$groups&userType=$userType\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertGrep "You are not authorized to perform this operation" "$TmpDir/$test_out"
+ rlLog "List users"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='users'
+ local test_out=$OP_TYPE\.out
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "List Users"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertNotGrep "$user2" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-0011: TKS Console: Verify Operator user cannot add new user"
+ local user2=$TKS_INST-$RANDOM
+ local OP_TYPE='OP_ADD'
+ local OP_SCOPE='users'
+ local RS_ID=$user2
+ local fullname=$user2
+ local password=$user2
+ local email=$user2@example.org
+ local phone=''
+ local state=''
+ local groups='Data Recovery Manager Agents'
+ local userType=''
+ local test_out=add.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_operator:$valid_operator_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&fullname=$fullname&password=$password&email=$email&phone=$phone&state=$state&groups=$groups&userType=$userType\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_operator:$valid_operator_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID&fullname=$fullname&password=$password&email=$email&phone=$phone&state=$state&groups=$groups&userType=$userType\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertGrep "You are not authorized to perform this operation" "$TmpDir/$test_out"
+ rlLog "List users"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='users'
+ local test_out=$OP_TYPE\.out
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" \
+ -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "List Users"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertNotGrep "$user2" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-0012: TKS Console: Verify Agent user cannot add new group"
+ local group2=$TKS_INST-group-$RANDOM
+ local OP_TYPE='OP_ADD'
+ local OP_SCOPE='groups'
+ local RS_ID=$group2
+ local desc=$group2
+ local user=$user2
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_agent:$valid_agent_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Add Group $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_agent:$valid_agent_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Add Group $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertGrep "You are not authorized to perform this operation" "$TmpDir/$test_out"
+ rlLog "Verify group is added"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='groups'
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertNotGrep "$group2" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-0013: TKS Console: Verify Audit user cannot add new group"
+ local group2=$TKS_INST-group-$RANDOM
+ local OP_TYPE='OP_ADD'
+ local OP_SCOPE='groups'
+ local RS_ID=$group2
+ local desc=$group2
+ local user=$user2
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_audit:$valid_audit_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Add Group $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_audit:$valid_audit_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Add Group $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertGrep "You are not authorized to perform this operation" "$TmpDir/$test_out"
+ rlLog "Verify group is added"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='groups'
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertNotGrep "$group2" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-0014: TKS Console: Verify Operator user cannot add new group"
+ local group2=$TKS_INST-group-$RANDOM
+ local OP_TYPE='OP_ADD'
+ local OP_SCOPE='groups'
+ local RS_ID=$group2
+ local desc=$group2
+ local user=$user2
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_operator:$valid_operator_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Add Group $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_operator:$valid_operator_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Add Group $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertGrep "You are not authorized to perform this operation" "$TmpDir/$test_out"
+ rlLog "Verify group is added"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='groups'
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertNotGrep "$group2" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-0015: TKS Console: Verify Agent User cannot delete existing group"
+ local OP_TYPE='OP_DELETE'
+ local OP_SCOPE='groups'
+ local RS_ID=$group1
+ local test_out=groupdelete.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_agent:$valid_agent_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_agent:$valid_agent_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlLog "Verify group is deleted"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='groups'
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertNotGrep "$group1" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartSetup "TKS Console: Add Group"
+ local group1=$TKS_INST-group-$RANDOM
+ local OP_TYPE='OP_ADD'
+ local OP_SCOPE='groups'
+ local RS_ID=$group1
+ local desc=$group1
+ local user=$user1
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Add Group $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Add Group $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlLog "Verify group is added"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='groups'
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertGrep "$group1" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-0016: TKS Console: Verify Agent User cannot delete existing group"
+ local OP_TYPE='OP_DELETE'
+ local OP_SCOPE='groups'
+ local RS_ID=$group1
+ local test_out=groupdelete.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_agent:$valid_agent_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_agent:$valid_agent_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertGrep "You are not authorized to perform this operation" "$TmpDir/$test_out"
+ rlLog "Verify group is not deleted"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='groups'
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertGrep "$group1" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-0017: TKS Console: Verify Audit User cannot delete existing group"
+ local OP_TYPE='OP_DELETE'
+ local OP_SCOPE='groups'
+ local RS_ID=$group1
+ local test_out=groupdelete.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_audit:$valid_audit_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_audit:$valid_audit_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertGrep "You are not authorized to perform this operation" "$TmpDir/$test_out"
+ rlLog "Verify group is not deleted"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='groups'
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertGrep "$group1" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartTest "pki_tks_ad_usergroups-0018: TKS Console: Verify Operator User cannot delete existing group"
+ local OP_TYPE='OP_DELETE'
+ local OP_SCOPE='groups'
+ local RS_ID=$group1
+ local test_out=groupdelete.out
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_operator:$valid_operator_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_operator:$valid_operator_pwd" -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE&RS_ID=$RS_ID\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Delete $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlAssertGrep "You are not authorized to perform this operation" "$TmpDir/$test_out"
+ rlLog "Verify group is not deleted"
+ local OP_TYPE='OP_SEARCH'
+ local OP_SCOPE='groups'
+ rlLog "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlRun "curl --capath $CERTDB_DIR \
+ --dump-header $admin_out \
+ --basic --user "$valid_admin:$valid_admin_pwd" \
+ -d \"OP_TYPE=$OP_TYPE&OP_SCOPE=$OP_SCOPE\" -k \"https://$tmp_tks_host:$target_secure_port/tks/ug\" > $TmpDir/$test_out" 0 "Search for $group1"
+ rlAssertGrep "HTTP/1.1 200 OK" "$admin_out"
+ rlRun "process_curl_output $TmpDir/$test_out" 0 "Process curl output file"
+ rlAssertGrep "$group1" "$TmpDir/$test_out"
+ rlPhaseEnd
+
+ rlPhaseStartCleanup "Delete temporary dir and enable nonce"
+ rlRun "popd"
+ rlRun "rm -r $TmpDir" 0 "Removing tmp directory"
+ enable_ca_nonce $tomcat_name
+ rlPhaseEnd
+
+}
+verify_cert()
+{
+ local serial_number=$1
+ local request_dn=$2
+ STRIP_HEX=$(echo $serial_number | cut -dx -f2)
+ CONV_LOW_VAL=${STRIP_HEX,,}
+ rlRun "pki -h $tmp_ca_host -p $target_unsecure_port cert-show $serial_number > $cert_show_out" 0 "Executing pki cert-show $serial_number"
+ rlAssertGrep "Serial Number: 0x$CONV_LOW_VAL" "$cert_show_out"
+ rlAssertGrep "Issuer: CN=PKI $CA_INST Signing Cert,O=redhat" "$cert_show_out"
+ rlAssertGrep "Subject: $request_dn" "$cert_show_out"
+ rlAssertGrep "Status: VALID" "$cert_show_out"
+}
diff --git a/tests/dogtag/runtest.sh b/tests/dogtag/runtest.sh
index c1faea6fc..e20887bf9 100755
--- a/tests/dogtag/runtest.sh
+++ b/tests/dogtag/runtest.sh
@@ -218,6 +218,10 @@
. ./acceptance/legacy/ocsp-tests/logs/ocsp-ad-logs.sh
. ./acceptance/legacy/ocsp-tests/internaldb/ocsp-ad-internaldb.sh
. ./acceptance/legacy/ocsp-tests/agent/ocsp-ag-tests.sh
+. ./acceptance/legacy/tks-tests/usergroups/tks-ad-usergroups.sh
+. ./acceptance/legacy/tks-tests/logs/tks-ad-logs.sh
+. ./acceptance/legacy/tks-tests/internaldb/tks-ad-internaldb.sh
+. ./acceptance/legacy/tks-tests/acls/tks-ad-acls.sh
. ./acceptance/bugzilla/bug_setup.sh
. ./acceptance/bugzilla/bug_uninstall.sh
. ./acceptance/bugzilla/tomcatjss-bugs/bug-1058366.sh
@@ -1671,6 +1675,26 @@ rlJournalStart
subsystemType=ocsp
run_ocsp-ag_tests $subsystemType $MYROLE
fi
+ PKI_LEGACY_TKS_AD_USERGROUPS_UPPERCASE=$(echo $PKI_LEGACY_TKS_AD_USERGROUPS | tr [a-z] [A-Z])
+ if [ "$PKI_LEGACY_TKS_AD_USERGROUPS_UPPERCASE" = "TRUE" ] || [ "$TEST_ALL_UPPERCASE" = "TRUE" ]; then
+ subsystemType=tks
+ run_tks-ad_usergroups $subsystemType $MYROLE
+ fi
+ PKI_LEGACY_TKS_AD_ACLS_UPPERCASE=$(echo $PKI_LEGACY_TKS_AD_ACLS | tr [a-z] [A-Z])
+ if [ "$PKI_LEGACY_TKS_AD_ACLS_UPPERCASE" = "TRUE" ] || [ "$TEST_ALL_UPPERCASE" = "TRUE" ]; then
+ subsystemType=tks
+ run_admin-tks-acl_tests $subsystemType $MYROLE
+ fi
+ PKI_LEGACY_TKS_AD_LOGS_UPPERCASE=$(echo $PKI_LEGACY_TKS_AD_LOGS | tr [a-z] [A-Z])
+ if [ "$PKI_LEGACY_TKS_AD_LOGS_UPPERCASE" = "TRUE" ] || [ "$TEST_ALL_UPPERCASE" = "TRUE" ]; then
+ subsystemType=tks
+ run_admin-tks-log_tests $subsystemType $MYROLE
+ fi
+ PKI_LEGACY_TKS_AD_INTERNALDB_UPPERCASE=$(echo $PKI_LEGACY_TKS_AD_INTERNALDB | tr [a-z] [A-Z])
+ if [ "$PKI_LEGACY_TKS_AD_INTERNALDB_UPPERCASE" = "TRUE" ] || [ "$TEST_ALL_UPPERCASE" = "TRUE" ]; then
+ subsystemType=tks
+ run_admin-tks-internaldb_tests $subsystemType $MYROLE
+ fi
rlPhaseEnd
######## DEV UNIT TESTS ############
DEV_JAVA_TESTS_UPPERCASE=$(echo $DEV_JAVA_TESTS | tr [a-z] [A-Z])