mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-25 01:21:20 +01:00
Fix removal scheduling involving server ticks
Signed-off-by: TheMode <themode@outlook.fr>
This commit is contained in:
parent
f1ca048eb6
commit
5b699e0375
@ -1453,8 +1453,12 @@ public class Entity implements Viewable, Tickable, Schedulable, TagHandler, Perm
|
||||
* @param temporalUnit the unit of the delay
|
||||
*/
|
||||
public void scheduleRemove(long delay, @NotNull TemporalUnit temporalUnit) {
|
||||
if (temporalUnit == TimeUnit.SERVER_TICK) {
|
||||
scheduleRemove(TaskSchedule.tick((int) delay));
|
||||
} else {
|
||||
scheduleRemove(Duration.of(delay, temporalUnit));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Triggers {@link #remove()} after the specified time.
|
||||
@ -1462,7 +1466,11 @@ public class Entity implements Viewable, Tickable, Schedulable, TagHandler, Perm
|
||||
* @param delay the time before removing the entity
|
||||
*/
|
||||
public void scheduleRemove(Duration delay) {
|
||||
this.scheduler.buildTask(this::remove).delay(TaskSchedule.duration(delay)).schedule();
|
||||
scheduleRemove(TaskSchedule.duration(delay));
|
||||
}
|
||||
|
||||
private void scheduleRemove(TaskSchedule schedule) {
|
||||
this.scheduler.buildTask(this::remove).delay(schedule).schedule();
|
||||
}
|
||||
|
||||
protected @NotNull Vec getVelocityForPacket() {
|
||||
|
@ -0,0 +1,42 @@
|
||||
package net.minestom.server.entity;
|
||||
|
||||
import net.minestom.server.api.Env;
|
||||
import net.minestom.server.api.EnvTest;
|
||||
import net.minestom.server.coordinate.Pos;
|
||||
import net.minestom.server.utils.time.TimeUnit;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import java.time.temporal.TemporalUnit;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
|
||||
@EnvTest
|
||||
public class EntityScheduledRemovalIntegrationTest {
|
||||
|
||||
@Test
|
||||
public void tickRemoval(Env env) throws InterruptedException {
|
||||
var instance = env.createFlatInstance();
|
||||
var entity = new TestEntity(2, TimeUnit.SERVER_TICK);
|
||||
entity.setInstance(instance, new Pos(0, 40, 0)).join();
|
||||
|
||||
assertFalse(entity.isRemoved());
|
||||
assertEquals(0, entity.getAliveTicks());
|
||||
|
||||
Thread.sleep(150); // Ensure that time is not used for tick scheduling
|
||||
|
||||
env.tick();
|
||||
assertFalse(entity.isRemoved());
|
||||
assertEquals(1, entity.getAliveTicks());
|
||||
|
||||
env.tick();
|
||||
assertTrue(entity.isRemoved());
|
||||
assertEquals(1, entity.getAliveTicks());
|
||||
}
|
||||
|
||||
static final class TestEntity extends Entity {
|
||||
public TestEntity(long delay, TemporalUnit unit) {
|
||||
super(EntityType.ZOMBIE);
|
||||
scheduleRemove(delay, unit);
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user