From 5bee29e036d9212319b4b752cb3869fe12c80412 Mon Sep 17 00:00:00 2001
From: Mike Mazur
Date: Mon, 9 Mar 2009 08:07:12 +0000
Subject: Refactor login test class.
There were multiple tests in one test method (T011_Auth_Login). This
test has been refactored into multiple tests. Common setup code was
placed into a SetUp method executed before each test.
---
.../Communications/Tests/LoginServiceTests.cs | 241 +++++++++++----------
1 file changed, 126 insertions(+), 115 deletions(-)
(limited to 'OpenSim/Framework/Communications')
diff --git a/OpenSim/Framework/Communications/Tests/LoginServiceTests.cs b/OpenSim/Framework/Communications/Tests/LoginServiceTests.cs
index d8d08c9..daa2a89 100644
--- a/OpenSim/Framework/Communications/Tests/LoginServiceTests.cs
+++ b/OpenSim/Framework/Communications/Tests/LoginServiceTests.cs
@@ -47,46 +47,54 @@ namespace OpenSim.Framework.Communications.Tests
[TestFixture]
public class LoginServiceTests
{
- ///
- /// Test the normal response to a login. Does not test authentication.
- ///
- [Test]
- public void T010_NormalLoginResponse()
+ private string m_firstName = "Adam";
+ private string m_lastName = "West";
+ private string m_regionExternalName = "localhost";
+
+ private IPEndPoint m_capsEndPoint;
+ private CommunicationsManager m_commsManager;
+ private TestLoginToRegionConnector m_regionConnector;
+ private LocalUserServices m_localUserServices;
+ private LoginService m_loginService;
+ private UserProfileData m_userProfileData;
+
+ [SetUp]
+ public void SetUpLoginEnviroment()
{
- //log4net.Config.XmlConfigurator.Configure();
+ m_capsEndPoint = new IPEndPoint(IPAddress.Loopback, 9123);
+ m_commsManager = new TestCommunicationsManager(new NetworkServersInfo(42, 43));
+ m_regionConnector = new TestLoginToRegionConnector();
- string firstName = "Timmy";
- string lastName = "Mallet";
- string regionExternalName = "localhost";
- IPEndPoint capsEndPoint = new IPEndPoint(IPAddress.Loopback, 9123);
+ m_regionConnector.AddRegion(new RegionInfo(42, 43, m_capsEndPoint, m_regionExternalName));
- CommunicationsManager commsManager
- = new TestCommunicationsManager(new NetworkServersInfo(42, 43));
-
- //commsManager.GridService.RegisterRegion(
- // new RegionInfo(42, 43, capsEndPoint, regionExternalName));
- //commsManager.GridService.RegionLoginsEnabled = true;
+ m_localUserServices = (LocalUserServices) m_commsManager.UserService;
+ m_localUserServices.AddUser(m_firstName,m_lastName,"boingboing","abc@ftw.com",42,43);
- //LoginService loginService
- // = new LocalLoginService(
- // (UserManagerBase)commsManager.UserService, "Hello folks", commsManager.InterServiceInventoryService,
- // (LocalBackEndServices)commsManager.GridService,
- // commsManager.NetworkServersInfo, false, new LibraryRootFolder(String.Empty));
+ m_loginService = new LLStandaloneLoginService((UserManagerBase) m_localUserServices, "Hello folks", m_commsManager.InterServiceInventoryService,
+ m_commsManager.NetworkServersInfo, true, new LibraryRootFolder(String.Empty), m_regionConnector);
- TestLoginToRegionConnector regionConnector = new TestLoginToRegionConnector();
- regionConnector.AddRegion(new RegionInfo(42, 43, capsEndPoint, regionExternalName));
+ m_userProfileData = m_localUserServices.GetUserProfile(m_firstName, m_lastName);
+ }
- LoginService loginService = new LLStandaloneLoginService((UserManagerBase)commsManager.UserService, "Hello folks", commsManager.InterServiceInventoryService,
- commsManager.NetworkServersInfo, false, new LibraryRootFolder(String.Empty), regionConnector);
+ ///
+ /// Test the normal response to a login. Does not test authentication.
+ ///
+ [Test]
+ public void TestUnauthenticatedLogin()
+ {
+ // We want to use our own LoginService for this test, one that
+ // doesn't require authentication.
+ LoginService loginService = new LLStandaloneLoginService((UserManagerBase)m_commsManager.UserService, "Hello folks", m_commsManager.InterServiceInventoryService,
+ m_commsManager.NetworkServersInfo, false, new LibraryRootFolder(String.Empty), m_regionConnector);
Hashtable loginParams = new Hashtable();
- loginParams["first"] = firstName;
- loginParams["last"] = lastName;
+ loginParams["first"] = m_firstName;
+ loginParams["last"] = m_lastName;
loginParams["passwd"] = "boingboing";
ArrayList sendParams = new ArrayList();
sendParams.Add(loginParams);
- sendParams.Add(capsEndPoint); // is this parameter correct?
+ sendParams.Add(m_capsEndPoint); // is this parameter correct?
sendParams.Add(new Uri("http://localhost:8002/")); // is this parameter correct?
XmlRpcRequest request = new XmlRpcRequest("login_to_simulator", sendParams);
@@ -94,78 +102,48 @@ namespace OpenSim.Framework.Communications.Tests
XmlRpcResponse response = loginService.XmlRpcLoginMethod(request);
Hashtable responseData = (Hashtable)response.Value;
- Assert.That(responseData["first_name"], Is.EqualTo(firstName));
- Assert.That(responseData["last_name"], Is.EqualTo(lastName));
+ Assert.That(responseData["first_name"], Is.EqualTo(m_firstName));
+ Assert.That(responseData["last_name"], Is.EqualTo(m_lastName));
Assert.That(
responseData["circuit_code"], Is.GreaterThanOrEqualTo(0) & Is.LessThanOrEqualTo(Int32.MaxValue));
Regex capsSeedPattern
= new Regex("^http://"
- + regionExternalName
+ + m_regionExternalName
+ ":9000/CAPS/[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{8}0000/$");
Assert.That(capsSeedPattern.IsMatch((string)responseData["seed_capability"]), Is.True);
}
[Test]
- public void T011_Auth_Login()
+ public void TestAuthenticatedLoginSuccess()
{
- string firstName = "Adam";
- string lastName = "West";
- string regionExternalName = "localhost";
- IPEndPoint capsEndPoint = new IPEndPoint(IPAddress.Loopback, 9123);
-
- CommunicationsManager commsManager
- = new TestCommunicationsManager(new NetworkServersInfo(42, 43));
-
- LocalUserServices lus = (LocalUserServices)commsManager.UserService;
-
- lus.AddUser(firstName,lastName,"boingboing","abc@ftw.com",42,43);
-
- //commsManager.GridService.RegisterRegion(
- // new RegionInfo(42, 43, capsEndPoint, regionExternalName));
- //commsManager.GridService.RegionLoginsEnabled = true;
-
- //LoginService loginService
- // = new LocalLoginService(
- // (UserManagerBase)lus, "Hello folks", commsManager.InterServiceInventoryService,
- // (LocalBackEndServices)commsManager.GridService,
- // commsManager.NetworkServersInfo, true, new LibraryRootFolder(String.Empty));
-
- TestLoginToRegionConnector regionConnector = new TestLoginToRegionConnector();
- regionConnector.AddRegion(new RegionInfo(42, 43, capsEndPoint, regionExternalName));
-
- LoginService loginService = new LLStandaloneLoginService((UserManagerBase) lus, "Hello folks", commsManager.InterServiceInventoryService,
- commsManager.NetworkServersInfo, true, new LibraryRootFolder(String.Empty), regionConnector);
-
// TODO: Not check inventory part of response yet.
// TODO: Not checking all of login response thoroughly yet.
// 1) Test for positive authentication
Hashtable loginParams = new Hashtable();
- loginParams["first"] = firstName;
- loginParams["last"] = lastName;
+ loginParams["first"] = m_firstName;
+ loginParams["last"] = m_lastName;
loginParams["passwd"] = "boingboing";
ArrayList sendParams = new ArrayList();
sendParams.Add(loginParams);
- sendParams.Add(capsEndPoint); // is this parameter correct?
+ sendParams.Add(m_capsEndPoint); // is this parameter correct?
sendParams.Add(new Uri("http://localhost:8002/")); // is this parameter correct?
XmlRpcRequest request = new XmlRpcRequest("login_to_simulator", sendParams);
- XmlRpcResponse response = loginService.XmlRpcLoginMethod(request);
+ XmlRpcResponse response = m_loginService.XmlRpcLoginMethod(request);
Hashtable responseData = (Hashtable)response.Value;
- UserProfileData uprof = lus.GetUserProfile(firstName,lastName);
-
- UserAgentData uagent = uprof.CurrentAgent;
+ UserAgentData uagent = m_userProfileData.CurrentAgent;
Assert.That(uagent,Is.Not.Null);
Assert.That(responseData["first_name"], Is.Not.Null);
- Assert.That(responseData["first_name"], Is.EqualTo(firstName));
- Assert.That(responseData["last_name"], Is.EqualTo(lastName));
+ Assert.That(responseData["first_name"], Is.EqualTo(m_firstName));
+ Assert.That(responseData["last_name"], Is.EqualTo(m_lastName));
Assert.That(responseData["agent_id"], Is.EqualTo(uagent.ProfileID.ToString()));
Assert.That(responseData["session_id"], Is.EqualTo(uagent.SessionID.ToString()));
Assert.That(responseData["secure_session_id"], Is.EqualTo(uagent.SecureSessionID.ToString()));
@@ -180,34 +158,38 @@ namespace OpenSim.Framework.Communications.Tests
Regex capsSeedPattern
= new Regex("^http://"
- + regionExternalName
+ + m_regionExternalName
+ ":9000/CAPS/[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{8}0000/$");
Assert.That(capsSeedPattern.IsMatch((string)responseData["seed_capability"]), Is.True);
+ }
+ [Test]
+ public void TestAuthenticatedLoginForBuddies()
+ {
// 1.1) Test for budddies!
- lus.AddUser("Friend","Number1","boingboing","abc@ftw.com",42,43);
- lus.AddUser("Friend","Number2","boingboing","abc@ftw.com",42,43);
+ m_localUserServices.AddUser("Friend","Number1","boingboing","abc@ftw.com",42,43);
+ m_localUserServices.AddUser("Friend","Number2","boingboing","abc@ftw.com",42,43);
- UserProfileData friend1 = lus.GetUserProfile("Friend","Number1");
- UserProfileData friend2 = lus.GetUserProfile("Friend","Number2");
- lus.AddNewUserFriend(friend1.ID,uprof.ID,1);
- lus.AddNewUserFriend(friend1.ID,friend2.ID,2);
+ UserProfileData friend1 = m_localUserServices.GetUserProfile("Friend","Number1");
+ UserProfileData friend2 = m_localUserServices.GetUserProfile("Friend","Number2");
+ m_localUserServices.AddNewUserFriend(friend1.ID,m_userProfileData.ID,1);
+ m_localUserServices.AddNewUserFriend(friend1.ID,friend2.ID,2);
- loginParams = new Hashtable();
+ Hashtable loginParams = new Hashtable();
loginParams["first"] = "Friend";
loginParams["last"] = "Number1";
loginParams["passwd"] = "boingboing";
- sendParams = new ArrayList();
+ ArrayList sendParams = new ArrayList();
sendParams.Add(loginParams);
- sendParams.Add(capsEndPoint); // is this parameter correct?
+ sendParams.Add(m_capsEndPoint); // is this parameter correct?
sendParams.Add(new Uri("http://localhost:8002/")); // is this parameter correct?
- request = new XmlRpcRequest("login_to_simulator", sendParams);
+ XmlRpcRequest request = new XmlRpcRequest("login_to_simulator", sendParams);
- response = loginService.XmlRpcLoginMethod(request);
- responseData = (Hashtable)response.Value;
+ XmlRpcResponse response = m_loginService.XmlRpcLoginMethod(request);
+ Hashtable responseData = (Hashtable)response.Value;
ArrayList friendslist = (ArrayList) responseData["buddy-list"];
@@ -217,89 +199,118 @@ namespace OpenSim.Framework.Communications.Tests
Hashtable buddy1 = (Hashtable) friendslist[0];
Hashtable buddy2 = (Hashtable) friendslist[1];
Assert.That(friendslist.Count, Is.EqualTo(2));
- Assert.That(uprof.ID.ToString(), Is.EqualTo(buddy1["buddy_id"]) | Is.EqualTo(buddy2["buddy_id"]));
+ Assert.That(m_userProfileData.ID.ToString(), Is.EqualTo(buddy1["buddy_id"]) | Is.EqualTo(buddy2["buddy_id"]));
Assert.That(friend2.ID.ToString(), Is.EqualTo(buddy1["buddy_id"]) | Is.EqualTo(buddy2["buddy_id"]));
+ }
+
+ [Test]
+ public void TestAuthenticatedLoginBadUsername()
+ {
// 2) Test for negative authentication
//
string error_auth_message = "Could not authenticate your avatar. Please check your username and password, and check the grid if problems persist.";
- string error_xml_message = "Error connecting to grid. Could not percieve credentials from login XML.";
- string error_already_logged = "You appear to be already logged in. " +
- "If this is not the case please wait for your session to timeout. " +
- "If this takes longer than a few minutes please contact the grid owner. " +
- "Please wait 5 minutes if you are going to connect to a region nearby to the region you were at previously.";
//string error_region_unavailable = "The region you are attempting to log into is not responding. Please select another region and try again.";
// 2.1) Test for wrong user name
- loginParams = new Hashtable();
- loginParams["first"] = lastName;
- loginParams["last"] = firstName;
+ Hashtable loginParams = new Hashtable();
+ loginParams["first"] = m_lastName;
+ loginParams["last"] = m_firstName;
loginParams["passwd"] = "boingboing";
- sendParams = new ArrayList();
+ ArrayList sendParams = new ArrayList();
sendParams.Add(loginParams);
- sendParams.Add(capsEndPoint); // is this parameter correct?
+ sendParams.Add(m_capsEndPoint); // is this parameter correct?
sendParams.Add(new Uri("http://localhost:8002/")); // is this parameter correct?
- request = new XmlRpcRequest("login_to_simulator", sendParams);
+ XmlRpcRequest request = new XmlRpcRequest("login_to_simulator", sendParams);
- response = loginService.XmlRpcLoginMethod(request);
- responseData = (Hashtable)response.Value;
+ XmlRpcResponse response = m_loginService.XmlRpcLoginMethod(request);
+ Hashtable responseData = (Hashtable)response.Value;
Assert.That(responseData["message"], Is.EqualTo(error_auth_message));
+ }
+
+ [Test]
+ public void TestAuthenticatedLoginBadPassword()
+ {
+ string error_auth_message = "Could not authenticate your avatar. Please check your username and password, and check the grid if problems persist.";
// 2.2) Test for wrong password
- loginParams = new Hashtable();
+ Hashtable loginParams = new Hashtable();
loginParams["first"] = "Friend";
loginParams["last"] = "Number2";
loginParams["passwd"] = "boing";
- sendParams = new ArrayList();
+ ArrayList sendParams = new ArrayList();
sendParams.Add(loginParams);
- sendParams.Add(capsEndPoint); // is this parameter correct?
+ sendParams.Add(m_capsEndPoint); // is this parameter correct?
sendParams.Add(new Uri("http://localhost:8002/")); // is this parameter correct?
- request = new XmlRpcRequest("login_to_simulator", sendParams);
+ XmlRpcRequest request = new XmlRpcRequest("login_to_simulator", sendParams);
- response = loginService.XmlRpcLoginMethod(request);
- responseData = (Hashtable)response.Value;
+ XmlRpcResponse response = m_loginService.XmlRpcLoginMethod(request);
+ Hashtable responseData = (Hashtable)response.Value;
Assert.That(responseData["message"], Is.EqualTo(error_auth_message));
+ }
+
+ [Test]
+ public void TestAuthenticatedLoginBadXml()
+ {
+ string error_xml_message = "Error connecting to grid. Could not percieve credentials from login XML.";
// 2.3) Bad XML
- loginParams = new Hashtable();
+ Hashtable loginParams = new Hashtable();
loginParams["first"] = "Friend";
loginParams["banana"] = "Banana";
loginParams["passwd"] = "boingboing";
-
- sendParams = new ArrayList();
+
+ ArrayList sendParams = new ArrayList();
sendParams.Add(loginParams);
- sendParams.Add(capsEndPoint); // is this parameter correct?
+ sendParams.Add(m_capsEndPoint); // is this parameter correct?
sendParams.Add(new Uri("http://localhost:8002/")); // is this parameter correct?
- request = new XmlRpcRequest("login_to_simulator", sendParams);
+ XmlRpcRequest request = new XmlRpcRequest("login_to_simulator", sendParams);
- response = loginService.XmlRpcLoginMethod(request);
- responseData = (Hashtable)response.Value;
+ XmlRpcResponse response = m_loginService.XmlRpcLoginMethod(request);
+ Hashtable responseData = (Hashtable)response.Value;
Assert.That(responseData["message"], Is.EqualTo(error_xml_message));
-
+
+ }
+
+ [Test]
+ public void TestAuthenticatedLoginAlreadyLoggedIn()
+ {
+ string error_already_logged = "You appear to be already logged in. " +
+ "If this is not the case please wait for your session to timeout. " +
+ "If this takes longer than a few minutes please contact the grid owner. " +
+ "Please wait 5 minutes if you are going to connect to a region nearby to the region you were at previously.";
// 2.4) Already logged in and sucessfull post login
- loginParams = new Hashtable();
+ Hashtable loginParams = new Hashtable();
loginParams["first"] = "Adam";
loginParams["last"] = "West";
loginParams["passwd"] = "boingboing";
- sendParams = new ArrayList();
+ ArrayList sendParams = new ArrayList();
sendParams.Add(loginParams);
- sendParams.Add(capsEndPoint); // is this parameter correct?
+ sendParams.Add(m_capsEndPoint); // is this parameter correct?
sendParams.Add(new Uri("http://localhost:8002/")); // is this parameter correct?
+ // First we log in.
+ XmlRpcRequest request = new XmlRpcRequest("login_to_simulator", sendParams);
+ XmlRpcResponse response = m_loginService.XmlRpcLoginMethod(request);
+ Hashtable responseData = (Hashtable)response.Value;
+ Assert.That(responseData["message"], Is.EqualTo("Hello folks"));
+
+ // Then we try again, this time expecting failure.
request = new XmlRpcRequest("login_to_simulator", sendParams);
- response = loginService.XmlRpcLoginMethod(request);
+ response = m_loginService.XmlRpcLoginMethod(request);
responseData = (Hashtable)response.Value;
Assert.That(responseData["message"], Is.EqualTo(error_already_logged));
+ // Finally the third time we should be able to get right back in.
request = new XmlRpcRequest("login_to_simulator", sendParams);
- response = loginService.XmlRpcLoginMethod(request);
+ response = m_loginService.XmlRpcLoginMethod(request);
responseData = (Hashtable)response.Value;
Assert.That(responseData["message"], Is.EqualTo("Hello folks"));
}
--
cgit v1.1