* WIP changes * Fix tests, merge conflict and trigger once behavior * Update yml * Change test strings to be consts * Fix total damage types and classes triggers * Simplify damage trigger logic, move state to Threshold * Update outdated code and docs * Change the name of IBehavior back to IThresholdBehavior * Change human gibbing to trigger at 400 brute damage * Change gibbing from brute to blunt damage * Fix one (1) typo * Add damage class trigger test * Add missing nullable enable to thresholds
171 lines
7.4 KiB
C#
171 lines
7.4 KiB
C#
using System.Threading.Tasks;
|
|
using Content.Server.GameObjects.Components.Destructible.Thresholds.Triggers;
|
|
using Content.Shared.Damage;
|
|
using Content.Shared.GameObjects.Components.Damage;
|
|
using NUnit.Framework;
|
|
using Robust.Shared.Interfaces.GameObjects;
|
|
using Robust.Shared.Interfaces.Map;
|
|
using Robust.Shared.IoC;
|
|
using Robust.Shared.Map;
|
|
using static Content.IntegrationTests.Tests.Destructible.DestructibleTestPrototypes;
|
|
|
|
namespace Content.IntegrationTests.Tests.Destructible
|
|
{
|
|
[TestFixture]
|
|
[TestOf(typeof(TotalDamageClassesTrigger))]
|
|
public class DestructibleDamageClassTest : ContentIntegrationTest
|
|
{
|
|
[Test]
|
|
public async Task Test()
|
|
{
|
|
var server = StartServerDummyTicker(new ServerContentIntegrationOption
|
|
{
|
|
ExtraPrototypes = Prototypes,
|
|
ContentBeforeIoC = () =>
|
|
{
|
|
IoCManager.Resolve<IComponentFactory>().Register<TestThresholdListenerComponent>();
|
|
}
|
|
});
|
|
|
|
await server.WaitIdleAsync();
|
|
|
|
var sEntityManager = server.ResolveDependency<IEntityManager>();
|
|
var sMapManager = server.ResolveDependency<IMapManager>();
|
|
|
|
IEntity sDestructibleEntity;
|
|
IDamageableComponent sDamageableComponent = null;
|
|
TestThresholdListenerComponent sThresholdListenerComponent = null;
|
|
|
|
await server.WaitPost(() =>
|
|
{
|
|
var mapId = new MapId(1);
|
|
var coordinates = new MapCoordinates(0, 0, mapId);
|
|
sMapManager.CreateMap(mapId);
|
|
|
|
sDestructibleEntity = sEntityManager.SpawnEntity(DestructibleDamageClassEntityId, coordinates);
|
|
sDamageableComponent = sDestructibleEntity.GetComponent<IDamageableComponent>();
|
|
sThresholdListenerComponent = sDestructibleEntity.GetComponent<TestThresholdListenerComponent>();
|
|
});
|
|
|
|
await server.WaitRunTicks(5);
|
|
|
|
await server.WaitAssertion(() =>
|
|
{
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
});
|
|
|
|
await server.WaitAssertion(() =>
|
|
{
|
|
// Raise brute damage to 5
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Brute, 5, true));
|
|
|
|
// No thresholds reached yet, the earliest one is at 10 damage
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
|
|
// Raise brute damage to 10
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Brute, 5, true));
|
|
|
|
// No threshold reached, burn needs to be 10 as well
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
|
|
// Raise burn damage to 10
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Burn, 10, true));
|
|
|
|
// One threshold reached, brute 10 + burn 10
|
|
Assert.That(sThresholdListenerComponent.ThresholdsReached.Count, Is.EqualTo(1));
|
|
|
|
// Threshold brute 10 + burn 10
|
|
var msg = sThresholdListenerComponent.ThresholdsReached[0];
|
|
var threshold = msg.Threshold;
|
|
|
|
// Check that it matches the YAML prototype
|
|
Assert.That(threshold.Behaviors, Is.Empty);
|
|
Assert.NotNull(threshold.Trigger);
|
|
Assert.That(threshold.Triggered, Is.True);
|
|
Assert.IsInstanceOf<TotalDamageClassesTrigger>(threshold.Trigger);
|
|
|
|
sThresholdListenerComponent.ThresholdsReached.Clear();
|
|
|
|
// Raise brute damage to 20
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Brute, 10, true));
|
|
|
|
// No new thresholds reached
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
|
|
// Raise burn damage to 20
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Burn, 10, true));
|
|
|
|
// No new thresholds reached
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
|
|
// Lower brute damage to 0
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Brute, -20, true));
|
|
|
|
// No new thresholds reached, healing should not trigger it
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
|
|
// Raise brute damage back up to 10
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Brute, 10, true));
|
|
|
|
// 10 brute + 10 burn threshold reached, brute was healed and brought back to its threshold amount and slash stayed the same
|
|
Assert.That(sThresholdListenerComponent.ThresholdsReached.Count, Is.EqualTo(1));
|
|
|
|
sThresholdListenerComponent.ThresholdsReached.Clear();
|
|
|
|
// Heal both classes of damage to 0
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Brute, -10, true));
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Burn, -20, true));
|
|
|
|
// No new thresholds reached, healing should not trigger it
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
|
|
// Raise brute damage to 10
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Brute, 10, true));
|
|
|
|
// No new thresholds reached
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
|
|
// Raise burn damage to 10
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Burn, 10, true));
|
|
|
|
// Both classes of damage were healed and then raised again, the threshold should have been reached as triggers once is default false
|
|
Assert.That(sThresholdListenerComponent.ThresholdsReached.Count, Is.EqualTo(1));
|
|
|
|
// Threshold brute 10 + burn 10
|
|
msg = sThresholdListenerComponent.ThresholdsReached[0];
|
|
threshold = msg.Threshold;
|
|
|
|
// Check that it matches the YAML prototype
|
|
Assert.That(threshold.Behaviors, Is.Empty);
|
|
Assert.NotNull(threshold.Trigger);
|
|
Assert.That(threshold.Triggered, Is.True);
|
|
Assert.IsInstanceOf<TotalDamageClassesTrigger>(threshold.Trigger);
|
|
|
|
sThresholdListenerComponent.ThresholdsReached.Clear();
|
|
|
|
// Change triggers once to true
|
|
threshold.TriggersOnce = true;
|
|
|
|
// Heal brute and burn back to 0
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Brute, -10, true));
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Burn, -10, true));
|
|
|
|
// No new thresholds reached from healing
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
|
|
// Raise brute damage to 10
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Brute, 10, true));
|
|
|
|
// No new thresholds reached
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
|
|
// Raise burn damage to 10
|
|
Assert.True(sDamageableComponent.ChangeDamage(DamageClass.Burn, 10, true));
|
|
|
|
// No new thresholds reached as triggers once is set to true and it already triggered before
|
|
Assert.IsEmpty(sThresholdListenerComponent.ThresholdsReached);
|
|
});
|
|
}
|
|
}
|
|
}
|