aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Framework
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/Framework')
-rw-r--r--OpenSim/Region/Framework/Scenes/Tests/ScenePresenceTeleportTests.cs89
1 files changed, 87 insertions, 2 deletions
diff --git a/OpenSim/Region/Framework/Scenes/Tests/ScenePresenceTeleportTests.cs b/OpenSim/Region/Framework/Scenes/Tests/ScenePresenceTeleportTests.cs
index afd2779..936c2c0 100644
--- a/OpenSim/Region/Framework/Scenes/Tests/ScenePresenceTeleportTests.cs
+++ b/OpenSim/Region/Framework/Scenes/Tests/ScenePresenceTeleportTests.cs
@@ -30,6 +30,7 @@ using System.Collections.Generic;
30using System.IO; 30using System.IO;
31using System.Net; 31using System.Net;
32using System.Text; 32using System.Text;
33using System.Threading;
33using Nini.Config; 34using Nini.Config;
34using NUnit.Framework; 35using NUnit.Framework;
35using OpenMetaverse; 36using OpenMetaverse;
@@ -107,7 +108,7 @@ namespace OpenSim.Region.Framework.Scenes.Tests
107 } 108 }
108 109
109 [Test] 110 [Test]
110 public void TestSameSimulatorIsolatedRegions() 111 public void TestSameSimulatorIsolatedRegionsV1()
111 { 112 {
112 TestHelpers.InMethod(); 113 TestHelpers.InMethod();
113// TestHelpers.EnableLogging(); 114// TestHelpers.EnableLogging();
@@ -428,7 +429,7 @@ namespace OpenSim.Region.Framework.Scenes.Tests
428 } 429 }
429 430
430 [Test] 431 [Test]
431 public void TestSameSimulatorNeighbouringRegions() 432 public void TestSameSimulatorNeighbouringRegionsV1()
432 { 433 {
433 TestHelpers.InMethod(); 434 TestHelpers.InMethod();
434// TestHelpers.EnableLogging(); 435// TestHelpers.EnableLogging();
@@ -512,5 +513,89 @@ namespace OpenSim.Region.Framework.Scenes.Tests
512 513
513// TestHelpers.DisableLogging(); 514// TestHelpers.DisableLogging();
514 } 515 }
516
517 [Test]
518 public void TestSameSimulatorNeighbouringRegionsV2()
519 {
520 TestHelpers.InMethod();
521// TestHelpers.EnableLogging();
522
523 UUID userId = TestHelpers.ParseTail(0x1);
524
525 EntityTransferModule etmA = new EntityTransferModule();
526 EntityTransferModule etmB = new EntityTransferModule();
527 LocalSimulationConnectorModule lscm = new LocalSimulationConnectorModule();
528
529 IConfigSource config = new IniConfigSource();
530 IConfig modulesConfig = config.AddConfig("Modules");
531 modulesConfig.Set("EntityTransferModule", etmA.Name);
532 modulesConfig.Set("SimulationServices", lscm.Name);
533
534 SceneHelpers sh = new SceneHelpers();
535 TestScene sceneA = sh.SetupScene("sceneA", TestHelpers.ParseTail(0x100), 1000, 1000);
536 TestScene sceneB = sh.SetupScene("sceneB", TestHelpers.ParseTail(0x200), 1001, 1000);
537
538 SceneHelpers.SetupSceneModules(new Scene[] { sceneA, sceneB }, config, lscm);
539 SceneHelpers.SetupSceneModules(sceneA, config, new CapabilitiesModule(), etmA);
540 SceneHelpers.SetupSceneModules(sceneB, config, new CapabilitiesModule(), etmB);
541
542 Vector3 teleportPosition = new Vector3(10, 11, 12);
543 Vector3 teleportLookAt = new Vector3(20, 21, 22);
544
545 AgentCircuitData acd = SceneHelpers.GenerateAgentData(userId);
546 TestClient tc = new TestClient(acd, sceneA);
547 List<TestClient> destinationTestClients = new List<TestClient>();
548 EntityTransferHelpers.SetUpInformClientOfNeighbour(tc, destinationTestClients);
549
550 ScenePresence beforeSceneASp = SceneHelpers.AddScenePresence(sceneA, tc, acd);
551 beforeSceneASp.AbsolutePosition = new Vector3(30, 31, 32);
552
553 Assert.That(beforeSceneASp, Is.Not.Null);
554 Assert.That(beforeSceneASp.IsChildAgent, Is.False);
555
556 ScenePresence beforeSceneBSp = sceneB.GetScenePresence(userId);
557 Assert.That(beforeSceneBSp, Is.Not.Null);
558 Assert.That(beforeSceneBSp.IsChildAgent, Is.True);
559
560 // Here, we need to make clientA's receipt of SendRegionTeleport trigger clientB's CompleteMovement(). This
561 // is to operate the teleport V2 mechanism where the EntityTransferModule will first request the client to
562 // CompleteMovement to the region and then call UpdateAgent to the destination region to confirm the receipt
563 // Both these operations will occur on different threads and will wait for each other.
564 // We have to do this via ThreadPool directly since FireAndForget has been switched to sync for the V1
565 // test protocol, where we are trying to avoid unpredictable async operations in regression tests.
566 tc.OnTestClientSendRegionTeleport
567 += (regionHandle, simAccess, regionExternalEndPoint, locationID, flags, capsURL)
568 => ThreadPool.UnsafeQueueUserWorkItem(o => destinationTestClients[0].CompleteMovement(), null);
569
570 sceneA.RequestTeleportLocation(
571 beforeSceneASp.ControllingClient,
572 sceneB.RegionInfo.RegionHandle,
573 teleportPosition,
574 teleportLookAt,
575 (uint)TeleportFlags.ViaLocation);
576
577 ScenePresence afterSceneASp = sceneA.GetScenePresence(userId);
578 Assert.That(afterSceneASp, Is.Not.Null);
579 Assert.That(afterSceneASp.IsChildAgent, Is.True);
580
581 ScenePresence afterSceneBSp = sceneB.GetScenePresence(userId);
582 Assert.That(afterSceneBSp, Is.Not.Null);
583 Assert.That(afterSceneBSp.IsChildAgent, Is.False);
584 Assert.That(afterSceneBSp.Scene.RegionInfo.RegionName, Is.EqualTo(sceneB.RegionInfo.RegionName));
585 Assert.That(afterSceneBSp.AbsolutePosition, Is.EqualTo(teleportPosition));
586
587 Assert.That(sceneA.GetRootAgentCount(), Is.EqualTo(0));
588 Assert.That(sceneA.GetChildAgentCount(), Is.EqualTo(1));
589 Assert.That(sceneB.GetRootAgentCount(), Is.EqualTo(1));
590 Assert.That(sceneB.GetChildAgentCount(), Is.EqualTo(0));
591
592 // TODO: Add assertions to check correct circuit details in both scenes.
593
594 // Lookat is sent to the client only - sp.Lookat does not yield the same thing (calculation from camera
595 // position instead).
596// Assert.That(sp.Lookat, Is.EqualTo(teleportLookAt));
597
598// TestHelpers.DisableLogging();
599 }
515 } 600 }
516} \ No newline at end of file 601} \ No newline at end of file