name: CI on: workflow_dispatch: push: paths-ignore: - .gitignore - "*.md" pull_request: paths-ignore: - .gitignore - "*.md" jobs: pytest: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - name: "Install dependencies" run: pip install -r requirements.txt && pip install -r test/requirements.txt - name: "Run tests" run: pytest -vvv test: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - name: "Install dependencies" run: | pip install -r requirements.txt sudo apt update && sudo apt install -y docker-compose - name: "Checkout JellyPlex-Watched-CI" uses: actions/checkout@v4 with: repository: luigi311/JellyPlex-Watched-CI path: JellyPlex-Watched-CI - name: "Start containers" run: | JellyPlex-Watched-CI/start_containers.sh # Wait for containers to start sleep 10 for FOLDER in $(find "JellyPlex-Watched-CI" -type f -name "docker-compose.yml" -exec dirname {} \;); do docker-compose -f "${FOLDER}/docker-compose.yml" logs done - name: "Test Plex" run: | mv test/ci_plex.env .env python main.py python test/validate_ci_marklog.py --plex rm mark.log - name: "Test Jellyfin" run: | mv test/ci_jellyfin.env .env python main.py python test/validate_ci_marklog.py --jellyfin rm mark.log - name: "Test Emby" run: | mv test/ci_emby.env .env python main.py python test/validate_ci_marklog.py --emby rm mark.log - name: "Test Guids" run: | mv test/ci_guids.env .env python main.py python test/validate_ci_marklog.py --dry rm mark.log - name: "Test Locations" run: | mv test/ci_locations.env .env python main.py python test/validate_ci_marklog.py --dry rm mark.log - name: "Test writing to the servers" run: | # Test writing to the servers mv test/ci_write.env .env python main.py # Test again to test if it can handle existing data python main.py python test/validate_ci_marklog.py --write rm mark.log docker: runs-on: ubuntu-latest needs: - pytest - test env: DEFAULT_VARIANT: alpine strategy: fail-fast: false matrix: include: - dockerfile: Dockerfile.alpine variant: alpine - dockerfile: Dockerfile.slim variant: slim steps: - name: Checkout uses: actions/checkout@v4 - name: Docker meta id: docker_meta uses: docker/metadata-action@v5 with: images: | ${{ secrets.DOCKER_USERNAME }}/jellyplex-watched,enable=${{ secrets.DOCKER_USERNAME != '' }} # Do not push to ghcr.io on PRs due to permission issues, only push if the owner is luigi311 so it doesnt fail on forks ghcr.io/${{ github.repository }},enable=${{ github.event_name != 'pull_request' && github.repository_owner == 'luigi311'}} tags: | type=raw,value=latest,enable=${{ matrix.variant == env.DEFAULT_VARIANT && github.ref_name == github.event.repository.default_branch }} type=raw,value=dev,enable=${{ matrix.variant == env.DEFAULT_VARIANT && github.ref_name == 'dev' }} type=raw,value=latest,suffix=-${{ matrix.variant }},enable={{ is_default_branch }} type=ref,event=branch,suffix=-${{ matrix.variant }} type=ref,event=branch,enable=${{ matrix.variant == env.DEFAULT_VARIANT }} type=ref,event=pr,suffix=-${{ matrix.variant }} type=ref,event=pr,enable=${{ matrix.variant == env.DEFAULT_VARIANT }} type=semver,pattern={{ version }},suffix=-${{ matrix.variant }} type=semver,pattern={{ version }},enable=${{ matrix.variant == env.DEFAULT_VARIANT }} type=semver,pattern={{ major }}.{{ minor }},suffix=-${{ matrix.variant }} type=semver,pattern={{ major }}.{{ minor }},enable=${{ matrix.variant == env.DEFAULT_VARIANT }} type=sha,suffix=-${{ matrix.variant }} type=sha,enable=${{ matrix.variant == env.DEFAULT_VARIANT }} - name: Set up QEMU uses: docker/setup-qemu-action@v3 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Login to DockerHub env: DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} if: "${{ env.DOCKER_USERNAME != '' }}" uses: docker/login-action@v3 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_TOKEN }} - name: Login to GitHub Container Registry if: "${{ steps.docker_meta.outcome == 'success' }}" uses: docker/login-action@v3 with: registry: ghcr.io username: ${{ github.actor }} password: ${{ secrets.GITHUB_TOKEN }} - name: Build id: build if: "${{ steps.docker_meta.outputs.tags == '' }}" uses: docker/build-push-action@v5 with: context: . file: ${{ matrix.dockerfile }} platforms: linux/amd64,linux/arm64 push: false tags: jellyplex-watched:action - name: Build Push id: build_push if: "${{ steps.docker_meta.outputs.tags != '' }}" uses: docker/build-push-action@v5 with: context: . file: ${{ matrix.dockerfile }} platforms: linux/amd64,linux/arm64 push: true tags: ${{ steps.docker_meta.outputs.tags }} labels: ${{ steps.docker_meta.outputs.labels }} # Echo digest so users can validate their image - name: Image digest if: "${{ steps.docker_meta.outcome == 'success' }}" run: echo "${{ steps.build_push.outputs.digest }}"