add regression test for osNpcCreate when cloning an in-region avatar
							parent
							
								
									83ca5a101d
								
							
						
					
					
						commit
						50945dd560
					
				|  | @ -40,9 +40,9 @@ namespace OpenSim.Region.Framework.Interfaces | |||
|         /// <param name="lastname"></param> | ||||
|         /// <param name="position"></param> | ||||
|         /// <param name="scene"></param> | ||||
|         /// <param name="cloneAppearanceFrom">The UUID of the avatar from which to clone the NPC's appearance from.</param> | ||||
|         /// <param name="appearance">The avatar appearance to use for the new NPC.</param> | ||||
|         /// <returns>The UUID of the ScenePresence created.</returns> | ||||
|         UUID CreateNPC(string firstname, string lastname, Vector3 position, Scene scene, UUID cloneAppearanceFrom); | ||||
|         UUID CreateNPC(string firstname, string lastname, Vector3 position, Scene scene, AvatarAppearance appearance); | ||||
| 
 | ||||
|         /// <summary> | ||||
|         /// Check if the agent is an NPC. | ||||
|  |  | |||
|  | @ -45,7 +45,6 @@ namespace OpenSim.Region.OptionalModules.World.NPC | |||
|         private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | ||||
| 
 | ||||
|         private Dictionary<UUID, NPCAvatar> m_avatars = new Dictionary<UUID, NPCAvatar>(); | ||||
|         private Dictionary<UUID, AvatarAppearance> m_appearanceCache = new Dictionary<UUID, AvatarAppearance>(); | ||||
| 
 | ||||
|         public void Initialise(Scene scene, IConfigSource source) | ||||
|         { | ||||
|  | @ -124,28 +123,6 @@ namespace OpenSim.Region.OptionalModules.World.NPC | |||
|             } | ||||
|         } | ||||
| 
 | ||||
|         private AvatarAppearance GetAppearance(UUID target, Scene scene) | ||||
|         { | ||||
|             if (m_appearanceCache.ContainsKey(target)) | ||||
|                 return m_appearanceCache[target]; | ||||
| 
 | ||||
|             ScenePresence originalPresence = scene.GetScenePresence(target); | ||||
| 
 | ||||
|             if (originalPresence != null) | ||||
|             { | ||||
|                 AvatarAppearance originalAppearance = originalPresence.Appearance; | ||||
|                 m_appearanceCache.Add(target, originalAppearance); | ||||
|                 return originalAppearance; | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 m_log.DebugFormat( | ||||
|                     "[NPC MODULE]: Avatar {0} is not in the scene for us to grab baked textures from them.  Using defaults.", target); | ||||
| 
 | ||||
|                 return new AvatarAppearance(); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         public bool IsNPC(UUID agentId, Scene scene) | ||||
|         { | ||||
|             ScenePresence sp = scene.GetScenePresence(agentId); | ||||
|  | @ -176,7 +153,8 @@ namespace OpenSim.Region.OptionalModules.World.NPC | |||
|             return true; | ||||
|         } | ||||
| 
 | ||||
|         public UUID CreateNPC(string firstname, string lastname, Vector3 position, Scene scene, UUID cloneAppearanceFrom) | ||||
|         public UUID CreateNPC( | ||||
|             string firstname, string lastname, Vector3 position, Scene scene, AvatarAppearance appearance) | ||||
|         { | ||||
|             NPCAvatar npcAvatar = new NPCAvatar(firstname, lastname, position, scene); | ||||
|             npcAvatar.CircuitCode = (uint)Util.RandomClass.Next(0, int.MaxValue); | ||||
|  | @ -191,8 +169,7 @@ namespace OpenSim.Region.OptionalModules.World.NPC | |||
|             acd.lastname = lastname; | ||||
|             acd.ServiceURLs = new Dictionary<string, object>(); | ||||
| 
 | ||||
|             AvatarAppearance originalAppearance = GetAppearance(cloneAppearanceFrom, scene); | ||||
|             AvatarAppearance npcAppearance = new AvatarAppearance(originalAppearance, true); | ||||
|             AvatarAppearance npcAppearance = new AvatarAppearance(appearance, true); | ||||
|             acd.Appearance = npcAppearance; | ||||
| 
 | ||||
| //            for (int i = 0; i < acd.Appearance.Texture.FaceTextures.Length; i++) | ||||
|  |  | |||
|  | @ -59,7 +59,7 @@ namespace OpenSim.Region.OptionalModules.World.NPC.Tests | |||
|             AvatarFactoryModule afm = new AvatarFactoryModule(); | ||||
|             TestScene scene = SceneHelpers.SetupScene(); | ||||
|             SceneHelpers.SetupSceneModules(scene, config, afm, new NPCModule()); | ||||
|             IClientAPI originalClient = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseTail(0x1)).ControllingClient; | ||||
|             ScenePresence sp = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseTail(0x1)); | ||||
| //            ScenePresence originalAvatar = scene.GetScenePresence(originalClient.AgentId); | ||||
| 
 | ||||
|             // 8 is the index of the first baked texture in AvatarAppearance | ||||
|  | @ -72,10 +72,10 @@ namespace OpenSim.Region.OptionalModules.World.NPC.Tests | |||
|             // ScenePresence.SendInitialData() to reset our entire appearance. | ||||
|             scene.AssetService.Store(AssetHelpers.CreateAsset(originalFace8TextureId)); | ||||
| 
 | ||||
|             afm.SetAppearanceFromClient(originalClient, originalTe, null); | ||||
|             afm.SetAppearanceFromClient(sp.ControllingClient, originalTe, null); | ||||
| 
 | ||||
|             INPCModule npcModule = scene.RequestModuleInterface<INPCModule>(); | ||||
|             UUID npcId = npcModule.CreateNPC("John", "Smith", new Vector3(128, 128, 30), scene, originalClient.AgentId); | ||||
|             UUID npcId = npcModule.CreateNPC("John", "Smith", new Vector3(128, 128, 30), scene, sp.Appearance); | ||||
| 
 | ||||
|             ScenePresence npc = scene.GetScenePresence(npcId); | ||||
| 
 | ||||
|  | @ -96,12 +96,12 @@ namespace OpenSim.Region.OptionalModules.World.NPC.Tests | |||
| 
 | ||||
|             TestScene scene = SceneHelpers.SetupScene(); | ||||
|             SceneHelpers.SetupSceneModules(scene, config, new NPCModule()); | ||||
|             IClientAPI originalClient = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseTail(0x1)).ControllingClient; | ||||
|             ScenePresence sp = SceneHelpers.AddScenePresence(scene, TestHelpers.ParseTail(0x1)); | ||||
| //            ScenePresence originalAvatar = scene.GetScenePresence(originalClient.AgentId); | ||||
| 
 | ||||
|             Vector3 startPos = new Vector3(128, 128, 30); | ||||
|             INPCModule npcModule = scene.RequestModuleInterface<INPCModule>(); | ||||
|             UUID npcId = npcModule.CreateNPC("John", "Smith", startPos, scene, originalClient.AgentId); | ||||
|             UUID npcId = npcModule.CreateNPC("John", "Smith", startPos, scene, sp.Appearance); | ||||
| 
 | ||||
|             ScenePresence npc = scene.GetScenePresence(npcId); | ||||
|             Assert.That(npc.AbsolutePosition, Is.EqualTo(startPos)); | ||||
|  |  | |||
|  | @ -2135,11 +2135,15 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
|             INPCModule module = World.RequestModuleInterface<INPCModule>(); | ||||
|             if (module != null) | ||||
|             { | ||||
|                 ScenePresence clonePresence = World.GetScenePresence(new UUID(cloneFrom.m_string)); | ||||
|                 if (clonePresence == null) | ||||
|                     return new LSL_Key(UUID.Zero.ToString()); | ||||
| 
 | ||||
|                 UUID x = module.CreateNPC(firstname, | ||||
|                                           lastname, | ||||
|                                           new Vector3((float) position.x, (float) position.y, (float) position.z), | ||||
|                                           World, | ||||
|                                           new UUID(cloneFrom)); | ||||
|                                           clonePresence.Appearance); | ||||
| 
 | ||||
|                 return new LSL_Key(x.ToString()); | ||||
|             } | ||||
|  |  | |||
|  | @ -27,7 +27,9 @@ | |||
| 
 | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Reflection; | ||||
| using System.Text; | ||||
| using log4net; | ||||
| using Nini.Config; | ||||
| using NUnit.Framework; | ||||
| using OpenMetaverse; | ||||
|  | @ -35,6 +37,7 @@ using OpenMetaverse.Assets; | |||
| using OpenMetaverse.StructuredData; | ||||
| using OpenSim.Framework; | ||||
| using OpenSim.Region.CoreModules.Avatar.AvatarFactory; | ||||
| using OpenSim.Region.OptionalModules.World.NPC; | ||||
| using OpenSim.Region.Framework.Scenes; | ||||
| using OpenSim.Region.ScriptEngine.Shared; | ||||
| using OpenSim.Region.ScriptEngine.Shared.Api; | ||||
|  | @ -61,9 +64,11 @@ namespace OpenSim.Region.ScriptEngine.Shared.Tests | |||
|             config.Set("Enabled", "true"); | ||||
|             config.Set("AllowOSFunctions", "true"); | ||||
|             config.Set("OSFunctionThreatLevel", "Severe"); | ||||
|             config = initConfigSource.AddConfig("NPC"); | ||||
|             config.Set("Enabled", "true"); | ||||
| 
 | ||||
|             m_scene = SceneHelpers.SetupScene(); | ||||
|             SceneHelpers.SetupSceneModules(m_scene, new AvatarFactoryModule()); | ||||
|             SceneHelpers.SetupSceneModules(m_scene, initConfigSource, new AvatarFactoryModule(), new NPCModule()); | ||||
| 
 | ||||
|             m_engine = new XEngine.XEngine(); | ||||
|             m_engine.Initialise(initConfigSource); | ||||
|  | @ -73,12 +78,72 @@ namespace OpenSim.Region.ScriptEngine.Shared.Tests | |||
|         /// <summary> | ||||
|         /// Test creation of an NPC where the appearance data comes from a notecard | ||||
|         /// </summary> | ||||
| //        [Test] | ||||
| //        public void TestOsNpcCreateFromNotecard() | ||||
| //        { | ||||
| //            TestHelpers.InMethod(); | ||||
| ////            log4net.Config.XmlConfigurator.Configure(); | ||||
| //        } | ||||
|         //[Test] | ||||
|         public void TestOsNpcCreateFromNotecard() | ||||
|         { | ||||
|             TestHelpers.InMethod(); | ||||
|             log4net.Config.XmlConfigurator.Configure(); | ||||
| 
 | ||||
|             // Store an avatar with a different height from default in a notecard. | ||||
|             UUID userId = TestHelpers.ParseTail(0x1); | ||||
|             float newHeight = 1.9f; | ||||
| 
 | ||||
|             ScenePresence sp = SceneHelpers.AddScenePresence(m_scene, userId); | ||||
|             sp.Appearance.AvatarHeight = newHeight; | ||||
|             SceneObjectGroup so = SceneHelpers.CreateSceneObject(1, userId); | ||||
|             SceneObjectPart part = so.RootPart; | ||||
|             m_scene.AddSceneObject(so); | ||||
| 
 | ||||
|             OSSL_Api osslApi = new OSSL_Api(); | ||||
|             osslApi.Initialize(m_engine, part, part.LocalId, part.UUID); | ||||
| 
 | ||||
|             string notecardName = "appearanceNc"; | ||||
|             osslApi.osOwnerSaveAppearance(notecardName); | ||||
| 
 | ||||
|             // Try creating a bot using the appearance in the notecard. | ||||
|             string npcRaw = osslApi.osNpcCreate("Jane", "Doe", new LSL_Types.Vector3(128, 128, 128), notecardName); | ||||
|             Assert.That(npcRaw, Is.Not.Null); | ||||
| 
 | ||||
|             UUID npcId = new UUID(npcRaw); | ||||
|             ScenePresence npc = m_scene.GetScenePresence(npcId); | ||||
|             Assert.That(npc, Is.Not.Null); | ||||
|             Assert.That(npc.Appearance.AvatarHeight, Is.EqualTo(newHeight)); | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         /// Test creation of an NPC where the appearance data comes from an avatar already in the region. | ||||
|         /// </summary> | ||||
|         [Test] | ||||
|         public void TestOsNpcCreateFromAvatar() | ||||
|         { | ||||
|             TestHelpers.InMethod(); | ||||
| //            log4net.Config.XmlConfigurator.Configure(); | ||||
| 
 | ||||
|             // Store an avatar with a different height from default in a notecard. | ||||
|             UUID userId = TestHelpers.ParseTail(0x1); | ||||
|             float newHeight = 1.9f; | ||||
| 
 | ||||
|             ScenePresence sp = SceneHelpers.AddScenePresence(m_scene, userId); | ||||
|             sp.Appearance.AvatarHeight = newHeight; | ||||
|             SceneObjectGroup so = SceneHelpers.CreateSceneObject(1, userId); | ||||
|             SceneObjectPart part = so.RootPart; | ||||
|             m_scene.AddSceneObject(so); | ||||
| 
 | ||||
|             OSSL_Api osslApi = new OSSL_Api(); | ||||
|             osslApi.Initialize(m_engine, part, part.LocalId, part.UUID); | ||||
| 
 | ||||
|             string notecardName = "appearanceNc"; | ||||
|             osslApi.osOwnerSaveAppearance(notecardName); | ||||
| 
 | ||||
|             // Try creating a bot using the existing avatar's appearance | ||||
|             string npcRaw = osslApi.osNpcCreate("Jane", "Doe", new LSL_Types.Vector3(128, 128, 128), sp.UUID.ToString()); | ||||
|             Assert.That(npcRaw, Is.Not.Null); | ||||
| 
 | ||||
|             UUID npcId = new UUID(npcRaw); | ||||
|             ScenePresence npc = m_scene.GetScenePresence(npcId); | ||||
|             Assert.That(npc, Is.Not.Null); | ||||
|             Assert.That(npc.Appearance.AvatarHeight, Is.EqualTo(newHeight)); | ||||
|         } | ||||
| 
 | ||||
|         [Test] | ||||
|         public void TestOsOwnerSaveAppearance() | ||||
|  |  | |||
|  | @ -3143,11 +3143,13 @@ | |||
|       <Reference name="OpenSim.Framework.Communications"/> | ||||
|       <Reference name="OpenSim.Region.CoreModules"/> | ||||
|       <Reference name="OpenSim.Region.Framework"/> | ||||
|       <Reference name="OpenSim.Region.OptionalModules"/> | ||||
|       <Reference name="OpenSim.Region.ScriptEngine.Shared"/> | ||||
|       <Reference name="OpenSim.Region.ScriptEngine.Shared.Api"/> | ||||
|       <Reference name="OpenSim.Region.ScriptEngine.XEngine"/> | ||||
|       <Reference name="OpenSim.Services.Interfaces"/> | ||||
|       <Reference name="OpenSim.Tests.Common"/> | ||||
|       <Reference name="log4net"/> | ||||
|       <Reference name="nunit.framework" path="../../../bin/"/> | ||||
|       <Reference name="Nini" path="../../../bin/"/> | ||||
|       <Reference name="OpenMetaverse" path="../../../bin/"/> | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Justin Clark-Casey (justincc)
						Justin Clark-Casey (justincc)