From 40b6c66491474be8daad6f8f91d62823ed72e954 Mon Sep 17 00:00:00 2001
From: Pasqual Koschmieder <40468651+derklaro@users.noreply.github.com>
Date: Tue, 30 Nov 2021 20:10:03 +0100
Subject: [PATCH] Update to minecraft 1.18 (#1446)
---
.github/workflows/build.yml | 2 +-
jitpack.yml | 4 +-
pom.xml | 31 ++++++++----
.../com/comphenix/protocol/PacketLogging.java | 16 ++++++-
.../com/comphenix/protocol/PacketType.java | 35 +++++++-------
.../comphenix/protocol/ProtocolLibrary.java | 6 +--
.../injector/netty/NettyByteBufAdapter.java | 2 +-
.../injector/netty/PipelineProxy.java | 2 +-
.../protocol/reflect/FieldUtils.java | 9 ++--
.../accessors/DefaultFieldAccessor.java | 42 ++++++++++++----
.../reflect/accessors/UnsafeFieldAccess.java | 48 +++++++++++++++++++
.../comphenix/protocol/utility/Constants.java | 4 +-
.../utility/MinecraftProtocolVersion.java | 2 +
.../protocol/utility/MinecraftReflection.java | 18 ++++---
.../protocol/utility/MinecraftVersion.java | 5 ++
.../protocol/utility/ZeroBuffer.java | 2 +-
.../protocol/wrappers/WrappedDataWatcher.java | 2 +-
.../protocol/wrappers/WrappedRegistry.java | 11 +++--
.../protocol/SimpleCraftBukkitITCase.java | 2 +-
.../protocol/BukkitInitialization.java | 16 ++++---
.../protocol/events/PacketContainerTest.java | 18 +++++--
.../injector/EntityUtilitiesTest.java | 10 ++--
.../protocol/injector/PluginVerifierTest.java | 4 +-
.../utility/MinecraftReflectionTest.java | 4 +-
.../utility/StreamSerializerTest.java | 2 +-
.../wrappers/ChunkCoordIntPairTest.java | 4 +-
.../wrappers/MultiBlockChangeTest.java | 2 +-
.../wrappers/WrappedAttributeTest.java | 2 +-
.../wrappers/WrappedBlockDataTest.java | 8 ++--
.../wrappers/WrappedDataWatcherTest.java | 4 +-
.../protocol/wrappers/nbt/NbtFactoryTest.java | 2 +-
31 files changed, 219 insertions(+), 100 deletions(-)
create mode 100644 src/main/java/com/comphenix/protocol/reflect/accessors/UnsafeFieldAccess.java
diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml
index 541c92cc..8dd8a96d 100644
--- a/.github/workflows/build.yml
+++ b/.github/workflows/build.yml
@@ -13,7 +13,7 @@ jobs:
uses: actions/setup-java@v2
with:
distribution: 'temurin'
- java-version: '16'
+ java-version: '17'
- name: Run maven build lifecycle
run: mvn --batch-mode clean test package
diff --git a/jitpack.yml b/jitpack.yml
index 376245fb..f5195ef9 100644
--- a/jitpack.yml
+++ b/jitpack.yml
@@ -1,5 +1,5 @@
before_install:
- source "$HOME/.sdkman/bin/sdkman-init.sh"
- sdk update
- - sdk install java 16.0.1.hs-adpt
- - sdk use java 16.0.1.hs-adpt
+ - sdk install java 17.0.1-tem
+ - sdk use java 17.0.1-tem
diff --git a/pom.xml b/pom.xml
index a9a79389..ae8cff1d 100644
--- a/pom.xml
+++ b/pom.xml
@@ -4,7 +4,7 @@
com.comphenix.protocol
ProtocolLib
ProtocolLib
- 4.7.1-SNAPSHOT
+ 4.7.2-SNAPSHOT
Provides read/write access to the Minecraft protocol.
https://github.com/dmulloy2/ProtocolLib
@@ -16,8 +16,8 @@
${project.version}
- 2.0.7
- 1.17.1-R0.1-SNAPSHOT
+ 2.0.9
+ 1.18-R0.1-SNAPSHOT
@@ -110,13 +110,13 @@
- --illegal-access=permit
+ --add-opens java.base/java.lang=ALL-UNNAMED --add-opens java.base/java.util=ALL-UNNAMED --add-opens java.base/java.util.regex=ALL-UNNAMED --add-opens java.base/java.lang.reflect=ALL-UNNAMED --add-opens java.base/java.io=ALL-UNNAMED
maven-javadoc-plugin
- 3.2.0
+ 3.3.1
false
ISO-8859-1
@@ -284,6 +284,19 @@
4.0.23.Final
provided
+
+
+ io.netty
+ netty-common
+ 4.1.70.Final
+ test
+
+
+ io.netty
+ netty-transport
+ 4.1.70.Final
+ test
+
org.spigotmc
spigot-api
@@ -299,27 +312,27 @@
net.kyori
adventure-text-serializer-gson
- 4.5.1
+ 4.9.3
provided
net.bytebuddy
byte-buddy
- 1.11.0
+ 1.12.1
junit
junit
- 4.13.1
+ 4.13.2
test
org.mockito
mockito-core
- 3.5.10
+ 3.12.4
test
diff --git a/src/main/java/com/comphenix/protocol/PacketLogging.java b/src/main/java/com/comphenix/protocol/PacketLogging.java
index 1958616f..a7d0c363 100644
--- a/src/main/java/com/comphenix/protocol/PacketLogging.java
+++ b/src/main/java/com/comphenix/protocol/PacketLogging.java
@@ -19,6 +19,7 @@ package com.comphenix.protocol;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.IOException;
+import java.io.OutputStream;
import java.text.MessageFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
@@ -31,13 +32,16 @@ import com.comphenix.protocol.events.ListeningWhitelist;
import com.comphenix.protocol.events.PacketEvent;
import com.comphenix.protocol.events.PacketListener;
import com.comphenix.protocol.injector.netty.WirePacket;
+import com.comphenix.protocol.reflect.FuzzyReflection;
+import com.comphenix.protocol.reflect.accessors.Accessors;
+import com.comphenix.protocol.reflect.accessors.MethodAccessor;
+import com.comphenix.protocol.utility.MinecraftReflection;
import com.google.common.base.Charsets;
import org.bukkit.ChatColor;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
-import org.bukkit.craftbukkit.libs.org.apache.commons.io.HexDump;
import org.bukkit.plugin.Plugin;
/**
@@ -47,6 +51,8 @@ import org.bukkit.plugin.Plugin;
public class PacketLogging implements CommandExecutor, PacketListener {
public static final String NAME = "packetlog";
+ private static MethodAccessor HEX_DUMP;
+
private List sendingTypes = new ArrayList<>();
private List receivingTypes = new ArrayList<>();
@@ -199,7 +205,13 @@ public class PacketLogging implements CommandExecutor, PacketListener {
private static String hexDump(byte[] bytes) throws IOException {
try (ByteArrayOutputStream output = new ByteArrayOutputStream()) {
- HexDump.dump(bytes, 0, output, 0);
+ if (HEX_DUMP == null) {
+ Class> hexDumpClass = MinecraftReflection.getLibraryClass("org.apache.commons.io.HexDump");
+ HEX_DUMP = Accessors.getMethodAccessor(FuzzyReflection.fromClass(hexDumpClass)
+ .getMethodByParameters("dump", byte[].class, long.class, OutputStream.class, int.class));
+ }
+
+ HEX_DUMP.invoke(null, bytes, 0, output, 0);
return new String(output.toByteArray(), Charsets.UTF_8);
}
}
diff --git a/src/main/java/com/comphenix/protocol/PacketType.java b/src/main/java/com/comphenix/protocol/PacketType.java
index f5ea08a6..9d822481 100644
--- a/src/main/java/com/comphenix/protocol/PacketType.java
+++ b/src/main/java/com/comphenix/protocol/PacketType.java
@@ -137,7 +137,7 @@ public class PacketType implements Serializable, Cloneable, Comparable unsafeClass = Class.forName("sun.misc.Unsafe");
+ // get the unsafe instance
+ Field theUnsafe = unsafeClass.getDeclaredField("theUnsafe");
+ theUnsafe.setAccessible(true);
+ sun.misc.Unsafe unsafe = (sun.misc.Unsafe) theUnsafe.get(null);
+ // get the trusted lookup field
+ Field trustedLookup = Lookup.class.getDeclaredField("IMPL_LOOKUP");
+ // get access to the base and offset value of it
+ long offset = unsafe.staticFieldOffset(trustedLookup);
+ Object baseValue = unsafe.staticFieldBase(trustedLookup);
+ // get the trusted lookup instance
+ trusted = (Lookup) unsafe.getObject(baseValue, offset);
+ } catch (Exception exception) {
+ ProtocolLogger.log(Level.SEVERE, "Unable to retrieve trusted lookup", exception);
+ }
+
+ TRUSTED_LOOKUP = trusted;
+ }
+
+ public static boolean hasTrustedLookup() {
+ return TRUSTED_LOOKUP != null;
+ }
+
+ public static MethodHandle findSetter(Field field) throws ReflectiveOperationException {
+ if (Modifier.isStatic(field.getModifiers())) {
+ return TRUSTED_LOOKUP.findStaticSetter(field.getDeclaringClass(), field.getName(), field.getType());
+ } else {
+ return TRUSTED_LOOKUP.findSetter(field.getDeclaringClass(), field.getName(), field.getType());
+ }
+ }
+}
diff --git a/src/main/java/com/comphenix/protocol/utility/Constants.java b/src/main/java/com/comphenix/protocol/utility/Constants.java
index 78772048..96f9985d 100644
--- a/src/main/java/com/comphenix/protocol/utility/Constants.java
+++ b/src/main/java/com/comphenix/protocol/utility/Constants.java
@@ -21,10 +21,10 @@ package com.comphenix.protocol.utility;
*/
public final class Constants {
- public static final String PACKAGE_VERSION = "v1_17_R1";
+ public static final String PACKAGE_VERSION = "v1_18_R1";
public static final String NMS = "net.minecraft";
public static final String OBC = "org.bukkit.craftbukkit." + PACKAGE_VERSION;
- public static final MinecraftVersion CURRENT_VERSION = MinecraftVersion.CAVES_CLIFFS_1;
+ public static final MinecraftVersion CURRENT_VERSION = MinecraftVersion.CAVES_CLIFFS_2;
public static void init() {
MinecraftReflection.setMinecraftPackage(NMS, OBC);
diff --git a/src/main/java/com/comphenix/protocol/utility/MinecraftProtocolVersion.java b/src/main/java/com/comphenix/protocol/utility/MinecraftProtocolVersion.java
index 88575d5e..9d3730c1 100644
--- a/src/main/java/com/comphenix/protocol/utility/MinecraftProtocolVersion.java
+++ b/src/main/java/com/comphenix/protocol/utility/MinecraftProtocolVersion.java
@@ -76,6 +76,8 @@ public class MinecraftProtocolVersion {
map.put(new MinecraftVersion(1, 17, 0), 755);
map.put(new MinecraftVersion(1, 17, 1), 756);
+
+ map.put(new MinecraftVersion(1, 18, 0), 757);
return map;
}
diff --git a/src/main/java/com/comphenix/protocol/utility/MinecraftReflection.java b/src/main/java/com/comphenix/protocol/utility/MinecraftReflection.java
index 94c92bf2..861c7a80 100644
--- a/src/main/java/com/comphenix/protocol/utility/MinecraftReflection.java
+++ b/src/main/java/com/comphenix/protocol/utility/MinecraftReflection.java
@@ -2267,13 +2267,7 @@ public class MinecraftReflection {
}
public static Class> getFastUtilClass(String className) {
- try {
- return getMinecraftLibraryClass("it.unimi.dsi.fastutil." + className);
- } catch (RuntimeException ex) {
- Class> clazz = getMinecraftLibraryClass("org.bukkit.craftbukkit.libs.it.unimi.dsi.fastutil." + className);
- setMinecraftLibraryClass("it.unimi.dsi.fastutil." + className, clazz);
- return clazz;
- }
+ return getLibraryClass("it.unimi.dsi.fastutil." + className);
}
public static Class> getInt2ObjectMapClass() {
@@ -2283,4 +2277,14 @@ public class MinecraftReflection {
public static Class> getIntArrayListClass() {
return getFastUtilClass("ints.IntArrayList");
}
+
+ public static Class> getLibraryClass(String classname) {
+ try {
+ return getMinecraftLibraryClass(classname);
+ } catch (RuntimeException ex) {
+ Class> clazz = getMinecraftLibraryClass("org.bukkit.craftbukkit.libs." + classname);
+ setMinecraftLibraryClass(classname, clazz);
+ return clazz;
+ }
+ }
}
diff --git a/src/main/java/com/comphenix/protocol/utility/MinecraftVersion.java b/src/main/java/com/comphenix/protocol/utility/MinecraftVersion.java
index cb48d36e..308d6e03 100644
--- a/src/main/java/com/comphenix/protocol/utility/MinecraftVersion.java
+++ b/src/main/java/com/comphenix/protocol/utility/MinecraftVersion.java
@@ -44,6 +44,11 @@ public class MinecraftVersion implements Comparable, Serializa
*/
private static final Pattern VERSION_PATTERN = Pattern.compile(".*\\(.*MC.\\s*([a-zA-z0-9\\-.]+).*");
+ /**
+ * Version 1.18 - caves and cliffs part 2
+ */
+ public static final MinecraftVersion CAVES_CLIFFS_2 = new MinecraftVersion("1.18");
+
/**
* Version 1.17 - caves and cliffs part 1
*/
diff --git a/src/main/java/com/comphenix/protocol/utility/ZeroBuffer.java b/src/main/java/com/comphenix/protocol/utility/ZeroBuffer.java
index 99e0e398..a813cba0 100644
--- a/src/main/java/com/comphenix/protocol/utility/ZeroBuffer.java
+++ b/src/main/java/com/comphenix/protocol/utility/ZeroBuffer.java
@@ -738,4 +738,4 @@ public class ZeroBuffer extends ByteBuf {
public ByteBuf retain() {
return null;
}
-}
+}
\ No newline at end of file
diff --git a/src/main/java/com/comphenix/protocol/wrappers/WrappedDataWatcher.java b/src/main/java/com/comphenix/protocol/wrappers/WrappedDataWatcher.java
index b9217918..0a5b0b3b 100644
--- a/src/main/java/com/comphenix/protocol/wrappers/WrappedDataWatcher.java
+++ b/src/main/java/com/comphenix/protocol/wrappers/WrappedDataWatcher.java
@@ -495,7 +495,7 @@ public class WrappedDataWatcher extends AbstractWrapper implements Iterable methods = fuzzy.getMethodList(contract);
for (Method method : methods) {
- if (method.getName().equals("set") || method.getName().equals("watch")) {
+ if (method.getName().equals("set") || method.getName().equals("watch") || method.getName().equals("b")) {
SETTER = Accessors.getMethodAccessor(method);
} else {
REGISTER = Accessors.getMethodAccessor(method);
diff --git a/src/main/java/com/comphenix/protocol/wrappers/WrappedRegistry.java b/src/main/java/com/comphenix/protocol/wrappers/WrappedRegistry.java
index 4b129761..b5b5276b 100644
--- a/src/main/java/com/comphenix/protocol/wrappers/WrappedRegistry.java
+++ b/src/main/java/com/comphenix/protocol/wrappers/WrappedRegistry.java
@@ -5,10 +5,10 @@ import com.comphenix.protocol.reflect.accessors.Accessors;
import com.comphenix.protocol.reflect.accessors.MethodAccessor;
import com.comphenix.protocol.reflect.fuzzy.FuzzyMethodContract;
import com.comphenix.protocol.utility.MinecraftReflection;
-import com.comphenix.protocol.utility.MinecraftVersion;
import com.google.common.collect.ImmutableMap;
import java.lang.reflect.Field;
+import java.lang.reflect.Modifier;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.HashMap;
@@ -46,9 +46,14 @@ public class WrappedRegistry {
REGISTRY = ImmutableMap.copyOf(regMap);
- GET = Accessors.getMethodAccessor(regClass, "get", MinecraftReflection.getMinecraftKeyClass());
-
FuzzyReflection fuzzy = FuzzyReflection.fromClass(regClass, false);
+ GET = Accessors.getMethodAccessor(fuzzy.getMethod(FuzzyMethodContract
+ .newBuilder()
+ .parameterCount(1)
+ .returnDerivedOf(Object.class)
+ .requireModifier(Modifier.ABSTRACT)
+ .parameterExactType(MinecraftReflection.getMinecraftKeyClass())
+ .build()));
GET_KEY = Accessors.getMethodAccessor(fuzzy.getMethod(FuzzyMethodContract
.newBuilder()
.parameterCount(1)
diff --git a/src/test/java/com/comphenix/integration/protocol/SimpleCraftBukkitITCase.java b/src/test/java/com/comphenix/integration/protocol/SimpleCraftBukkitITCase.java
index 39b95a14..d7ab0f83 100644
--- a/src/test/java/com/comphenix/integration/protocol/SimpleCraftBukkitITCase.java
+++ b/src/test/java/com/comphenix/integration/protocol/SimpleCraftBukkitITCase.java
@@ -33,7 +33,7 @@ import com.google.common.io.Files;
// TODO Migrate this to Gradle if necessary
// Damn final classes ...
@RunWith(org.powermock.modules.junit4.PowerMockRunner.class)
-@PowerMockIgnore({ "org.apache.log4j.*", "org.apache.logging.*", "org.bukkit.craftbukkit.libs.jline.*" })
+@PowerMockIgnore({ "org.apache.logging.log4j.core.config.xml.*", "javax.management.*" })
@PrepareForTest(PluginDescriptionFile.class)
public class SimpleCraftBukkitITCase {
// The fake plugin
diff --git a/src/test/java/com/comphenix/protocol/BukkitInitialization.java b/src/test/java/com/comphenix/protocol/BukkitInitialization.java
index 0fa575a8..9a25e1df 100644
--- a/src/test/java/com/comphenix/protocol/BukkitInitialization.java
+++ b/src/test/java/com/comphenix/protocol/BukkitInitialization.java
@@ -5,7 +5,6 @@ import java.util.List;
import com.comphenix.protocol.reflect.FieldUtils;
import com.comphenix.protocol.utility.Constants;
-import com.mojang.bridge.game.GameVersion;
import net.minecraft.SharedConstants;
import net.minecraft.core.IRegistry;
@@ -16,10 +15,10 @@ import org.apache.logging.log4j.LogManager;
import org.bukkit.Bukkit;
import org.bukkit.Server;
import org.bukkit.World;
-import org.bukkit.craftbukkit.v1_17_R1.CraftServer;
-import org.bukkit.craftbukkit.v1_17_R1.CraftWorld;
-import org.bukkit.craftbukkit.v1_17_R1.inventory.CraftItemFactory;
-import org.bukkit.craftbukkit.v1_17_R1.util.Versioning;
+import org.bukkit.craftbukkit.v1_18_R1.CraftServer;
+import org.bukkit.craftbukkit.v1_18_R1.CraftWorld;
+import org.bukkit.craftbukkit.v1_18_R1.inventory.CraftItemFactory;
+import org.bukkit.craftbukkit.v1_18_R1.util.Versioning;
import org.spigotmc.SpigotWorldConfig;
import static org.mockito.Mockito.mock;
@@ -81,7 +80,7 @@ public class BukkitInitialization {
instance.setPackage();
SharedConstants.a();
- DispenserRegistry.init();
+ DispenserRegistry.a();
try {
IRegistry.class.getName();
@@ -89,12 +88,15 @@ public class BukkitInitialization {
ex.printStackTrace();
}
+ String releaseTarget = SharedConstants.b().getReleaseTarget();
+ String serverVersion = CraftServer.class.getPackage().getImplementationVersion();
+
// Mock the server object
Server mockedServer = mock(Server.class);
when(mockedServer.getLogger()).thenReturn(java.util.logging.Logger.getLogger("Minecraft"));
when(mockedServer.getName()).thenReturn("Mock Server");
- when(mockedServer.getVersion()).thenReturn(CraftServer.class.getPackage().getImplementationVersion());
+ when(mockedServer.getVersion()).thenReturn(serverVersion + " (MC: " + releaseTarget + ")");
when(mockedServer.getBukkitVersion()).thenReturn(Versioning.getBukkitVersion());
when(mockedServer.getItemFactory()).thenReturn(CraftItemFactory.instance());
diff --git a/src/test/java/com/comphenix/protocol/events/PacketContainerTest.java b/src/test/java/com/comphenix/protocol/events/PacketContainerTest.java
index cf184f4c..91ab697b 100644
--- a/src/test/java/com/comphenix/protocol/events/PacketContainerTest.java
+++ b/src/test/java/com/comphenix/protocol/events/PacketContainerTest.java
@@ -76,7 +76,7 @@ import static org.junit.Assert.*;
// Ensure that the CraftItemFactory is mockable
@RunWith(org.powermock.modules.junit4.PowerMockRunner.class)
-@PowerMockIgnore({ "org.apache.log4j.*", "org.apache.logging.*", "org.bukkit.craftbukkit.libs.jline.*", "javax.management.*", "javax.xml.parsers.*", "com.sun.org.apache.xerces.internal.jaxp.*" })
+@PowerMockIgnore({ "org.apache.logging.log4j.core.config.xml.*", "javax.management.*" })
//@PrepareForTest(CraftItemFactory.class)
public class PacketContainerTest {
// Helper converters
@@ -191,7 +191,7 @@ public class PacketContainerTest {
@Test
public void testGetIntegerArrays() {
// Contains a byte array we will test
- PacketContainer packet = new PacketContainer(PacketType.Play.Server.MAP_CHUNK);
+ PacketContainer packet = new PacketContainer(PacketType.Play.Server.MOUNT);
StructureModifier integers = packet.getIntegerArrays();
int[] testArray = new int[] { 1, 2, 3 };
@@ -411,7 +411,7 @@ public class PacketContainerTest {
// are inner classes (which is ultimately pointless because AttributeSnapshots don't access any
// members of the packet itself)
PacketPlayOutUpdateAttributes packet = (PacketPlayOutUpdateAttributes) attribute.getHandle();
- AttributeBase base = IRegistry.al.get(MinecraftKey.a("generic.max_health"));
+ AttributeBase base = IRegistry.am.a(MinecraftKey.a("generic.max_health"));
AttributeSnapshot snapshot = new AttributeSnapshot(base, 20.0D, modifiers);
attribute.getSpecificModifier(List.class).write(0, Lists.newArrayList(snapshot));
@@ -461,7 +461,7 @@ public class PacketContainerTest {
@SuppressWarnings("deprecation")
public void testPotionEffect() {
PotionEffect effect = new PotionEffect(PotionEffectType.FIRE_RESISTANCE, 20 * 60, 1);
- MobEffect mobEffect = new MobEffect(MobEffectList.fromId(effect.getType().getId()), effect.getDuration(), effect.getAmplifier(), effect.isAmbient(),
+ MobEffect mobEffect = new MobEffect(MobEffectList.a(effect.getType().getId()), effect.getDuration(), effect.getAmplifier(), effect.isAmbient(),
effect.hasParticles());
int entityId = 42;
@@ -663,12 +663,20 @@ public class PacketContainerTest {
assertEquals(position, clone.getPosition());
}
+ @Test
+ public void testSetSimulationDistance() {
+ // first packet which is a record - set will fail if we missed something during patching
+ PacketContainer container = new PacketContainer(PacketType.Play.Server.UPDATE_SIMULATION_DISTANCE);
+ container.getIntegers().write(0, 1234);
+ assertEquals(1234, (int) container.getIntegers().read(0));
+ }
+
@Test
public void testMapChunk() {
// this is a special case as we are generating a data serializer class (we only need to construct the packet)
PacketContainer container = new PacketContainer(PacketType.Play.Server.MAP_CHUNK);
// check if we can read an nbt compound from the class
- assertTrue(container.getNbtModifier().optionRead(0).isPresent());
+ assertTrue(container.getStructures().read(0).getNbtModifier().optionRead(0).isPresent());
}
/**
diff --git a/src/test/java/com/comphenix/protocol/injector/EntityUtilitiesTest.java b/src/test/java/com/comphenix/protocol/injector/EntityUtilitiesTest.java
index 2ca81315..495f4995 100644
--- a/src/test/java/com/comphenix/protocol/injector/EntityUtilitiesTest.java
+++ b/src/test/java/com/comphenix/protocol/injector/EntityUtilitiesTest.java
@@ -9,6 +9,8 @@ import com.comphenix.protocol.reflect.accessors.Accessors;
import com.comphenix.protocol.reflect.accessors.FieldAccessor;
import com.comphenix.protocol.reflect.fuzzy.FuzzyFieldContract;
+import it.unimi.dsi.fastutil.ints.Int2ObjectMap;
+import it.unimi.dsi.fastutil.ints.Int2ObjectOpenHashMap;
import net.minecraft.server.level.ChunkProviderServer;
import net.minecraft.server.level.EntityTrackerEntry;
import net.minecraft.server.level.PlayerChunkMap;
@@ -16,10 +18,8 @@ import net.minecraft.server.level.PlayerChunkMap.EntityTracker;
import net.minecraft.server.level.WorldServer;
import net.minecraft.world.entity.Entity;
-import org.bukkit.craftbukkit.libs.it.unimi.dsi.fastutil.ints.Int2ObjectMap;
-import org.bukkit.craftbukkit.libs.it.unimi.dsi.fastutil.ints.Int2ObjectOpenHashMap;
-import org.bukkit.craftbukkit.v1_17_R1.CraftWorld;
-import org.bukkit.craftbukkit.v1_17_R1.entity.CraftEntity;
+import org.bukkit.craftbukkit.v1_18_R1.CraftWorld;
+import org.bukkit.craftbukkit.v1_18_R1.entity.CraftEntity;
import org.junit.BeforeClass;
import org.junit.Test;
@@ -45,7 +45,7 @@ public class EntityUtilitiesTest {
when(bukkit.getHandle()).thenReturn(world);
ChunkProviderServer provider = mock(ChunkProviderServer.class);
- when(world.getChunkProvider()).thenReturn(provider);
+ when(world.k()).thenReturn(provider);
PlayerChunkMap chunkMap = mock(PlayerChunkMap.class);
Field chunkMapField = FuzzyReflection.fromClass(ChunkProviderServer.class, true)
diff --git a/src/test/java/com/comphenix/protocol/injector/PluginVerifierTest.java b/src/test/java/com/comphenix/protocol/injector/PluginVerifierTest.java
index 15febf7f..b730cb8e 100644
--- a/src/test/java/com/comphenix/protocol/injector/PluginVerifierTest.java
+++ b/src/test/java/com/comphenix/protocol/injector/PluginVerifierTest.java
@@ -1,7 +1,7 @@
package com.comphenix.protocol.injector;
import static org.junit.Assert.assertEquals;
-import static org.mockito.Matchers.anyString;
+import static org.mockito.ArgumentMatchers.anyString;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
@@ -26,7 +26,7 @@ import com.google.common.collect.Lists;
// Damn final classes
@RunWith(org.powermock.modules.junit4.PowerMockRunner.class)
-@PowerMockIgnore({ "org.apache.log4j.*", "org.apache.logging.*", "org.bukkit.craftbukkit.libs.jline.*" })
+@PowerMockIgnore({ "org.apache.logging.log4j.core.config.xml.*", "javax.management.*" })
@PrepareForTest(PluginDescriptionFile.class)
public class PluginVerifierTest {
@Test
diff --git a/src/test/java/com/comphenix/protocol/utility/MinecraftReflectionTest.java b/src/test/java/com/comphenix/protocol/utility/MinecraftReflectionTest.java
index 62b72e74..81dcf41e 100644
--- a/src/test/java/com/comphenix/protocol/utility/MinecraftReflectionTest.java
+++ b/src/test/java/com/comphenix/protocol/utility/MinecraftReflectionTest.java
@@ -8,7 +8,7 @@ import static org.mockito.Mockito.verify;
import org.bukkit.Material;
import org.bukkit.block.Block;
-import org.bukkit.craftbukkit.v1_17_R1.inventory.CraftItemStack;
+import org.bukkit.craftbukkit.v1_18_R1.inventory.CraftItemStack;
import org.bukkit.entity.Entity;
import org.bukkit.inventory.ItemStack;
import org.junit.AfterClass;
@@ -31,7 +31,7 @@ import net.minecraft.world.level.ChunkCoordIntPair;
import net.minecraft.world.level.block.state.IBlockData;
@RunWith(org.powermock.modules.junit4.PowerMockRunner.class)
-@PowerMockIgnore({ "org.apache.log4j.*", "org.apache.logging.*", "org.bukkit.craftbukkit.libs.jline.*" })
+@PowerMockIgnore({ "org.apache.logging.log4j.core.config.xml.*", "javax.management.*" })
public class MinecraftReflectionTest {
@BeforeClass
diff --git a/src/test/java/com/comphenix/protocol/utility/StreamSerializerTest.java b/src/test/java/com/comphenix/protocol/utility/StreamSerializerTest.java
index fc1ad6a4..9ff6eb86 100644
--- a/src/test/java/com/comphenix/protocol/utility/StreamSerializerTest.java
+++ b/src/test/java/com/comphenix/protocol/utility/StreamSerializerTest.java
@@ -19,7 +19,7 @@ import static com.comphenix.protocol.utility.TestUtils.assertItemsEqual;
import static org.junit.Assert.assertEquals;
@RunWith(org.powermock.modules.junit4.PowerMockRunner.class)
-@PowerMockIgnore({ "org.apache.log4j.*", "org.apache.logging.*", "org.bukkit.craftbukkit.libs.jline.*" })
+@PowerMockIgnore({ "org.apache.logging.log4j.core.config.xml.*", "org.bukkit.craftbukkit.libs.jline.*" })
//@PrepareForTest(CraftItemFactory.class)
public class StreamSerializerTest {
diff --git a/src/test/java/com/comphenix/protocol/wrappers/ChunkCoordIntPairTest.java b/src/test/java/com/comphenix/protocol/wrappers/ChunkCoordIntPairTest.java
index 1c73e805..39d25feb 100644
--- a/src/test/java/com/comphenix/protocol/wrappers/ChunkCoordIntPairTest.java
+++ b/src/test/java/com/comphenix/protocol/wrappers/ChunkCoordIntPairTest.java
@@ -26,7 +26,7 @@ public class ChunkCoordIntPairTest {
(net.minecraft.world.level.ChunkCoordIntPair) ChunkCoordIntPair.getConverter().
getGeneric(specific);
- assertEquals(1, roundtrip.b);
- assertEquals(2, roundtrip.c);
+ assertEquals(1, roundtrip.c);
+ assertEquals(2, roundtrip.d);
}
}
diff --git a/src/test/java/com/comphenix/protocol/wrappers/MultiBlockChangeTest.java b/src/test/java/com/comphenix/protocol/wrappers/MultiBlockChangeTest.java
index a34123b1..92e74d82 100644
--- a/src/test/java/com/comphenix/protocol/wrappers/MultiBlockChangeTest.java
+++ b/src/test/java/com/comphenix/protocol/wrappers/MultiBlockChangeTest.java
@@ -33,7 +33,7 @@ import com.comphenix.protocol.utility.MinecraftReflection;
* @author dmulloy2
*/
@RunWith(org.powermock.modules.junit4.PowerMockRunner.class)
-@PowerMockIgnore({ "org.apache.log4j.*", "org.apache.logging.*", "org.bukkit.craftbukkit.libs.jline.*" })
+@PowerMockIgnore({ "org.apache.logging.log4j.core.config.xml.*", "javax.management.*" })
public class MultiBlockChangeTest {
// @BeforeClass
diff --git a/src/test/java/com/comphenix/protocol/wrappers/WrappedAttributeTest.java b/src/test/java/com/comphenix/protocol/wrappers/WrappedAttributeTest.java
index d6921465..7ae44a98 100644
--- a/src/test/java/com/comphenix/protocol/wrappers/WrappedAttributeTest.java
+++ b/src/test/java/com/comphenix/protocol/wrappers/WrappedAttributeTest.java
@@ -92,7 +92,7 @@ public class WrappedAttributeTest {
modifiers.add((AttributeModifier) wrapper.getHandle());
}
- AttributeBase base = IRegistry.al.get(MinecraftKey.a(attribute.getAttributeKey()));
+ AttributeBase base = IRegistry.am.a(MinecraftKey.a(attribute.getAttributeKey()));
return new AttributeSnapshot(base, attribute.getBaseValue(), modifiers);
}
diff --git a/src/test/java/com/comphenix/protocol/wrappers/WrappedBlockDataTest.java b/src/test/java/com/comphenix/protocol/wrappers/WrappedBlockDataTest.java
index 4ee165d6..2a5265da 100644
--- a/src/test/java/com/comphenix/protocol/wrappers/WrappedBlockDataTest.java
+++ b/src/test/java/com/comphenix/protocol/wrappers/WrappedBlockDataTest.java
@@ -23,9 +23,9 @@ import net.minecraft.world.level.block.state.IBlockData;
import org.bukkit.Material;
import org.bukkit.block.BlockFace;
import org.bukkit.block.data.type.GlassPane;
-import org.bukkit.craftbukkit.v1_17_R1.block.data.CraftBlockData;
-import org.bukkit.craftbukkit.v1_17_R1.block.impl.CraftStainedGlassPane;
-import org.bukkit.craftbukkit.v1_17_R1.util.CraftMagicNumbers;
+import org.bukkit.craftbukkit.v1_18_R1.block.data.CraftBlockData;
+import org.bukkit.craftbukkit.v1_18_R1.block.impl.CraftStainedGlassPane;
+import org.bukkit.craftbukkit.v1_18_R1.util.CraftMagicNumbers;
import org.junit.BeforeClass;
import org.junit.Test;
@@ -60,7 +60,7 @@ public class WrappedBlockDataTest {
@Test
public void testDataCreation() {
- IBlockData nmsData = CraftMagicNumbers.getBlock(Material.CYAN_STAINED_GLASS_PANE).getBlockData();
+ IBlockData nmsData = CraftMagicNumbers.getBlock(Material.CYAN_STAINED_GLASS_PANE).n();
GlassPane data = (GlassPane) CraftBlockData.fromData(nmsData);
data.setFace(BlockFace.EAST, true);
diff --git a/src/test/java/com/comphenix/protocol/wrappers/WrappedDataWatcherTest.java b/src/test/java/com/comphenix/protocol/wrappers/WrappedDataWatcherTest.java
index 14841c97..43289042 100644
--- a/src/test/java/com/comphenix/protocol/wrappers/WrappedDataWatcherTest.java
+++ b/src/test/java/com/comphenix/protocol/wrappers/WrappedDataWatcherTest.java
@@ -25,8 +25,8 @@ import com.comphenix.protocol.wrappers.WrappedDataWatcher.WrappedDataWatcherObje
import net.minecraft.world.entity.projectile.EntityEgg;
-import org.bukkit.craftbukkit.v1_17_R1.entity.CraftEgg;
-import org.bukkit.craftbukkit.v1_17_R1.entity.CraftEntity;
+import org.bukkit.craftbukkit.v1_18_R1.entity.CraftEgg;
+import org.bukkit.craftbukkit.v1_18_R1.entity.CraftEntity;
import org.junit.BeforeClass;
import org.junit.Test;
diff --git a/src/test/java/com/comphenix/protocol/wrappers/nbt/NbtFactoryTest.java b/src/test/java/com/comphenix/protocol/wrappers/nbt/NbtFactoryTest.java
index abf718f5..d96e3c0f 100644
--- a/src/test/java/com/comphenix/protocol/wrappers/nbt/NbtFactoryTest.java
+++ b/src/test/java/com/comphenix/protocol/wrappers/nbt/NbtFactoryTest.java
@@ -48,7 +48,7 @@ import net.minecraft.world.item.ItemStack;
import net.minecraft.world.item.Items;
@RunWith(org.powermock.modules.junit4.PowerMockRunner.class)
-@PowerMockIgnore({ "org.apache.log4j.*", "org.apache.logging.*", "org.bukkit.craftbukkit.libs.jline.*" })
+@PowerMockIgnore({ "org.apache.logging.log4j.core.config.xml.*", "javax.management.*" })
//@PrepareForTest(CraftItemFactory.class)
public class NbtFactoryTest {
@BeforeClass