github.com/ethereum/go-ethereum@v1.16.1/crypto/secp256k1/libsecp256k1/.github/actions/run-in-docker-action/action.yml (about) 1 name: 'Run in Docker with environment' 2 description: 'Run a command in a Docker container, while passing explicitly set environment variables into the container.' 3 inputs: 4 dockerfile: 5 description: 'A Dockerfile that defines an image' 6 required: true 7 tag: 8 description: 'A tag of an image' 9 required: true 10 command: 11 description: 'A command to run in a container' 12 required: false 13 default: ./ci/ci.sh 14 runs: 15 using: "composite" 16 steps: 17 - uses: docker/setup-buildx-action@v3 18 19 - uses: docker/build-push-action@v5 20 id: main_builder 21 continue-on-error: true 22 with: 23 context: . 24 file: ${{ inputs.dockerfile }} 25 tags: ${{ inputs.tag }} 26 load: true 27 cache-from: type=gha 28 29 - uses: docker/build-push-action@v5 30 id: retry_builder 31 if: steps.main_builder.outcome == 'failure' 32 with: 33 context: . 34 file: ${{ inputs.dockerfile }} 35 tags: ${{ inputs.tag }} 36 load: true 37 cache-from: type=gha 38 39 - # Workaround for https://github.com/google/sanitizers/issues/1614 . 40 # The underlying issue has been fixed in clang 18.1.3. 41 run: sudo sysctl -w vm.mmap_rnd_bits=28 42 shell: bash 43 44 - # Tell Docker to pass environment variables in `env` into the container. 45 run: > 46 docker run \ 47 $(echo '${{ toJSON(env) }}' | jq -r 'keys[] | "--env \(.) "') \ 48 --volume ${{ github.workspace }}:${{ github.workspace }} \ 49 --workdir ${{ github.workspace }} \ 50 ${{ inputs.tag }} bash -c " 51 git config --global --add safe.directory ${{ github.workspace }} 52 ${{ inputs.command }} 53 " 54 shell: bash