diff --git a/OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests/GroupsModuleTests.cs b/OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests/GroupsModuleTests.cs
index 71f10986f2..b5a10afabd 100644
--- a/OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests/GroupsModuleTests.cs
+++ b/OpenSim/Region/OptionalModules/Avatar/XmlRpcGroups/Tests/GroupsModuleTests.cs
@@ -187,5 +187,76 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups.Tests
Assert.That(sp2ReceivedMessages.Count, Is.EqualTo(0));
}
+
+ ///
+ /// Run test with the MessageOnlineUsersOnly flag set.
+ ///
+ [Test]
+ public void TestSendGroupNoticeOnlineOnly()
+ {
+ TestHelpers.InMethod();
+ // TestHelpers.EnableLogging();
+
+ TestScene scene = new SceneHelpers().SetupScene();
+
+ MessageTransferModule mtm = new MessageTransferModule();
+ GroupsModule gm = new GroupsModule();
+ GroupsMessagingModule gmm = new GroupsMessagingModule();
+
+ IConfigSource configSource = new IniConfigSource();
+
+ {
+ IConfig config = configSource.AddConfig("Messaging");
+ config.Set("MessageTransferModule", mtm.Name);
+ }
+
+ {
+ IConfig config = configSource.AddConfig("Groups");
+ config.Set("Enabled", true);
+ config.Set("Module", gm.Name);
+ config.Set("DebugEnabled", true);
+ config.Set("MessagingModule", gmm.Name);
+ config.Set("MessagingEnabled", true);
+ config.Set("MessageOnlineUsersOnly", true);
+ }
+
+ SceneHelpers.SetupSceneModules(scene, configSource, new MockGroupsServicesConnector(), mtm, gm, gmm);
+
+ UUID userId = TestHelpers.ParseTail(0x1);
+ string subjectText = "newman";
+ string messageText = "Hello";
+ string combinedSubjectMessage = string.Format("{0}|{1}", subjectText, messageText);
+
+ ScenePresence sp = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseTail(0x1));
+ TestClient tc = (TestClient)sp.ControllingClient;
+
+ UUID groupID = gm.CreateGroup(tc, "group1", null, true, UUID.Zero, 0, true, true, true);
+ gm.JoinGroupRequest(tc, groupID);
+
+ // Create a second user who doesn't want to receive notices
+ ScenePresence sp2 = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseTail(0x2));
+ TestClient tc2 = (TestClient)sp2.ControllingClient;
+ gm.JoinGroupRequest(tc2, groupID);
+ gm.SetGroupAcceptNotices(tc2, groupID, false, true);
+
+ List spReceivedMessages = new List();
+ tc.OnReceivedInstantMessage += im => spReceivedMessages.Add(im);
+
+ List sp2ReceivedMessages = new List();
+ tc2.OnReceivedInstantMessage += im => sp2ReceivedMessages.Add(im);
+
+ GridInstantMessage noticeIm = new GridInstantMessage();
+ noticeIm.fromAgentID = userId.Guid;
+ noticeIm.toAgentID = groupID.Guid;
+ noticeIm.message = combinedSubjectMessage;
+ noticeIm.dialog = (byte)InstantMessageDialog.GroupNotice;
+
+ tc.HandleImprovedInstantMessage(noticeIm);
+
+ Assert.That(spReceivedMessages.Count, Is.EqualTo(1));
+ Assert.That(spReceivedMessages[0].message, Is.EqualTo(combinedSubjectMessage));
+
+ Assert.That(sp2ReceivedMessages.Count, Is.EqualTo(0));
+ }
}
}
\ No newline at end of file