mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 13:12:12 +08:00 
			
		
		
		
	refactor: improve workflows logic.
This commit is contained in:
		
							parent
							
								
									47e916aebe
								
							
						
					
					
						commit
						3918f4717f
					
				| @ -19,26 +19,26 @@ jobs: | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v3 | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Set up Docker Buildx | ||||
|         uses: docker/setup-buildx-action@v2 | ||||
|         uses: docker/setup-buildx-action@v3.8.0 | ||||
| 
 | ||||
|       - name: Log in to Docker Hub | ||||
|         uses: docker/login-action@v2 | ||||
|         uses: docker/login-action@v3.3.0 | ||||
|         with: | ||||
|           username: ${{ secrets.DOCKER_USERNAME }} | ||||
|           password: ${{ secrets.DOCKER_PASSWORD }} | ||||
| 
 | ||||
|       - name: Log in to GitHub Container Registry | ||||
|         uses: docker/login-action@v2 | ||||
|         uses: docker/login-action@v3.3.0 | ||||
|         with: | ||||
|           registry: ghcr.io | ||||
|           username: ${{ github.repository_owner }} | ||||
|           password: ${{ secrets.GITHUB_TOKEN }} | ||||
| 
 | ||||
|       - name: Log in to Aliyun Container Registry | ||||
|         uses: docker/login-action@v2 | ||||
|         uses: docker/login-action@v3.3.0 | ||||
|         with: | ||||
|           registry: registry.cn-hangzhou.aliyuncs.com | ||||
|           username: ${{ secrets.ALIREGISTRY_USERNAME }} | ||||
| @ -46,7 +46,7 @@ jobs: | ||||
| 
 | ||||
|       - name: Extract metadata for Docker (tags, labels) | ||||
|         id: meta | ||||
|         uses: docker/metadata-action@v5 | ||||
|         uses: docker/metadata-action@v5.6.0 | ||||
|         with: | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
| @ -54,7 +54,6 @@ jobs: | ||||
|             type=ref,event=branch | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             # type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern=release-{{raw}} | ||||
|             type=sha | ||||
|             type=raw,value=${{ github.event.inputs.tag }} | ||||
|  | ||||
							
								
								
									
										136
									
								
								.github/workflows/go-build-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										136
									
								
								.github/workflows/go-build-test.yml
									
									
									
									
										vendored
									
									
								
							| @ -4,7 +4,7 @@ on: | ||||
|   push: | ||||
|   pull_request: | ||||
|     paths-ignore: | ||||
|       - '**/*.md' | ||||
|       - "**/*.md" | ||||
| 
 | ||||
|   workflow_dispatch: | ||||
| 
 | ||||
| @ -18,7 +18,7 @@ jobs: | ||||
|     strategy: | ||||
|       matrix: | ||||
|         os: [ubuntu-latest] | ||||
|         go_version: ["1.21.x", "1.22.x"] | ||||
|         go_version: ["1.22.x"] | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout Server repository | ||||
| @ -41,23 +41,17 @@ jobs: | ||||
|         with: | ||||
|           compose-file: "./docker-compose.yml" | ||||
| 
 | ||||
|         # run: | | ||||
|         #   sudo docker compose up -d | ||||
|         #   sudo sleep 30  # Increased sleep time for better stability | ||||
|         # timeout-minutes: 60 # Increased timeout for Docker setup | ||||
|       # - name: Get Internal IP Address | ||||
|       #   id: get-ip | ||||
|       #   run: | | ||||
|       #     IP=$(hostname -I | awk '{print $1}') | ||||
|       #     echo "The IP Address is: $IP" | ||||
|       #     echo "::set-output name=ip::$IP" | ||||
| 
 | ||||
| 
 | ||||
|     # - name: Get Internal IP Address | ||||
|     #   id: get-ip | ||||
|     #   run: | | ||||
|     #     IP=$(hostname -I | awk '{print $1}') | ||||
|     #     echo "The IP Address is: $IP" | ||||
|     #     echo "::set-output name=ip::$IP" | ||||
|        | ||||
|     # - name: Update .env | ||||
|     #   run: | | ||||
|     #     sed -i 's|externalAddress:.*|externalAddress: "http://${{ steps.get-ip.outputs.ip }}:10005"|' config/minio.yml | ||||
|     #     cat config/minio.yml | ||||
|       # - name: Update .env | ||||
|       #   run: | | ||||
|       #     sed -i 's|externalAddress:.*|externalAddress: "http://${{ steps.get-ip.outputs.ip }}:10005"|' config/minio.yml | ||||
|       #     cat config/minio.yml | ||||
| 
 | ||||
|       - name: Build and test Server Services | ||||
|         run: | | ||||
| @ -85,6 +79,90 @@ jobs: | ||||
|           mage start | ||||
|           mage check | ||||
| 
 | ||||
|       - name: Test Server and Chat | ||||
|         run: | | ||||
|           check_error() { | ||||
|             echo "Response: $1" | ||||
|             errCode=$(echo $1 | jq -r '.errCode') | ||||
|             if [ "$errCode" != "0" ]; then | ||||
|               errMsg=$(echo $1 | jq -r '.errMsg') | ||||
|               echo "Error: $errMsg" | ||||
|               exit 1 | ||||
|             fi | ||||
|           } | ||||
| 
 | ||||
|           # Test register | ||||
|           response1=$(curl -X POST -H "Content-Type: application/json" -H "operationID: imAdmin" -d '{ | ||||
|             "verifyCode": "666666", | ||||
|             "platform": 3, | ||||
|             "autoLogin": true, | ||||
|             "user":{ | ||||
|             "nickname": "test12312", | ||||
|             "areaCode":"+86", | ||||
|             "phoneNumber": "12345678190", | ||||
|             "password":"test123456" | ||||
|             } | ||||
|           }' http://127.0.0.1:10008/account/register) | ||||
|           check_error "$response1" | ||||
|           userID1=$(echo $response1 | jq -r '.data.userID') | ||||
|           echo "userID1: $userID1" | ||||
| 
 | ||||
|           response2=$(curl -X POST -H "Content-Type: application/json" -H "operationID: imAdmin" -d '{ | ||||
|             "verifyCode": "666666", | ||||
|             "platform": 3, | ||||
|             "autoLogin": true, | ||||
|             "user":{ | ||||
|             "nickname": "test22312", | ||||
|             "areaCode":"+86", | ||||
|             "phoneNumber": "12345678290", | ||||
|             "password":"test123456" | ||||
|             } | ||||
|           }' http://127.0.0.1:10008/account/register) | ||||
|           check_error "$response2" | ||||
|           userID2=$(echo $response2 | jq -r '.data.userID') | ||||
|           echo "userID2: $userID2" | ||||
| 
 | ||||
|           # Test login | ||||
|           login_response=$(curl -X POST -H "Content-Type: application/json" -H "operationID: imAdmin"  -d '{ | ||||
|             "platform": 3, | ||||
|             "areaCode":"+86", | ||||
|             "phoneNumber": "12345678190", | ||||
|             "password":"test123456" | ||||
|           }' http://localhost:10008/account/login) | ||||
|           check_error "$login_response" | ||||
| 
 | ||||
|           # Test get admin token | ||||
|           get_admin_token_response=$(curl -X POST -H "Content-Type: application/json" -H "operationID: imAdmin" -d '{ | ||||
|             "secret": "openIM123", | ||||
|             "platformID": 2, | ||||
|             "userID": "imAdmin" | ||||
|           }' http://127.0.0.1:10002/auth/get_admin_token) | ||||
|           check_error "$get_admin_token_response" | ||||
|           adminToken=$(echo $get_admin_token_response | jq -r '.data.token') | ||||
|           echo "adminToken: $adminToken" | ||||
| 
 | ||||
|           # Test send message | ||||
|           send_msg_response=$(curl -X POST -H "Content-Type: application/json" -H "operationID: imAdmin" -H "token: $adminToken" -d '{ | ||||
|             "sendID": "'$userID1'", | ||||
|             "recvID": "'$userID2'", | ||||
|             "senderPlatformID": 3, | ||||
|             "content": { | ||||
|               "content": "hello!!" | ||||
|             }, | ||||
|             "contentType": 101, | ||||
|             "sessionType": 1 | ||||
|            }' http://127.0.0.1:10002/msg/send_msg) | ||||
|            check_error "$send_msg_response" | ||||
| 
 | ||||
|           # Test get users | ||||
|           get_users_response=$(curl -X POST -H "Content-Type: application/json" -H "operationID: imAdmin" -H "token: ${{ env.ADMIN_TOKEN }}" -d '{ | ||||
|             "pagination": { | ||||
|                "pageNumber": 1, | ||||
|                "showNumber": 100 | ||||
|              } | ||||
|             }' http://127.0.0.1:10002/user/get_users) | ||||
|           check_error "$get_users_response" | ||||
| 
 | ||||
|   go-test: | ||||
|     name: Benchmark Test with go ${{ matrix.go_version }} on ${{ matrix.os }} | ||||
|     runs-on: ${{ matrix.os }} | ||||
| @ -93,11 +171,11 @@ jobs: | ||||
|     env: | ||||
|       SDK_DIR: openim-sdk-core | ||||
|       CONFIG_PATH: config/notification.yml | ||||
|     #   pull-requests: write | ||||
| 
 | ||||
|     strategy: | ||||
|       matrix: | ||||
|         os: [ ubuntu-latest ] | ||||
|         go_version: [ "1.22.x" ] | ||||
|         os: [ubuntu-latest] | ||||
|         go_version: ["1.22.x"] | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout Server repository | ||||
| @ -106,7 +184,8 @@ jobs: | ||||
|       - name: Checkout SDK repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           repository: 'openimsdk/openim-sdk-core' | ||||
|           repository: "openimsdk/openim-sdk-core" | ||||
|           ref: "release-v3.8" | ||||
|           path: ${{ env.SDK_DIR }} | ||||
| 
 | ||||
|       - name: Set up Go ${{ matrix.go_version }} | ||||
| @ -119,11 +198,6 @@ jobs: | ||||
|           go install github.com/magefile/mage@latest | ||||
|           go mod download | ||||
| 
 | ||||
|       - name: Install yq | ||||
|         run: | | ||||
|           sudo wget https://github.com/mikefarah/yq/releases/download/v4.34.1/yq_linux_amd64 -O /usr/bin/yq | ||||
|           sudo chmod +x /usr/bin/yq | ||||
| 
 | ||||
|       - name: Modify Server Configuration | ||||
|         run: | | ||||
|           yq e '.groupCreated.isSendMsg = true' -i ${{ env.CONFIG_PATH }} | ||||
| @ -183,11 +257,3 @@ jobs: | ||||
|         run: | | ||||
|           CONTAINER_NAME="${{ github.event.repository.name }}-container" | ||||
|           docker logs $CONTAINER_NAME | ||||
| 
 | ||||
|       # - name: Cleanup Docker Container | ||||
|       #   run: | | ||||
|       #     CONTAINER_NAME="${{ github.event.repository.name }}-container" | ||||
|       #     IMAGE_NAME="${{ github.event.repository.name }}-test" | ||||
|       #     docker stop $CONTAINER_NAME | ||||
|       #     docker rm $CONTAINER_NAME | ||||
|       #     docker rmi $IMAGE_NAME | ||||
|  | ||||
							
								
								
									
										83
									
								
								.github/workflows/publish-docker-image.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										83
									
								
								.github/workflows/publish-docker-image.yml
									
									
									
									
										vendored
									
									
								
							| @ -25,11 +25,11 @@ jobs: | ||||
|         with: | ||||
|           path: main-repo | ||||
| 
 | ||||
|       - name: Set up QEMU | ||||
|         uses: docker/setup-qemu-action@v3 | ||||
|       # - name: Set up QEMU | ||||
|       #   uses: docker/setup-qemu-action@v3.3.0 | ||||
| 
 | ||||
|       - name: Set up Docker Buildx | ||||
|         uses: docker/setup-buildx-action@v3 | ||||
|         uses: docker/setup-buildx-action@v3.8.0 | ||||
| 
 | ||||
|       - name: Build Docker image | ||||
|         id: build | ||||
| @ -38,11 +38,8 @@ jobs: | ||||
|           context: ./main-repo | ||||
|           load: true | ||||
|           tags: "openim/openim-server:local" | ||||
|           cache-from: type=gha | ||||
|           cache-to: type=gha,mode=max | ||||
| 
 | ||||
|       - name: Save Docker image to file | ||||
|         run: docker save -o image.tar openim/openim-server:local | ||||
|           cache-from: type=gha,scope=build | ||||
|           cache-to: type=gha,mode=max,scope=build | ||||
| 
 | ||||
|       - name: Checkout compose repository | ||||
|         uses: actions/checkout@v4 | ||||
| @ -66,43 +63,12 @@ jobs: | ||||
|         run: | | ||||
|           cd ${{ github.workspace }}/compose-repo | ||||
|           docker compose up -d | ||||
|           sleep 60 | ||||
| 
 | ||||
|       # - name: Check openim-server health | ||||
|       #   run: | | ||||
|       #     timeout=300 | ||||
|       #     interval=30 | ||||
|       #     elapsed=0 | ||||
|       #     while [[ $elapsed -le $timeout ]]; do | ||||
|       #       if ! docker exec openim-server mage check; then | ||||
|       #         echo "openim-server is not ready, waiting..." | ||||
|       #         sleep $interval | ||||
|       #         elapsed=$(($elapsed + $interval)) | ||||
|       #       else | ||||
|       #         echo "Health check successful" | ||||
|       #         exit 0 | ||||
|       #       fi | ||||
|       #     done | ||||
|       #     echo "Health check failed after 5 minutes" | ||||
|       #     exit 1 | ||||
| 
 | ||||
|       # - name: Check openim-chat health | ||||
|       #   if: success() | ||||
|       #   run: | | ||||
|       #     if ! docker exec openim-chat mage check; then | ||||
|       #         echo "openim-chat check failed" | ||||
|       #         exit 1 | ||||
|       #       else | ||||
|       #         echo "Health check successful" | ||||
|       #         exit 0 | ||||
|       #       fi | ||||
| 
 | ||||
|       - name: Load Docker image from file | ||||
|         run: docker load -i image.tar | ||||
|           docker compose ps | ||||
| 
 | ||||
|       - name: Extract metadata for Docker (tags, labels) | ||||
|         id: meta | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         uses: docker/metadata-action@v5.6.0 | ||||
|         with: | ||||
|           images: | | ||||
|             openim/openim-server | ||||
| @ -112,29 +78,27 @@ jobs: | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=semver,pattern={{version}} | ||||
|             # type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern={{major}} | ||||
|             type=semver,pattern=release-{{raw}} | ||||
|             type=sha | ||||
|             type=raw,value=${{ github.event.inputs.tag }} | ||||
| 
 | ||||
|       - name: Log in to Docker Hub | ||||
|         uses: docker/login-action@v2 | ||||
|         uses: docker/login-action@v3.3.0 | ||||
|         with: | ||||
|           username: ${{ secrets.DOCKER_USERNAME }} | ||||
|           password: ${{ secrets.DOCKER_PASSWORD }} | ||||
| 
 | ||||
|       - name: Log in to GitHub Container Registry | ||||
|         uses: docker/login-action@v2 | ||||
|         uses: docker/login-action@v3.3.0 | ||||
|         with: | ||||
|           registry: ghcr.io | ||||
|           username: ${{ github.repository_owner }} | ||||
|           password: ${{ secrets.GITHUB_TOKEN }} | ||||
| 
 | ||||
|       - name: Log in to Aliyun Container Registry | ||||
|         uses: docker/login-action@v2 | ||||
|         uses: docker/login-action@v3.3.0 | ||||
|         with: | ||||
|           registry: registry.cn-hangzhou.aliyuncs.com | ||||
|           username: ${{ secrets.ALIREGISTRY_USERNAME }} | ||||
| @ -148,3 +112,28 @@ jobs: | ||||
|           platforms: linux/amd64,linux/arm64 | ||||
|           tags: ${{ steps.meta.outputs.tags }} | ||||
|           labels: ${{ steps.meta.outputs.labels }} | ||||
|           cache-from: type=gha,scope=build | ||||
|           cache-to: type=gha,mode=max,scope=build | ||||
| 
 | ||||
|       - name: Verify multi-platform support | ||||
|         run: | | ||||
|           images=("openim/openim-server" "ghcr.io/openimsdk/openim-server" "registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-server") | ||||
|           for image in "${images[@]}"; do | ||||
|               for tag in $(echo "${{ steps.meta.outputs.tags }}" | tr ',' '\n'); do | ||||
|                   manifest=$(docker manifest inspect "$image:$tag" || echo "error") | ||||
|                   if [[ "$manifest" == "error" ]]; then | ||||
|                       echo "Manifest not found for $image:$tag" | ||||
|                       exit 1 | ||||
|                   fi | ||||
|                   amd64_found=$(echo "$manifest" | jq '.manifests[] | select(.platform.architecture == "amd64")') | ||||
|                   arm64_found=$(echo "$manifest" | jq '.manifests[] | select(.platform.architecture == "arm64")') | ||||
|                   if [[ -z "$amd64_found" ]]; then | ||||
|                       echo "Multi-platform support check failed for $image:$tag - missing amd64" | ||||
|                       exit 1 | ||||
|                   fi | ||||
|                   if [[ -z "$arm64_found" ]]; then | ||||
|                       echo "Multi-platform support check failed for $image:$tag - missing arm64" | ||||
|                       exit 1 | ||||
|                   fi | ||||
|               done | ||||
|           done | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user