Deploying hardhat #20
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Deploying hardhat | |
on: | |
pull_request: | |
branches: ["master"] | |
workflow_dispatch: | |
env: | |
REGISTRY: ghcr.io | |
IMAGE_NAME: san-est/go-ethereum-devops | |
jobs: | |
deploy-hardhat: | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
packages: write | |
id-token: write | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Login to registry | |
uses: docker/login-action@v2 | |
with: | |
registry: ${{ env.REGISTRY }} | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Pull image | |
run: docker pull ghcr.io/san-est/go-ethereum-devops:9 | |
- name: Running image container | |
run: | | |
echo "Workspace path: ${{ github.workspace }}/hardhat" | |
docker run -d --name devnet -p 8545:8545 \ | |
-v ${{ github.workspace }}/hardhat:/workspace/hardhat \ | |
${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:9 | |
docker exec devnet ls /workspace/hardhat | |
docker exec devnet ls -l /workspace/hardhat | |
docker exec devnet ls -l /workspace | |
#steps were added so i can troublshoot if the folder is mounted properly | |
- name: Installing Node.js, npm and local hardhat so that hardhat sample can run | |
run: | | |
docker exec devnet apk add --no-cache nodejs npm | |
- name: Install local version of hardhat | |
run: docker exec devnet sh -c "cd /workspace/hardhat && npm install hardhat" | |
- name: Verify if Hardhat is installed | |
run: | | |
docker exec devnet npx hardhat --version | |
docker exec devnet npx hardhat --version | |
- name: Deploy hardhat sample project | |
run: | | |
docker exec devnet sh -c "npx hardhat test" | |
- name: Build a new docker image | |
run: | | |
docker commit devnet go-eth-hardhat:latest | |
docker tag go-eth-hardhat:latest ${{ env.REGISTRY }}/${{ github.repository_owner }}/go-eth-hardhat:latest | |
- name: Push new image to ghcr.io | |
run: docker push ${{ env.REGISTRY }}/${{ github.repository_owner }}/go-eth-hardhat:latest |