Implement backend data field filter for H2 & Postgresql (similar to MongoDB) #4495
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Copyright (c) 2020, 2022 Contributors to the Eclipse Foundation | |
# | |
# See the NOTICE file(s) distributed with this work for additional | |
# information regarding copyright ownership. | |
# | |
# This program and the accompanying materials are made available under the | |
# terms of the Eclipse Public License 2.0 which is available at | |
# http://www.eclipse.org/legal/epl-2.0 | |
# | |
# SPDX-License-Identifier: EPL-2.0 | |
# | |
# This workflow will build all of Hono's components, run unit tests and create | |
# Docker images. Finally, the integration tests are run. | |
# The job uses a matrix for the distinct device registry implementations. Thus, | |
# for each registry implementation, the workflow is run on a separate VM. | |
name: Build and run integration tests | |
on: [push,pull_request] | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
device-registry-name: [file,jdbc,mongodb-4.4,mongodb-5.0,mongodb-6.0] | |
include: | |
# Use Quarkus JVM images: file registry, AMQP messaging, Command Router with embedded cache | |
- device-registry-name: file | |
device-registry: file | |
commandrouting-cache: embedded | |
messaging-type: amqp | |
mongodb-image-name: mongo:4.4 | |
# Use Quarkus JVM images: jdbc registry, Kafka messaging, Command Router with embedded cache | |
- device-registry-name: jdbc | |
device-registry: jdbc | |
commandrouting-cache: embedded | |
messaging-type: kafka | |
mongodb-image-name: mongo:4.4 | |
# Use Quarkus JVM images: mongodb registry Kafka messaging, Command Router with data grid | |
- device-registry-name: mongodb-4.4 | |
device-registry: mongodb | |
commandrouting-cache: server | |
messaging-type: kafka | |
mongodb-image-name: mongo:4.4 | |
- device-registry-name: mongodb-5.0 | |
device-registry: mongodb | |
commandrouting-cache: server | |
messaging-type: kafka | |
mongodb-image-name: mongo:5.0 | |
- device-registry-name: mongodb-6.0 | |
device-registry: mongodb | |
commandrouting-cache: server | |
messaging-type: kafka | |
mongodb-image-name: mongo:6.0 | |
name: "Use ${{ matrix.device-registry-name }} registry, ${{ matrix.messaging-type }} messaging with ${{ matrix.commandrouting-cache }} cache" | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Set up Maven | |
uses: stCarolas/[email protected] | |
with: | |
maven-version: 3.8.6 | |
- name: Set up JDK | |
uses: actions/setup-java@v3 | |
with: | |
distribution: "temurin" | |
java-version: "17" | |
cache: "maven" | |
- name: Build all components (incl. unit tests) and run integration tests | |
run: | | |
mvn clean verify -B -e -DcreateJavadoc=true -DCI=$CI \ | |
-Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn \ | |
-Dhono.deviceregistry.type=${{ matrix.device-registry }} \ | |
-Dhono.messaging-infra.type=${{ matrix.messaging-type }} \ | |
-Dhono.commandrouting.cache=${{ matrix.commandrouting-cache }} \ | |
-Dmongodb-image.name=${{ matrix.mongodb-image-name }} \ | |
-Pbuild-docker-image,jaeger,run-tests |