-
-
Notifications
You must be signed in to change notification settings - Fork 738
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add some tests for JDABuilder intents and cache flags (#2762)
- Loading branch information
1 parent
53adaa1
commit 5d9e36c
Showing
3 changed files
with
273 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,211 @@ | ||
/* | ||
* Copyright 2015 Austin Keener, Michael Ritter, Florian Spieß, and the JDA contributors | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package net.dv8tion.jda.test; | ||
|
||
import net.dv8tion.jda.api.JDABuilder; | ||
import net.dv8tion.jda.api.requests.GatewayIntent; | ||
import net.dv8tion.jda.api.utils.ChunkingFilter; | ||
import net.dv8tion.jda.api.utils.cache.CacheFlag; | ||
import org.junit.jupiter.api.Test; | ||
import org.junit.jupiter.params.ParameterizedTest; | ||
import org.junit.jupiter.params.provider.EnumSource; | ||
|
||
import java.util.EnumSet; | ||
import java.util.List; | ||
import java.util.stream.Collectors; | ||
|
||
import static net.dv8tion.jda.api.requests.GatewayIntent.ALL_INTENTS; | ||
import static net.dv8tion.jda.test.TestHelper.captureLogging; | ||
import static org.assertj.core.api.Assertions.*; | ||
|
||
public class JDABuilderTest | ||
{ | ||
private static final String TOKEN = "invalid.token.here"; | ||
|
||
@Test | ||
void testCreateWithAllIntents() | ||
{ | ||
TestJDABuilder builder = new TestJDABuilder(ALL_INTENTS); | ||
builder.applyIntents(); | ||
|
||
List<String> logs = captureLogging(builder::checkIntents); | ||
assertThat(logs).isEmpty(); | ||
} | ||
|
||
@Test | ||
void testCreateWithMinimalIntents() | ||
{ | ||
TestJDABuilder builder = new TestJDABuilder(0); | ||
builder.applyIntents(); | ||
|
||
List<String> logs = captureLogging(builder::checkIntents); | ||
|
||
EnumSet<CacheFlag> flags = EnumSet.allOf(CacheFlag.class); | ||
flags.removeIf(flag -> flag.getRequiredIntent() == null); | ||
checkMissingIntentWarnings(logs, flags); | ||
} | ||
|
||
@Test | ||
void testCreateWithAllCacheAllIntents() | ||
{ | ||
TestJDABuilder builder = new TestJDABuilder(ALL_INTENTS); | ||
builder.applyIntents(); | ||
builder.enableCache(EnumSet.allOf(CacheFlag.class)); | ||
|
||
List<String> logs = captureLogging(builder::checkIntents); | ||
assertThat(logs).isEmpty(); | ||
} | ||
|
||
@Test | ||
void testCreateWithAllCacheNoIntents() | ||
{ | ||
TestJDABuilder builder = new TestJDABuilder(0); | ||
builder.applyIntents(); | ||
builder.enableCache(EnumSet.allOf(CacheFlag.class)); | ||
|
||
assertThatIllegalArgumentException() | ||
.isThrownBy(builder::checkIntents) | ||
.withMessage("Cannot use CacheFlag.ACTIVITY without GatewayIntent.GUILD_PRESENCES!"); | ||
} | ||
|
||
@ParameterizedTest | ||
@EnumSource(CacheFlag.class) | ||
void testRequiredIntentForCacheFlagMissing(CacheFlag cacheFlag) | ||
{ | ||
TestJDABuilder builder = new TestJDABuilder(0); | ||
builder.applyIntents(); | ||
builder.enableCache(cacheFlag); | ||
|
||
if (cacheFlag.getRequiredIntent() != null) | ||
{ | ||
assertThatIllegalArgumentException() | ||
.isThrownBy(builder::checkIntents) | ||
.withMessage(String.format("Cannot use CacheFlag.%s without GatewayIntent.%s!", cacheFlag, cacheFlag.getRequiredIntent())); | ||
} | ||
else | ||
{ | ||
assertThatNoException().isThrownBy(builder::checkIntents); | ||
} | ||
} | ||
|
||
|
||
@ParameterizedTest | ||
@EnumSource(CacheFlag.class) | ||
void testRequiredIntentForCacheFlagEnabled(CacheFlag cacheFlag) | ||
{ | ||
GatewayIntent requiredIntent = cacheFlag.getRequiredIntent(); | ||
TestJDABuilder builder = new TestJDABuilder(requiredIntent != null ? requiredIntent.getRawValue() : 0); | ||
builder.applyIntents(); | ||
builder.enableCache(cacheFlag); | ||
|
||
assertThatNoException().isThrownBy(builder::checkIntents); | ||
} | ||
|
||
@Test | ||
void testDefaultMinimal() | ||
{ | ||
TestJDABuilder builder = new TestJDABuilder(0); | ||
builder.applyIntents(); | ||
builder.applyDefault(); | ||
|
||
EnumSet<CacheFlag> defaultDisabled = CacheFlag.getPrivileged(); | ||
EnumSet<CacheFlag> flags = EnumSet.allOf(CacheFlag.class); | ||
flags.removeIf(flag -> flag.getRequiredIntent() == null || defaultDisabled.contains(flag)); | ||
|
||
List<String> logs = captureLogging(builder::checkIntents); | ||
checkMissingIntentWarnings(logs, flags); | ||
} | ||
|
||
@Test | ||
void testChunkingWithMissingIntent() | ||
{ | ||
TestJDABuilder builder = new TestJDABuilder(0); | ||
builder.applyIntents(); | ||
builder.setChunkingFilter(ChunkingFilter.ALL); | ||
|
||
List<String> logs = captureLogging(builder::checkIntents); | ||
assertThat(logs).contains("Member chunking is disabled due to missing GUILD_MEMBERS intent."); | ||
} | ||
|
||
@Test | ||
@SuppressWarnings("deprecation") | ||
void testDeprecatedIntentDoesNotDisableCache() | ||
{ | ||
TestJDABuilder builder = new TestJDABuilder(GatewayIntent.GUILD_EMOJIS_AND_STICKERS.getRawValue()); | ||
builder.applyIntents(); | ||
|
||
List<String> logs = captureLogging(() -> | ||
assertThatNoException().isThrownBy(builder::checkIntents) | ||
); | ||
|
||
assertThat(logs) | ||
.isNotEmpty() | ||
.noneMatch(log -> log.contains("CacheFlag." + CacheFlag.EMOJI)) | ||
.noneMatch(log -> log.contains("CacheFlag." + CacheFlag.STICKER)); | ||
} | ||
|
||
private void checkMissingIntentWarnings(List<String> logs, EnumSet<CacheFlag> cacheFlagsWithMissingIntents) | ||
{ | ||
String commaSeparatedList = cacheFlagsWithMissingIntents.stream() | ||
.map(CacheFlag::name) | ||
.map(name -> "CacheFlag." + name) | ||
.collect(Collectors.joining(", ")); | ||
|
||
String listOfWarnings = cacheFlagsWithMissingIntents.stream() | ||
.map(flag -> String.format("Disabled CacheFlag.%s (missing GatewayIntent.%s)", flag.name(), flag.getRequiredIntent().name())) | ||
.collect(Collectors.joining("\n")); | ||
|
||
assertThat(String.join("\n", logs)) | ||
.isEqualToIgnoringWhitespace( | ||
"Automatically disabled CacheFlags due to missing intents\n" + | ||
listOfWarnings + "\n" + | ||
"You can manually disable these flags to remove this warning by using disableCache(" + commaSeparatedList + ") on your JDABuilder" | ||
); | ||
} | ||
|
||
static class TestJDABuilder extends JDABuilder | ||
{ | ||
public TestJDABuilder(int intents) | ||
{ | ||
super(TOKEN, intents); | ||
} | ||
|
||
@Override | ||
public JDABuilder applyDefault() | ||
{ | ||
return super.applyDefault(); | ||
} | ||
|
||
@Override | ||
public JDABuilder applyLight() | ||
{ | ||
return super.applyLight(); | ||
} | ||
|
||
@Override | ||
public JDABuilder applyIntents() | ||
{ | ||
return super.applyIntents(); | ||
} | ||
|
||
@Override | ||
public void checkIntents() | ||
{ | ||
super.checkIntents(); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
/* | ||
* Copyright 2015 Austin Keener, Michael Ritter, Florian Spieß, and the JDA contributors | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package net.dv8tion.jda.test; | ||
|
||
import ch.qos.logback.classic.spi.ILoggingEvent; | ||
import ch.qos.logback.core.read.ListAppender; | ||
import org.slf4j.Logger; | ||
import org.slf4j.LoggerFactory; | ||
|
||
import java.util.List; | ||
import java.util.stream.Collectors; | ||
|
||
import static org.assertj.core.api.Assertions.assertThat; | ||
|
||
public class TestHelper | ||
{ | ||
public static List<String> captureLogging(Runnable task) | ||
{ | ||
return captureLogging(LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME), task); | ||
} | ||
|
||
public static List<String> captureLogging(Logger logger, Runnable task) | ||
{ | ||
assertThat(logger).isInstanceOf(ch.qos.logback.classic.Logger.class); | ||
ch.qos.logback.classic.Logger logbackLogger = (ch.qos.logback.classic.Logger) logger; | ||
|
||
ListAppender<ILoggingEvent> listAppender = new ListAppender<>(); | ||
listAppender.start(); | ||
logbackLogger.addAppender(listAppender); | ||
try | ||
{ | ||
task.run(); | ||
return listAppender.list | ||
.stream().map(ILoggingEvent::getFormattedMessage) | ||
.collect(Collectors.toList()); | ||
} | ||
finally | ||
{ | ||
logbackLogger.detachAppender(listAppender); | ||
listAppender.stop(); | ||
} | ||
} | ||
} |