使用Github Actions 组织从代码开发到git提交,再到持续集成测试的流程。 1.要求配置自动编译和打包2. 要求配置后台测试任务,并获取测试报告详细包括代码步骤
时间: 2024-02-11 17:04:02 浏览: 129
非常感谢您的提问,以下是使用Github Actions组织从代码开发到持续集成测试的完整流程,同时满足自动编译和打包、后台测试任务以及获取测试报告详细包括代码步骤的要求。
1. 在Github上创建一个新的repository,命名为你的项目名。
2. 在本地创建一个新的项目文件夹,打开命令行工具,使用git init命令初始化仓库。
3. 使用git remote add命令将本地仓库与Github仓库关联。
4. 在本地项目文件夹中添加Java代码并提交到Github仓库中。
接下来,我们需要使用Github Actions来实现从代码开发到持续集成测试的流程。
1. 在Github仓库中创建一个.github/workflows目录,用于存放Actions配置文件。
2. 在该目录下创建一个yaml文件,命名为ci.yaml,用于配置Actions的流程。
3. 在ci.yaml文件中,我们可以使用以下步骤:
```
name: CI
on:
push:
branches: [ main ]
pull_request:
branches: [ main ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Set up JDK 11
uses: actions/setup-java@v2
with:
java-version: '11'
- name: Build with Maven
run: mvn -B package --file pom.xml
- name: Run Tests
run: mvn test
env:
DATABASE_URL: jdbc:mysql://localhost:3306/test
DATABASE_USERNAME: root
DATABASE_PASSWORD: password
- name: Publish Test Results
uses: EnricoMi/publish-unit-test-result-action@v1.4
with:
files: **/surefire-reports/TEST-*.xml
- name: Build and push Docker image
uses: docker/build-push-action@v2
with:
context: .
push: true
tags: your-docker-registry/your-image-name:latest
env:
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }}
```
该配置文件的作用是:
- 当代码提交到main分支或有pull request时,触发Actions的执行;
- 在Ubuntu最新版本上执行Actions;
- 克隆Github仓库代码;
- 配置JDK 11;
- 使用Maven编译和打包代码;
- 运行测试,并使用环境变量配置数据库连接信息;
- 发布测试报告;
- 通过Docker构建和推送镜像到Docker Registry,并使用Github Secrets来保存Docker Registry的用户名和密码。
在这个流程中,我们使用了Maven来管理Java项目的依赖和编译打包工作,使用EnricoMi/publish-unit-test-result-action来将测试报告发布到Github Actions的界面上,使用Docker来构建和推送镜像,并使用Github Secrets来保存敏感信息。
总之,以上就是使用Github Actions组织从代码开发到持续集成测试的完整流程,同时满足自动编译和打包、后台测试任务以及获取测试报告详细包括代码步骤的要求。希望能对您有所帮助。
阅读全文