Skip to content

Fix https://github.com/Pil0tXia/eventmesh-dashboard/actions/runs/8750… #82

Fix https://github.com/Pil0tXia/eventmesh-dashboard/actions/runs/8750…

Fix https://github.com/Pil0tXia/eventmesh-dashboard/actions/runs/8750… #82

Workflow file for this run

#
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
#
name: "Continuous Integration"
on:
push:
branches: [ '**' ]
pull_request:
branches: [ '**' ]
jobs:
build:
name: Build
strategy:
fail-fast: false
matrix:
os: [ ubuntu-latest ]
java: [ 8, 11 ]
language: ['java']
runs-on: ${{ matrix.os }}
services:
mysql:
image: mysql:8.0
env:
# The MySQL docker container requires these environment variables to be set, so we can create and migrate the test database.
MYSQL_DATABASE: eventmesh_dashboard_test
MYSQL_ROOT_PASSWORD: password
ports:
# https://docs.github.com/en/actions/using-containerized-services/about-service-containers
- 3306:3306
# Set health checks to wait until MySQL has started
options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=3
meta:
image: nacos/nacos-server:v2.3.2
env:
MODE: standalone
ports:
- 8848:8848
options: --health-cmd="curl -X GET "http://localhost:8848/nacos/v1/cs/configs?dataId=*&group=&search=blur&pageNo=1&pageSize=10"" --health-interval=10s --health-timeout=5s --health-retries=3
# store-namesrv:
# image: apache/rocketmq:4.9.7
# ports:
# - 9876:9876
# options: >
# sh mqnamesrv
# --health-cmd="./mqadmin clusterList -n localhost:9876" --health-interval=10s --health-timeout=5s --health-retries=3
# store-broker:
# image: apache/rocketmq:4.9.7
# ports:
# - 10909:10909
# - 10911:10911
# options: >
# sh mqbroker -n localhost:9876
# --health-cmd="./mqadmin clusterRT -n localhost:9876" --health-interval=10s --health-timeout=5s --health-retries=3
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up JDK ${{ matrix.java }}
uses: actions/setup-java@v4
with:
distribution: 'corretto'
java-version: ${{ matrix.java }}
cache: maven
- name: Download RocketMQ Binary
run: |
wget https://dist.apache.org/repos/dist/release/rocketmq/4.9.8/rocketmq-all-4.9.8-source-release.zip
unzip rocketmq-all-4.9.8-source-release.zip
- name: Set up RocketMQ Namesrv
working-directory: rocketmq-all-4.9.8
run: |
nohup sh bin/mqnamesrv &
sleep 5
- name: Set up RocketMQ Broker
working-directory: rocketmq-all-4.9.8
run: nohup sh bin/mqbroker -n localhost:9876 &
- name: Build with Maven
run: ./mvnw -B package -DskipTests --file pom.xml
- name: Run Unit Tests
run: ./mvnw -B test --file pom.xml