diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index a08828a..8997d4a 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -40,10 +40,15 @@ jobs: IMAGE_ID=$(echo ghcr.io/${{ github.repository }} | tr '[A-Z]' '[a-z]') echo ::set-output name=IMAGE_ID::$IMAGE_ID + - name: Extract branch name + shell: bash + run: echo "branch=${GITHUB_HEAD_REF:-${GITHUB_REF#refs/heads/}}" >> $GITHUB_OUTPUT + id: extract_branch + - name: Get the version id: get_version run: | - VERSION=$(echo "${{ github.ref }}" | sed -e 's,.*/\(.*\),\1,') + VERSION="${{ steps.extract_branch.outputs.branch }}" [[ "${{ github.ref }}" == "refs/tags/"* ]] && VERSION=$(echo $VERSION | sed -e 's/^v//') [ "$VERSION" == "main" ] && VERSION=latest echo ::set-output name=VERSION::$VERSION @@ -78,3 +83,48 @@ jobs: --form ref=main \ --form "variables[GITHUB_TAG]=${{ steps.get_version.outputs.VERSION }}" \ "https://gitlab.com/api/v4/projects/${{ secrets.PROJECT_ID }}/trigger/pipeline" + + build-acceptance-image: + name: Build docker image for acceptance tests + runs-on: ubuntu-latest + + steps: + - name: Checkout Repository + uses: actions/checkout@v3 + + - name: Set up QEMU + uses: docker/setup-qemu-action@v2 + + - name: Set up Docker Buildx + id: buildx + uses: docker/setup-buildx-action@v2 + + - name: Login to Registry + uses: docker/login-action@v1 + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Get the image id + id: get_image_id + run: | + IMAGE_ID=$(echo ghcr.io/${{ github.repository }}-acceptance | tr '[A-Z]' '[a-z]') + echo ::set-output name=IMAGE_ID::$IMAGE_ID + + - name: Get the version + id: get_version + run: | + VERSION=$(echo "${{ github.ref }}" | sed -e 's,.*/\(.*\),\1,') + [[ "${{ github.ref }}" == "refs/tags/"* ]] && VERSION=$(echo $VERSION | sed -e 's/^v//') + [ "$VERSION" == "main" ] && VERSION=latest + echo ::set-output name=VERSION::$VERSION + + - name: Build and push container image + uses: docker/build-push-action@v3 + with: + context: . + file: ./Dockerfile.acceptance + push: true + tags: ${{ steps.get_image_id.outputs.IMAGE_ID }}:${{ steps.get_version.outputs.VERSION }} + platforms: linux/amd64,linux/arm64 diff --git a/.gitignore b/.gitignore index 2b29e9e..fd09e75 100644 --- a/.gitignore +++ b/.gitignore @@ -12,3 +12,4 @@ pyvenv.cfg /var /src/* Pipfile* +.python-version diff --git a/CHANGELOG.md b/CHANGELOG.md index 33f4971..e461f79 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,17 @@ - Upgrade Plone 6.0.4 -> 6.0.8 [mamico] +- design.plone.contenttypes 6.0.21 -> 6.1.0 [mamico] + - Optionally add image_scales and image_field in Summary serializer. [mamico] + - Add @@design-utils view that shows all available utility views. [cekk] + - Add user action that points to @@design-utils view. [cekk] + - Add @@export-incarichi view that allows to download a csv file with all - Persona and their roles. [cekk] + - Add tipologia_bando to summary serializer. [cekk] + +- redturtle.volto 5.3.0 -> 5.4.0 [cekk] + - Return error instead of raise Excpetion for BadRequest in querystringsearch [mamico] + - Add upgrade step and setuphandler to fix robots.txt original rules adding 'Allow: /?expand' [lucabel] + ## 20231030-02 - design.plone.contenttypes 6.0.20 -> 6.0.21 [cekk] diff --git a/Dockerfile.acceptance b/Dockerfile.acceptance new file mode 100644 index 0000000..0723da9 --- /dev/null +++ b/Dockerfile.acceptance @@ -0,0 +1,10 @@ +FROM plone/server-acceptance:6.0.4 +COPY docker/create-constraints.py docker/*.cfg docker/*.txt /app/ +COPY versions.cfg / +RUN pip install -r https://dist.plone.org/release/6.0.4/requirements.txt ${PIP_PARAMS} && \ + python create-constraints.py constraints.cfg constraints.txt && \ + ./bin/pip install --ignore-requires-python -r requirements-acceptance.txt -c constraints.txt ${PIP_PARAMS} && \ + find /app/lib -name LC_MESSAGES -exec chown -R plone:plone {} \; + +# Run DESIGN_PLONE_POLICY_ACCEPTANCE_TESTING by default +CMD ["design.plone.policy.testing.DESIGN_PLONE_POLICY_ACCEPTANCE_TESTING"] diff --git a/docker/requirements-acceptance.txt b/docker/requirements-acceptance.txt new file mode 100644 index 0000000..48543ef --- /dev/null +++ b/docker/requirements-acceptance.txt @@ -0,0 +1,3 @@ +Plone +design.plone.policy[test] +collective.MockMailHost diff --git a/versions.cfg b/versions.cfg index db85be0..7896981 100644 --- a/versions.cfg +++ b/versions.cfg @@ -40,7 +40,7 @@ collective.volto.socialsettings = 0.2.1 collective.volto.subfooter = 1.1.0 collective.volto.subsites = 1.4.0 collective.z3cform.datagridfield = 3.0.1 -design.plone.contenttypes = 6.0.21 +design.plone.contenttypes = 6.1.0 design.plone.policy = 5.0.6 eea.api.taxonomy = 1.5 et-xmlfile = 1.1.0 @@ -58,7 +58,7 @@ redturtle.bandi = 1.4.3 redturtle.faq = 1.0.1 redturtle.filesretriever = 1.0.0 redturtle.rssservice = 2.2.0 -redturtle.volto = 5.3.0 +redturtle.volto = 5.4.0 redturtle.voltoplugin.editablefooter = 1.1.2 rer.customersatisfaction = 2.0.0 sentry-sdk = 1.12.1