1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package io.netty5.testsuite.transport;
17
18 import io.netty5.bootstrap.AbstractBootstrap;
19 import io.netty5.buffer.api.BufferAllocator;
20 import io.netty5.testsuite.transport.TestsuitePermutation.AllocatorConfig;
21 import io.netty5.testsuite.util.TestUtils;
22 import io.netty5.util.internal.StringUtil;
23 import io.netty5.util.internal.logging.InternalLogger;
24 import io.netty5.util.internal.logging.InternalLoggerFactory;
25 import org.junit.jupiter.api.TestInfo;
26
27 import java.util.List;
28
29 public abstract class AbstractTestsuiteTest<T extends AbstractBootstrap<?, ?, ?>> {
30 protected final InternalLogger logger = InternalLoggerFactory.getInstance(getClass());
31 protected volatile T cb;
32
33 protected abstract List<TestsuitePermutation.BootstrapFactory<T>> newFactories();
34
35 protected List<AllocatorConfig> newAllocators() {
36 return TestsuitePermutation.allocator();
37 }
38
39 protected void run(TestInfo testInfo, Runner<T> runner) throws Throwable {
40 List<TestsuitePermutation.BootstrapFactory<T>> combos = newFactories();
41 String methodName = TestUtils.testMethodName(testInfo);
42 for (AllocatorConfig config: newAllocators()) {
43 int i = 0;
44 for (TestsuitePermutation.BootstrapFactory<T> e: combos) {
45 cb = e.newInstance();
46 configure(cb, config.bufferAllocator);
47 logger.info(String.format(
48 "Running: %s %d of %d with %s",
49 methodName, ++ i, combos.size(), StringUtil.simpleClassName(config.bufferAllocator)));
50 runner.run(cb);
51 }
52 }
53 }
54
55 protected abstract void configure(T bootstrap, BufferAllocator bufferAllocator);
56
57 public interface Runner<CB extends AbstractBootstrap<?, ?, ?>> {
58 void run(CB cb) throws Throwable;
59 }
60 }