
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
java-crossdock 是一款专为 Java 应用集成测试设计的 Docker 镜像,基于 Crossdock 测试框架构建。该镜像提供标准化的测试环境与工具链,支持开发者对 Java 应用(尤其是分布式、微服务架构中的组件)进行跨服务、跨依赖的集成测试验证,简化测试环境配置流程,提升测试效率。
eclipse-temurin:${JAVA_VERSION}-alpine),减少镜像体积。java-crossdock 镜像自动执行集成测试用例,拦截潜在跨服务兼容性问题。java-crossdock 配置,确保测试结果不受环境差异影响。通过 docker run 命令启动测试容器,指定测试目标服务地址与必要参数:
bashdocker run -d \ --name java-crossdock-test \ -e TEST_TARGET_URL="http://service-a:8080/api/v1" \ # 被测服务地址 -e JAVA_VERSION="11" \ # Java 版本(可选,默认 11) -e TEST_TIMEOUT="30s" \ # 测试超时时间(默认 30s) -v $(pwd)/test-cases:/app/test-cases \ # 挂载本地测试用例目录 java-crossdock:latest
在微服务测试场景中,可通过 docker-compose.yml 编排被测服务与 java-crossdock 测试容器,实现多服务联动测试:
yamlversion: '3.8' services: # 被测服务(示例:Java 微服务 service-a) service-a: image: my-java-service:latest ports: - "8080:8080" environment: - SPRING_PROFILES_ACTIVE=test # 测试容器(java-crossdock) crossdock-test: image: java-crossdock:latest depends_on: - service-a # 等待被测服务启动完成 environment: - TEST_TARGET_URL="http://service-a:8080/api/v1" # 被测服务内部访问地址 - TEST_CASES_PATH="/app/test-cases" # 测试用例存放路径 - LOG_LEVEL="INFO" # 日志级别(默认 INFO) volumes: - ./local-test-cases:/app/test-cases # 挂载本地测试用例(如 JUnit 测试类) command: ["java", "-jar", "/app/crossdock-runner.jar", "--cases", "${TEST_CASES_PATH}"]
| 环境变量名 | 描述 | 默认值 | 可选值 |
|---|---|---|---|
TEST_TARGET_URL | 被测服务的基础 URL(如 http://service:port) | 无(必填) | 合法 HTTP/HTTPS 地址 |
JAVA_VERSION | 运行时 Java 版本 | 11 | 8, 11, 17 |
TEST_TIMEOUT | 单条测试用例超时时间 | 30s | 如 10s, 1m(支持 s/m/h) |
TEST_CASES_PATH | 测试用例文件存放路径(容器内路径) | /app/test-cases | 容器内可访问的目录路径 |
LOG_LEVEL | 测试日志级别 | INFO | DEBUG, INFO, WARN, ERROR |
RETRY_COUNT | 测试失败重试次数 | 0 | 非负整数 |
测试执行完成后,结果默认通过标准输出(STDOUT)打印,格式如下:
[INFO] Test Summary: [INFO] Total Cases: 5 [INFO] Passed: 4 [INFO] Failed: 1 [INFO] Failed Case: TestUserCreation (Reason: Timeout connecting to service-a)
如需结构化报告,可通过 -e REPORT_PATH="/app/report.json" 指定 JSON 报告输出路径,报告内容包含测试用例详情、耗时、错误堆栈等信息。
CrossdockTestCase 基类,实现 run() 方法),或通过 -e CUSTOM_RUNNER="true" 启用自定义测试执行器。bridge 网络),或通过 networks 字段显式指定自定义网络。--memory=2g --cpus=1),避免因资源不足导致测试超时。您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务