Skip to content

Commit 91edc7c

Browse files
committed
test: add jboss eap-8.1 cases
1 parent b6caa04 commit 91edc7c

File tree

1 file changed

+89
-0
lines changed

1 file changed

+89
-0
lines changed
Lines changed: 89 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,89 @@
1+
package com.reajason.javaweb.integration.memshell.jbosseap;
2+
3+
import com.reajason.javaweb.Server;
4+
import com.reajason.javaweb.integration.ShellAssertion;
5+
import com.reajason.javaweb.integration.TestCasesProvider;
6+
import com.reajason.javaweb.memshell.ShellTool;
7+
import com.reajason.javaweb.memshell.ShellType;
8+
import com.reajason.javaweb.packer.Packers;
9+
import lombok.extern.slf4j.Slf4j;
10+
import net.bytebuddy.jar.asm.Opcodes;
11+
import org.junit.jupiter.api.AfterAll;
12+
import org.junit.jupiter.params.ParameterizedTest;
13+
import org.junit.jupiter.params.provider.Arguments;
14+
import org.junit.jupiter.params.provider.MethodSource;
15+
import org.junit.jupiter.params.provider.ValueSource;
16+
import org.testcontainers.containers.GenericContainer;
17+
import org.testcontainers.containers.Network;
18+
import org.testcontainers.containers.wait.strategy.Wait;
19+
import org.testcontainers.images.builder.ImageFromDockerfile;
20+
import org.testcontainers.junit.jupiter.Container;
21+
import org.testcontainers.junit.jupiter.Testcontainers;
22+
23+
import java.util.List;
24+
import java.util.stream.Stream;
25+
26+
import static com.reajason.javaweb.integration.ContainerTool.*;
27+
import static com.reajason.javaweb.integration.DoesNotContainExceptionMatcher.doesNotContainException;
28+
import static com.reajason.javaweb.integration.ShellAssertion.shellInjectIsOk;
29+
import static org.hamcrest.MatcherAssert.assertThat;
30+
31+
/**
32+
* @author ReaJason
33+
* @since 2024/12/10
34+
*/
35+
@Slf4j
36+
@Testcontainers
37+
public class JbossEap81ContainerTest {
38+
public static final String imageName = "reajason/jboss:eap-8.1-jdk17";
39+
static Network network = Network.newNetwork();
40+
@Container
41+
public final static GenericContainer<?> python = new GenericContainer<>(new ImageFromDockerfile()
42+
.withDockerfile(neoGeorgDockerfile))
43+
.withNetwork(network);
44+
@Container
45+
public static final GenericContainer<?> container = new GenericContainer<>(imageName)
46+
.withCopyToContainer(warJakartaFile, "/usr/local/jboss/standalone/deployments/app.war")
47+
.withCopyToContainer(jattachFile, "/jattach")
48+
.withCopyToContainer(jbossPid, "/fetch_pid.sh")
49+
.withNetwork(network)
50+
.withNetworkAliases("app")
51+
.waitingFor(Wait.forHttp("/app"))
52+
.withExposedPorts(8080);
53+
54+
static Stream<Arguments> casesProvider() {
55+
String server = Server.Undertow;
56+
List<String> supportedShellTypes = List.of(
57+
ShellType.JAKARTA_SERVLET,
58+
ShellType.JAKARTA_FILTER,
59+
ShellType.JAKARTA_LISTENER,
60+
ShellType.UNDERTOW_AGENT_SERVLET_HANDLER
61+
);
62+
List<Packers> testPackers = List.of(Packers.JSP);
63+
return TestCasesProvider.getTestCases(imageName, server, supportedShellTypes, testPackers,
64+
null, List.of(ShellTool.AntSword) // AntSword not support jakarta
65+
);
66+
}
67+
68+
@AfterAll
69+
static void tearDown() {
70+
String logs = container.getLogs();
71+
log.info(logs);
72+
assertThat("Logs should not contain any exceptions", logs, doesNotContainException());
73+
}
74+
75+
@ParameterizedTest(name = "{0}|{1}{2}|{3}")
76+
@MethodSource("casesProvider")
77+
void test(String imageName, String shellType, String shellTool, Packers packer) {
78+
shellInjectIsOk(getUrl(container), Server.Undertow, shellType, shellTool, Opcodes.V17, packer, container, python);
79+
}
80+
81+
@ParameterizedTest
82+
@ValueSource(strings = {ShellType.JAKARTA_SERVLET,
83+
ShellType.JAKARTA_FILTER,
84+
ShellType.JAKARTA_LISTENER,})
85+
void testProbeInject(String shellType) {
86+
String url = getUrl(container);
87+
ShellAssertion.testProbeInject(url, Server.Undertow, shellType, Opcodes.V17);
88+
}
89+
}

0 commit comments

Comments
 (0)