Following scenarios are covered through this automation script.
- The business users need to login to multiple service providers via multiple identity providers.
- Rather than providing a multi-login option page with all the available identity provider, once redirected from the service provider, the system should find out who the identity provider corresponding to the user and directly redirect the user there.
- Deploy WSO2 Identity Server as an identity provider and register all the service providers and identity providers.
- For each identity provider, specify a home realm identifier.
- The service provider prior to redirecting the user to the WSO2 Identity Server must find out the home realm identifier corresponding to the user and send it as a query parameter.
- Looking at the home realm identifier in the request the WSO2 Identity Server redirect the user to the corresponding identity provider.
- In this case, there is a direct one-to-one mapping between the home realm identifier in the request and the home realm identifier value set under the identity provider configuration.
Following sub scenarios are covered in the automation script
-
Scenario 1 - Identify the IDP corresponding to the fidp using the Home Realm identifier and authenticate with the IDP.
-
Scenario 2 - If there is no IDP corresponding to the fidp, An option should be given to the user to provide a valid fidp
-
Scenario 3 - If there is no IDP corresponding to the fidp an option is provided to the user to enter a valid fidp. Once the user provides a valid fidp, user should be able to get authenticated via the IDP.
-
Scenario 4 - When the Home Realm identifier of the IDP contains special charachters, Still the user should be able to get authenticated via the IDP corresponding to the fidp.
-
Scenario 5 - User should be able to define an identifier for the Resident IDP, and authenticate via Resident IDP
Export input variables in the terminal **>>export serverHost=<is_host> serverPort=<is_port> tomcatHost= tomcatPort= tomcatUsername=<tomcat_user> tomcatPassword=<tomcat_password> ** Ex:
>>export serverHost=is.localtest.com serverPort=9454 tomcatHost=localhost tomcatPort=8090 tomcatUsername=test1 tomcatPassword=testpass
Important you have to enable the role manager-script and assign that role to the particular user in tomcat-users.xml file which is in <tomcat_home>/conf/ directory
Execute the scenario as follows. (This will execute the pre scenario script, the jmeter scenario and post scenario script)
ex:-> sh run-scenario.sh