mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-01 14:07:43 +01:00
Add TagPathOverrideTest
This commit is contained in:
parent
a78309a2b2
commit
bf961e4b61
@ -0,0 +1,41 @@
|
||||
package net.minestom.server.tag;
|
||||
|
||||
import org.jglrxavpok.hephaistos.nbt.NBT;
|
||||
import org.openjdk.jcstress.annotations.*;
|
||||
import org.openjdk.jcstress.infra.results.L_Result;
|
||||
|
||||
import java.util.Map;
|
||||
|
||||
import static org.openjdk.jcstress.annotations.Expect.ACCEPTABLE;
|
||||
|
||||
@JCStressTest
|
||||
@Outcome(id = "actor1", expect = ACCEPTABLE)
|
||||
@Outcome(id = "actor2", expect = ACCEPTABLE)
|
||||
@State
|
||||
public class TagPathOverrideTest {
|
||||
private static final Tag<Integer> TAG_PATH = Tag.Integer("key").path("path");
|
||||
|
||||
private final TagHandler handler = TagHandler.newHandler();
|
||||
|
||||
@Actor
|
||||
public void actor1() {
|
||||
handler.setTag(TAG_PATH, 1);
|
||||
}
|
||||
|
||||
@Actor
|
||||
public void actor2() {
|
||||
handler.setTag(TAG_PATH, 5);
|
||||
}
|
||||
|
||||
@Arbiter
|
||||
public void arbiter(L_Result r) {
|
||||
var compound = handler.asCompound();
|
||||
if (compound.equals(NBT.Compound(Map.of("path", NBT.Compound(Map.of("key", NBT.Int(1))))))) {
|
||||
r.r1 = "actor1";
|
||||
} else if (compound.equals(NBT.Compound(Map.of("path", NBT.Compound(Map.of("key", NBT.Int(5))))))) {
|
||||
r.r1 = "actor2";
|
||||
} else {
|
||||
r.r1 = compound;
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user