Deploying hardhat #25
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 and see if the folder is mounted properly | |
- name: Installing Node.js and npm | |
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 | |
- name: Deploy hardhat sample project | |
run: | | |
docker exec devnet sh -c "cd /workspace/hardhat && npx hardhat ignition deploy ./ignition/modules/Lock.js" | |
- name: Testing contracts | |
run: | | |
docker exec devnet sh -c "cd /workspace/hardhat && 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 |