From a02d00752c68701722f3fe104eede965cd5ddca2 Mon Sep 17 00:00:00 2001 From: Lucas Pirola Date: Thu, 4 Jul 2024 16:32:57 -0300 Subject: [PATCH] Adiciona pipeline para teste e publicacao da imagem docker --- .github/workflows/ci.yml | 137 ++++++++++++++----- .github/workflows/cicd-dev.yml | 60 -------- .github/workflows/workflows/ci.yml | 73 ---------- .github/workflows/workflows/release.yml | 51 ------- api/config/packages/doctrine.yaml | 2 + api/mapas/docker/{Dockerfile => xDockerfile} | 0 api/mapas/{Dockerfile => xDockerfile} | 0 compose.yaml | 40 ++++-- 8 files changed, 130 insertions(+), 233 deletions(-) delete mode 100644 .github/workflows/cicd-dev.yml delete mode 100644 .github/workflows/workflows/ci.yml delete mode 100644 .github/workflows/workflows/release.yml rename api/mapas/docker/{Dockerfile => xDockerfile} (100%) rename api/mapas/{Dockerfile => xDockerfile} (100%) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index f742269039..8797a63664 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -1,46 +1,115 @@ -name: ci +name: CI on: - pull_request: + push: branches: - - homolog - - workflow_dispatch: + - develop + pull_request: ~ + workflow_dispatch: ~ +concurrency: + group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} + cancel-in-progress: true +env: + REGISTRY: ghcr.io + IMAGE_NAME: ${{ github.repository }} jobs: - BUILD: + tests: + name: Tests runs-on: ubuntu-latest + permissions: + contents: read + packages: write + attestations: write + id-token: write steps: - - - uses: actions/checkout@v4.1.1 - - - name: Docker Login - uses: docker/login-action@v3.0.0 + - + name: Checkout + uses: actions/checkout@v4 + - + name: Environment Variables + run: cp api/.env.sample api/.env && cp api/.env.sample .env + - + name: Submodules + run: git submodule init && git submodule update --remote + - + name: Build Frontend + run: cd api/mapas/src && npm i -g pnpm && pnpm i && pnpm run dev + - name: Log in to the Container registry + uses: docker/login-action@v4 with: - username: ${{ secrets.DOCKERHUB_USER }} - password: ${{ secrets.DOCKERHUB_PASSWORD }} - - - name: Checkout submodules - run: git submodule update --init --recursive - - - name: Ajusta branch do MultipleLocalAuth - run: cd src/plugins/MultipleLocalAuth && git checkout v3.0.0 - - - name: Criação da Imagem docker - uses: docker/build-push-action@v5.0.0 + registry: ${{ env.REGISTRY }} + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + - + name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Extract metadata (tags, labels) for Docker + id: meta + uses: docker/metadata-action@v4 + with: + images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} + - + name: Build Docker images + uses: docker/bake-action@v4 with: - context: ./ - file: ./Dockerfile + load: true push: true - tags: | - secultceara/mapascultural:7.3.7 - secultceara/mapascultural:latest + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} + files: | + compose.yaml + compose.override.yaml + set: | + *.cache-from=type=gha,scope=${{github.ref}} + *.cache-from=type=gha,scope=refs/heads/main + *.cache-to=type=gha,scope=${{github.ref}},mode=max - DEPLOY: - needs: BUILD - runs-on: mapahomolog + - name: Generate artifact attestation + uses: actions/attest-build-provenance@v1 + with: + subject-name: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME}} + subject-digest: ${{ steps.push.outputs.digest }} + push-to-registry: true + - + name: Create private-files folder + run: docker compose run --rm web mkdir var/private-files + - + name: Start services + run: docker compose up database redis mailhog web --wait --no-build + - + name: Check HTTP reachability + run: curl -v --fail-with-body http://localhost:5020 + # - + # name: Check API reachability + # run: curl -vk --fail-with-body https://localhost + # - + # name: Check PWA reachability + # run: "curl -vk --fail-with-body -H 'Accept: text/html' https://localhost" + - + name: Create test database + run: docker compose exec -T web bin/console -e test doctrine:database:create + - + name: Run db-updates + run: docker compose exec -T web php mapas/src/tools/apply-updates.php + - + name: Run migrations + run: docker compose exec -T web bin/console -e test doctrine:migrations:migrate --no-interaction + # - + # name: Run PHPUnit + # run: docker compose exec -T web bin/phpunit + - + name: Doctrine Schema Validator + run: docker compose exec -T web bin/console -e test doctrine:schema:validate + lint: + name: Docker Lint + runs-on: ubuntu-latest steps: - - name: Pull das imagens docker - run: cd /opt/docker/mapa7 && sudo docker-compose pull - - name: Restart do docker-compose para atualizar o container com a nova imagem - run: cd /opt/docker/mapa7 && sudo docker-compose down && sudo docker-compose up -d \ No newline at end of file + - + name: Checkout + uses: actions/checkout@v4 + - + name: Lint Dockerfiles + uses: hadolint/hadolint-action@v3.1.0 + with: + recursive: true diff --git a/.github/workflows/cicd-dev.yml b/.github/workflows/cicd-dev.yml deleted file mode 100644 index 4e1cad187b..0000000000 --- a/.github/workflows/cicd-dev.yml +++ /dev/null @@ -1,60 +0,0 @@ -name: ci/cd-dev - -on: - pull_request: - branches: - - develop - types: - - closed - - ready_for_review - - review_requested - - workflow_dispatch: - -jobs: - CODE_STYLE: - name: PHP-CS-Fixer - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - name: Run PHP-CS-Fixer - uses: erkenes/php-cs-fixer-action@main - with: - args: '--dry-run --diff -vvv' - - BUILD: - if: github.event.pull_request.merged == true - runs-on: ubuntu-latest - steps: - - - uses: actions/checkout@v4.1.1 - - - name: Docker Login - uses: docker/login-action@v3.0.0 - with: - username: ${{ secrets.DOCKERHUB_USER }} - password: ${{ secrets.DOCKERHUB_PASSWORD }} - - - name: Checkout submodules - run: git submodule update --init --recursive - - - name: Ajusta branch do MultipleLocalAuth - run: cd src/plugins/MultipleLocalAuth && git checkout v3.0.0 - - - name: Criação da Imagem docker - uses: docker/build-push-action@v5.0.0 - with: - context: ./ - file: ./Dockerfile - push: true - tags: | - secultceara/mapascultural:7.3.7-dev - - DEPLOY: - needs: BUILD - runs-on: mapahomolog - steps: - - name: Pull das imagens docker - run: cd /opt/docker/developv7 && sudo docker-compose pull - - name: Restart do docker-compose para atualizar o container com a nova imagem - run: cd /opt/docker/developv7 && sudo docker-compose down && sudo docker-compose up -d diff --git a/.github/workflows/workflows/ci.yml b/.github/workflows/workflows/ci.yml deleted file mode 100644 index 3e21569045..0000000000 --- a/.github/workflows/workflows/ci.yml +++ /dev/null @@ -1,73 +0,0 @@ -name: CI - -on: - push: - branches: - - main - pull_request: ~ - workflow_dispatch: ~ - -concurrency: - group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} - cancel-in-progress: true - -jobs: - tests: - name: Tests - runs-on: ubuntu-latest - steps: - - - name: Checkout - uses: actions/checkout@v4 - - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 - - - name: Build Docker images - uses: docker/bake-action@v4 - with: - pull: true - load: true - files: | - compose.yaml - compose.override.yaml - set: | - *.cache-from=type=gha,scope=${{github.ref}} - *.cache-from=type=gha,scope=refs/heads/main - *.cache-to=type=gha,scope=${{github.ref}},mode=max - - - name: Start services - run: docker compose up --wait --no-build - - - name: Check HTTP reachability - run: curl -v --fail-with-body http://localhost - - - name: Check API reachability - run: curl -vk --fail-with-body https://localhost - - - name: Check PWA reachability - run: "curl -vk --fail-with-body -H 'Accept: text/html' https://localhost" - - - name: Create test database - run: docker compose exec -T php bin/console -e test doctrine:database:create - - - name: Run migrations - run: docker compose exec -T php bin/console -e test doctrine:migrations:migrate --no-interaction - - - name: Run PHPUnit - run: docker compose exec -T php bin/phpunit - - - name: Doctrine Schema Validator - run: docker compose exec -T php bin/console -e test doctrine:schema:validate - lint: - name: Docker Lint - runs-on: ubuntu-latest - steps: - - - name: Checkout - uses: actions/checkout@v4 - - - name: Lint Dockerfiles - uses: hadolint/hadolint-action@v3.1.0 - with: - recursive: true diff --git a/.github/workflows/workflows/release.yml b/.github/workflows/workflows/release.yml deleted file mode 100644 index 35ed5a0284..0000000000 --- a/.github/workflows/workflows/release.yml +++ /dev/null @@ -1,51 +0,0 @@ -name: Release -permissions: - contents: write - pull-requests: write - -on: - workflow_dispatch: - inputs: - tag: - description: 'API Platform core tag' - required: true - -concurrency: - group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} - cancel-in-progress: true - -jobs: - tests: - name: Update api-platform/core - runs-on: ubuntu-latest - steps: - - - name: Checkout - uses: actions/checkout@v4 - - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 - - - name: Build Docker images - uses: docker/bake-action@v4 - with: - pull: true - load: true - files: | - compose.yaml - compose.override.yaml - set: | - *.cache-from=type=gha,scope=${{github.ref}} - *.cache-from=type=gha,scope=refs/heads/main - *.cache-to=type=gha,scope=${{github.ref}},mode=max - - - name: Update API Platform - run: docker compose run php composer update api-platform/core:${{ inputs.tag }} - - - name: Create Pull Request - uses: peter-evans/create-pull-request@v6 - with: - commit-message: 'chore: api-platform ${{ inputs.tag }}' - branch: api-platform-core - title: 'chore: api-platform ${{ inputs.tag }}' - body: 'Updates api-platform/core to ${{ inputs.tag }}' diff --git a/api/config/packages/doctrine.yaml b/api/config/packages/doctrine.yaml index 75ec9e8410..f31898a6fc 100644 --- a/api/config/packages/doctrine.yaml +++ b/api/config/packages/doctrine.yaml @@ -8,6 +8,8 @@ doctrine: profiling_collect_backtrace: '%kernel.debug%' use_savepoints: true + mapping_types: + enum: string orm: auto_generate_proxy_classes: true enable_lazy_ghost_objects: true diff --git a/api/mapas/docker/Dockerfile b/api/mapas/docker/xDockerfile similarity index 100% rename from api/mapas/docker/Dockerfile rename to api/mapas/docker/xDockerfile diff --git a/api/mapas/Dockerfile b/api/mapas/xDockerfile similarity index 100% rename from api/mapas/Dockerfile rename to api/mapas/xDockerfile diff --git a/compose.yaml b/compose.yaml index 51aa5b506a..36241dd335 100644 --- a/compose.yaml +++ b/compose.yaml @@ -1,6 +1,5 @@ services: php: - image: redemapas/mapas-api depends_on: - database restart: unless-stopped @@ -33,8 +32,8 @@ services: - ./api:/app # - /app/var - var-files:/app/var - # - ./api/frankenphp/Caddyfile:/etc/caddy/Caddyfile:ro - # - ./api/frankenphp/conf.d/app.dev.ini:/usr/local/etc/php/conf.d/app.dev.ini:ro + - ./api/frankenphp/Caddyfile:/etc/caddy/Caddyfile:ro + - ./api/frankenphp/conf.d/app.dev.ini:/usr/local/etc/php/conf.d/app.dev.ini:ro - caddy_data:/data - caddy_config:/config @@ -47,6 +46,17 @@ services: published: 5020 protocol: tcp + # pgadmin: + # image: dpage/pgadmin4 + # environment: + # PGADMIN_DEFAULT_EMAIL: ${PGADMIN_DEFAULT_EMAIL:-pgadmin4@pgadmin.org} + # PGADMIN_DEFAULT_PASSWORD: ${PGADMIN_DEFAULT_PASSWORD:-admin} + # PGADMIN_CONFIG_SERVER_MODE: 'False' + # volumes: + # - pgadmin:/var/lib/pgadmin + # ports: + # - 5050:80 + recreate-pending-pcache: extends: service: php @@ -96,19 +106,18 @@ services: # ports: # - "8025:8025" - # pwa: - # image: redemapas/mapas-pwa - # build: - # context: ./pwa - # target: dev - # volumes: - # - ./pwa:/srv/app - # environment: - # API_PLATFORM_CREATE_CLIENT_ENTRYPOINT: http://php - # API_PLATFORM_CREATE_CLIENT_OUTPUT: . - # NEXT_PUBLIC_ENTRYPOINT: http://php + pwa: + image: redemapas/mapas-pwa + build: + context: ./pwa + target: dev + volumes: + - ./pwa:/srv/app + environment: + API_PLATFORM_CREATE_CLIENT_ENTRYPOINT: http://php + API_PLATFORM_CREATE_CLIENT_OUTPUT: . + NEXT_PUBLIC_ENTRYPOINT: http://php - ###> doctrine/doctrine-bundle ### database: image: kartoza/postgis:14 environment: @@ -131,3 +140,4 @@ volumes: db_data: sessions: redis: + pgadmin: