Run integration tests with custom containers

0

As a PoC I want to build a pipeline for GitOps of policy management. When a policy is committed to a repo, I want to run an existing Docker container (available on Docker Hub) that acts as a policy engine with a REST API exposed for uploading the policies and then run queries against. What is the easiest way to accomplish this?

  1. Commit policies to Git (preferably CodeCommit)
  2. Spin up a prebuilt Docker container
  3. Run a shell script with curl commands to upload and test the validity of the policies on the Docker container
  4. Fail the pipeline if curl does not return 200.
profile pictureAWS
已提問 9 個月前檢視次數 273 次
2 個答案
0

Would something like this be the right approach to run the container inside the build?

version: 0.2

phases:
  install:
    runtime-versions:
      docker: 24

  pre_build:
    commands:
      - docker pull my-docker-image:tag
      - docker run -d --name policy-container my-docker-image:tag

  build:
    commands:
      - sh integration_tests.sh 

  post_build:
    commands:
      - docker stop policy-container
      - docker rm policy-container
profile pictureAWS
已回答 9 個月前
  • The latest version is docker: 20 in a buildspec. To avoid limits you need to log in:

    version: 0.2

    env: secrets-manager: DOCKERHUB_PASS: "/dockerhub/credentials:password" DOCKERHUB_USERNAME: "/dockerhub/credentials:username" phases: install: commands: - echo pre_build step... - docker login --username $DOCKERHUB_USERNAME --password $DOCKERHUB_PASS - $(aws ecr get-login --no-include-email --region us-east-1)

    In general, your buildspec is fine.

0

You can use AWS CI/CD stack: CodeCommit, CodeBuild, CodePipeline.

https://aws.amazon.com/codecommit/

https://aws.amazon.com/codebuild/

https://aws.amazon.com/codepipeline/

In a buildspec you can define all the needed commands:

https://docs.aws.amazon.com/codebuild/latest/userguide/build-spec-ref.html

profile picture
已回答 9 個月前

您尚未登入。 登入 去張貼答案。

一個好的回答可以清楚地回答問題並提供建設性的意見回饋,同時有助於提問者的專業成長。

回答問題指南