diff options
author | David Walter Seikel | 2016-11-03 21:44:39 +1000 |
---|---|---|
committer | David Walter Seikel | 2016-11-03 21:44:39 +1000 |
commit | 134f86e8d5c414409631b25b8c6f0ee45fbd8631 (patch) | |
tree | 216b89d3fb89acfb81be1e440c25c41ab09fa96d /OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests | |
parent | More changing to production grid. Double oops. (diff) | |
download | opensim-SC_OLD-134f86e8d5c414409631b25b8c6f0ee45fbd8631.zip opensim-SC_OLD-134f86e8d5c414409631b25b8c6f0ee45fbd8631.tar.gz opensim-SC_OLD-134f86e8d5c414409631b25b8c6f0ee45fbd8631.tar.bz2 opensim-SC_OLD-134f86e8d5c414409631b25b8c6f0ee45fbd8631.tar.xz |
Initial update to OpenSim 0.8.2.1 source code.
Diffstat (limited to 'OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests')
-rw-r--r-- | OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests/GroupsModuleTests.cs | 214 |
1 files changed, 209 insertions, 5 deletions
diff --git a/OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests/GroupsModuleTests.cs b/OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests/GroupsModuleTests.cs index c1bdacb..9a42bac 100644 --- a/OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests/GroupsModuleTests.cs +++ b/OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests/GroupsModuleTests.cs | |||
@@ -26,15 +26,25 @@ | |||
26 | */ | 26 | */ |
27 | 27 | ||
28 | using System; | 28 | using System; |
29 | using System.Collections; | ||
30 | using System.Collections.Generic; | ||
31 | using System.Net; | ||
29 | using System.Reflection; | 32 | using System.Reflection; |
30 | using Nini.Config; | 33 | using Nini.Config; |
31 | using NUnit.Framework; | 34 | using NUnit.Framework; |
32 | using OpenMetaverse; | 35 | using OpenMetaverse; |
36 | using OpenMetaverse.Messages.Linden; | ||
37 | using OpenMetaverse.Packets; | ||
38 | using OpenMetaverse.StructuredData; | ||
33 | using OpenSim.Framework; | 39 | using OpenSim.Framework; |
34 | using OpenSim.Framework.Communications; | 40 | using OpenSim.Framework.Servers; |
41 | using OpenSim.Framework.Servers.HttpServer; | ||
42 | using OpenSim.Region.ClientStack.Linden; | ||
43 | using OpenSim.Region.CoreModules.Avatar.InstantMessage; | ||
44 | using OpenSim.Region.CoreModules.Framework; | ||
35 | using OpenSim.Region.Framework.Scenes; | 45 | using OpenSim.Region.Framework.Scenes; |
46 | using OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups; | ||
36 | using OpenSim.Tests.Common; | 47 | using OpenSim.Tests.Common; |
37 | using OpenSim.Tests.Common.Mock; | ||
38 | 48 | ||
39 | namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups.Tests | 49 | namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups.Tests |
40 | { | 50 | { |
@@ -44,11 +54,28 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups.Tests | |||
44 | [TestFixture] | 54 | [TestFixture] |
45 | public class GroupsModuleTests : OpenSimTestCase | 55 | public class GroupsModuleTests : OpenSimTestCase |
46 | { | 56 | { |
57 | [SetUp] | ||
58 | public override void SetUp() | ||
59 | { | ||
60 | base.SetUp(); | ||
61 | |||
62 | uint port = 9999; | ||
63 | uint sslPort = 9998; | ||
64 | |||
65 | // This is an unfortunate bit of clean up we have to do because MainServer manages things through static | ||
66 | // variables and the VM is not restarted between tests. | ||
67 | MainServer.RemoveHttpServer(port); | ||
68 | |||
69 | BaseHttpServer server = new BaseHttpServer(port, false, sslPort, ""); | ||
70 | MainServer.AddHttpServer(server); | ||
71 | MainServer.Instance = server; | ||
72 | } | ||
73 | |||
47 | [Test] | 74 | [Test] |
48 | public void TestBasic() | 75 | public void TestSendAgentGroupDataUpdate() |
49 | { | 76 | { |
50 | TestHelpers.InMethod(); | 77 | TestHelpers.InMethod(); |
51 | // log4net.Config.XmlConfigurator.Configure(); | 78 | // TestHelpers.EnableLogging(); |
52 | 79 | ||
53 | TestScene scene = new SceneHelpers().SetupScene(); | 80 | TestScene scene = new SceneHelpers().SetupScene(); |
54 | IConfigSource configSource = new IniConfigSource(); | 81 | IConfigSource configSource = new IniConfigSource(); |
@@ -56,8 +83,185 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups.Tests | |||
56 | config.Set("Enabled", true); | 83 | config.Set("Enabled", true); |
57 | config.Set("Module", "GroupsModule"); | 84 | config.Set("Module", "GroupsModule"); |
58 | config.Set("DebugEnabled", true); | 85 | config.Set("DebugEnabled", true); |
86 | |||
87 | GroupsModule gm = new GroupsModule(); | ||
88 | EventQueueGetModule eqgm = new EventQueueGetModule(); | ||
89 | |||
90 | // We need a capabilities module active so that adding the scene presence creates an event queue in the | ||
91 | // EventQueueGetModule | ||
59 | SceneHelpers.SetupSceneModules( | 92 | SceneHelpers.SetupSceneModules( |
60 | scene, configSource, new object[] { new MockGroupsServicesConnector() }); | 93 | scene, configSource, gm, new MockGroupsServicesConnector(), new CapabilitiesModule(), eqgm); |
94 | |||
95 | ScenePresence sp = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseStem("1")); | ||
96 | |||
97 | gm.SendAgentGroupDataUpdate(sp.ControllingClient); | ||
98 | |||
99 | Hashtable eventsResponse = eqgm.GetEvents(UUID.Zero, sp.UUID); | ||
100 | |||
101 | Assert.That((int)eventsResponse["int_response_code"], Is.EqualTo((int)HttpStatusCode.OK)); | ||
102 | |||
103 | // Console.WriteLine("Response [{0}]", (string)eventsResponse["str_response_string"]); | ||
104 | |||
105 | OSDMap rawOsd = (OSDMap)OSDParser.DeserializeLLSDXml((string)eventsResponse["str_response_string"]); | ||
106 | OSDArray eventsOsd = (OSDArray)rawOsd["events"]; | ||
107 | |||
108 | bool foundUpdate = false; | ||
109 | foreach (OSD osd in eventsOsd) | ||
110 | { | ||
111 | OSDMap eventOsd = (OSDMap)osd; | ||
112 | |||
113 | if (eventOsd["message"] == "AgentGroupDataUpdate") | ||
114 | foundUpdate = true; | ||
115 | } | ||
116 | |||
117 | Assert.That(foundUpdate, Is.True, "Did not find AgentGroupDataUpdate in response"); | ||
118 | |||
119 | // TODO: More checking of more actual event data. | ||
120 | } | ||
121 | |||
122 | [Test] | ||
123 | public void TestSendGroupNotice() | ||
124 | { | ||
125 | TestHelpers.InMethod(); | ||
126 | // TestHelpers.EnableLogging(); | ||
127 | |||
128 | TestScene scene = new SceneHelpers().SetupScene(); | ||
129 | |||
130 | MessageTransferModule mtm = new MessageTransferModule(); | ||
131 | GroupsModule gm = new GroupsModule(); | ||
132 | GroupsMessagingModule gmm = new GroupsMessagingModule(); | ||
133 | MockGroupsServicesConnector mgsc = new MockGroupsServicesConnector(); | ||
134 | |||
135 | IConfigSource configSource = new IniConfigSource(); | ||
136 | |||
137 | { | ||
138 | IConfig config = configSource.AddConfig("Messaging"); | ||
139 | config.Set("MessageTransferModule", mtm.Name); | ||
140 | } | ||
141 | |||
142 | { | ||
143 | IConfig config = configSource.AddConfig("Groups"); | ||
144 | config.Set("Enabled", true); | ||
145 | config.Set("Module", gm.Name); | ||
146 | config.Set("DebugEnabled", true); | ||
147 | config.Set("MessagingModule", gmm.Name); | ||
148 | config.Set("MessagingEnabled", true); | ||
149 | } | ||
150 | |||
151 | SceneHelpers.SetupSceneModules(scene, configSource, mgsc, mtm, gm, gmm); | ||
152 | |||
153 | UUID userId = TestHelpers.ParseTail(0x1); | ||
154 | string subjectText = "newman"; | ||
155 | string messageText = "Hello"; | ||
156 | string combinedSubjectMessage = string.Format("{0}|{1}", subjectText, messageText); | ||
157 | |||
158 | ScenePresence sp = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseTail(0x1)); | ||
159 | TestClient tc = (TestClient)sp.ControllingClient; | ||
160 | |||
161 | UUID groupID = gm.CreateGroup(tc, "group1", null, true, UUID.Zero, 0, true, true, true); | ||
162 | gm.JoinGroupRequest(tc, groupID); | ||
163 | |||
164 | // Create a second user who doesn't want to receive notices | ||
165 | ScenePresence sp2 = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseTail(0x2)); | ||
166 | TestClient tc2 = (TestClient)sp2.ControllingClient; | ||
167 | gm.JoinGroupRequest(tc2, groupID); | ||
168 | gm.SetGroupAcceptNotices(tc2, groupID, false, true); | ||
169 | |||
170 | List<GridInstantMessage> spReceivedMessages = new List<GridInstantMessage>(); | ||
171 | tc.OnReceivedInstantMessage += im => spReceivedMessages.Add(im); | ||
172 | |||
173 | List<GridInstantMessage> sp2ReceivedMessages = new List<GridInstantMessage>(); | ||
174 | tc2.OnReceivedInstantMessage += im => sp2ReceivedMessages.Add(im); | ||
175 | |||
176 | GridInstantMessage noticeIm = new GridInstantMessage(); | ||
177 | noticeIm.fromAgentID = userId.Guid; | ||
178 | noticeIm.toAgentID = groupID.Guid; | ||
179 | noticeIm.message = combinedSubjectMessage; | ||
180 | noticeIm.dialog = (byte)InstantMessageDialog.GroupNotice; | ||
181 | |||
182 | tc.HandleImprovedInstantMessage(noticeIm); | ||
183 | |||
184 | Assert.That(spReceivedMessages.Count, Is.EqualTo(1)); | ||
185 | Assert.That(spReceivedMessages[0].message, Is.EqualTo(combinedSubjectMessage)); | ||
186 | |||
187 | List<GroupNoticeData> notices = mgsc.GetGroupNotices(UUID.Zero, groupID); | ||
188 | Assert.AreEqual(1, notices.Count); | ||
189 | |||
190 | // OpenSimulator (possibly also SL) transport the notice ID as the session ID! | ||
191 | Assert.AreEqual(notices[0].NoticeID.Guid, spReceivedMessages[0].imSessionID); | ||
192 | |||
193 | Assert.That(sp2ReceivedMessages.Count, Is.EqualTo(0)); | ||
194 | } | ||
195 | |||
196 | /// <summary> | ||
197 | /// Run test with the MessageOnlineUsersOnly flag set. | ||
198 | /// </summary> | ||
199 | [Test] | ||
200 | public void TestSendGroupNoticeOnlineOnly() | ||
201 | { | ||
202 | TestHelpers.InMethod(); | ||
203 | // TestHelpers.EnableLogging(); | ||
204 | |||
205 | TestScene scene = new SceneHelpers().SetupScene(); | ||
206 | |||
207 | MessageTransferModule mtm = new MessageTransferModule(); | ||
208 | GroupsModule gm = new GroupsModule(); | ||
209 | GroupsMessagingModule gmm = new GroupsMessagingModule(); | ||
210 | |||
211 | IConfigSource configSource = new IniConfigSource(); | ||
212 | |||
213 | { | ||
214 | IConfig config = configSource.AddConfig("Messaging"); | ||
215 | config.Set("MessageTransferModule", mtm.Name); | ||
216 | } | ||
217 | |||
218 | { | ||
219 | IConfig config = configSource.AddConfig("Groups"); | ||
220 | config.Set("Enabled", true); | ||
221 | config.Set("Module", gm.Name); | ||
222 | config.Set("DebugEnabled", true); | ||
223 | config.Set("MessagingModule", gmm.Name); | ||
224 | config.Set("MessagingEnabled", true); | ||
225 | config.Set("MessageOnlineUsersOnly", true); | ||
226 | } | ||
227 | |||
228 | SceneHelpers.SetupSceneModules(scene, configSource, new MockGroupsServicesConnector(), mtm, gm, gmm); | ||
229 | |||
230 | UUID userId = TestHelpers.ParseTail(0x1); | ||
231 | string subjectText = "newman"; | ||
232 | string messageText = "Hello"; | ||
233 | string combinedSubjectMessage = string.Format("{0}|{1}", subjectText, messageText); | ||
234 | |||
235 | ScenePresence sp = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseTail(0x1)); | ||
236 | TestClient tc = (TestClient)sp.ControllingClient; | ||
237 | |||
238 | UUID groupID = gm.CreateGroup(tc, "group1", null, true, UUID.Zero, 0, true, true, true); | ||
239 | gm.JoinGroupRequest(tc, groupID); | ||
240 | |||
241 | // Create a second user who doesn't want to receive notices | ||
242 | ScenePresence sp2 = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseTail(0x2)); | ||
243 | TestClient tc2 = (TestClient)sp2.ControllingClient; | ||
244 | gm.JoinGroupRequest(tc2, groupID); | ||
245 | gm.SetGroupAcceptNotices(tc2, groupID, false, true); | ||
246 | |||
247 | List<GridInstantMessage> spReceivedMessages = new List<GridInstantMessage>(); | ||
248 | tc.OnReceivedInstantMessage += im => spReceivedMessages.Add(im); | ||
249 | |||
250 | List<GridInstantMessage> sp2ReceivedMessages = new List<GridInstantMessage>(); | ||
251 | tc2.OnReceivedInstantMessage += im => sp2ReceivedMessages.Add(im); | ||
252 | |||
253 | GridInstantMessage noticeIm = new GridInstantMessage(); | ||
254 | noticeIm.fromAgentID = userId.Guid; | ||
255 | noticeIm.toAgentID = groupID.Guid; | ||
256 | noticeIm.message = combinedSubjectMessage; | ||
257 | noticeIm.dialog = (byte)InstantMessageDialog.GroupNotice; | ||
258 | |||
259 | tc.HandleImprovedInstantMessage(noticeIm); | ||
260 | |||
261 | Assert.That(spReceivedMessages.Count, Is.EqualTo(1)); | ||
262 | Assert.That(spReceivedMessages[0].message, Is.EqualTo(combinedSubjectMessage)); | ||
263 | |||
264 | Assert.That(sp2ReceivedMessages.Count, Is.EqualTo(0)); | ||
61 | } | 265 | } |
62 | } | 266 | } |
63 | } \ No newline at end of file | 267 | } \ No newline at end of file |