on: push: workflow_dispatch: inputs: verbose: description: "Verbose" required: false default: false type: boolean jobs: build: runs-on: container steps: - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Install the latest version of uv uses: astral-sh/setup-uv@v4 with: version: "0.5.16" - name: Install run: uv sync - name: Run tests (API call) run: .venv/bin/pytest -s tests/basic.py - name: Get version uses: mtkennerly/dunamai-action@v1 with: env-var: VERSION args: --style semver - name: Version run: echo $VERSION - name: Get version with git describe id: version run: | echo "version=$(git describe)" >> $GITHUB_OUTPUT echo "$VERSION" - name: Check if the container should be built id: builder env: RUN: ${{ toJSON(inputs.build || !contains(steps.version.outputs.version, '-')) }} run: | echo "run=$RUN" >> $GITHUB_OUTPUT echo "Run build: $RUN" - name: Set the version in pyproject.toml (workaround for uv not supporting dynamic version) if: fromJSON(steps.builder.outputs.run) env: VERSION: ${{ steps.version.outputs.version }} run: sed "s/0.0.0/$VERSION/" -i pyproject.toml - name: Workaround for bug of podman-login if: fromJSON(steps.builder.outputs.run) run: | mkdir -p $HOME/.docker echo "{ \"auths\": {} }" > $HOME/.docker/config.json - name: Log in to the container registry (with another workaround) if: fromJSON(steps.builder.outputs.run) uses: actions/podman-login@v1 with: registry: ${{ vars.REGISTRY }} username: ${{ secrets.REGISTRY_USER }} password: ${{ secrets.REGISTRY_PASSWORD }} auth_file_path: /tmp/auth.json - name: Build the container image if: fromJSON(steps.builder.outputs.run) uses: actions/buildah-build@v1 with: image: oidc-fastapi-test oci: true labels: oidc-fastapi-test tags: latest ${{ steps.version.outputs.version }} containerfiles: | ./Containerfile - name: Push the image to the registry if: fromJSON(steps.builder.outputs.run) uses: actions/push-to-registry@v2 with: registry: "docker://${{ vars.REGISTRY }}/${{ vars.ORGANISATION }}" image: oidc-fastapi-test tags: latest ${{ steps.version.outputs.version }} - name: Build wheel if: fromJSON(steps.builder.outputs.run) run: uv build --wheel - name: Publish Python package (home) if: fromJSON(steps.builder.outputs.run) env: LOCAL_PYPI_TOKEN: ${{ secrets.LOCAL_PYPI_TOKEN }} run: uv publish --publish-url https://code.philo.ydns.eu/api/packages/philorg/pypi --token $LOCAL_PYPI_TOKEN continue-on-error: true