run-drc-for-cell-gds-using-magic: Working on docker image generation.

Signed-off-by: Tim 'mithro' Ansell <tansell@google.com>
diff --git a/.github/workflows/build-docker-image-run-drc-for-cell-gds-using-magic.yml b/.github/workflows/build-docker-image-run-drc-for-cell-gds-using-magic.yml
index c1d7b9c..ba6ff8f 100644
--- a/.github/workflows/build-docker-image-run-drc-for-cell-gds-using-magic.yml
+++ b/.github/workflows/build-docker-image-run-drc-for-cell-gds-using-magic.yml
@@ -19,34 +19,134 @@
 on:
   workflow_dispatch:
   push:
+  pull_request_target:
 
 jobs:
-  prebuild-magic-gds-drc:
+  # FIXME: Remove once GitHub Container Registry is working.
+  # docker.pkg.github.com doesn't support buildx built packages, use
+  # docker/build-push-action instead.
+  build-github-package:
+    name: "Building Docker GitHub Package."
+
     runs-on: ubuntu-latest
+
     steps:
     - name: Checkout code
       uses: actions/checkout@v2
-
-    - name: Set up Docker Buildx
-      uses: docker/setup-buildx-action@v1
+      with:
+        # Always clone the full depth so git-describe works.
+        fetch-depth: 0
+        submodules: true
 
     - name: Set Action Name
       run: echo "ACTION_NAME=run-drc-for-cell-gds-using-magic" >> $GITHUB_ENV
 
-    - name: Login to GitHub Container Registry
-      uses: docker/login-action@v1
+    - name: Build container image
+      uses: docker/build-push-action@v1
       with:
-        registry: ghcr.io
+        registry: docker.pkg.github.com
         username: ${{ github.repository_owner }}
         password: ${{ github.token }}
+        repository: ${{ github.repository }}/${{ env.ACTION_NAME }}
+        path: ${{ env.ACTION_NAME }}
+        tag_with_ref: true
+        tag_with_sha: true
+        add_git_labels: true
+        push: true
+
+
+  build-docker-image:
+    name: "Building image."
+
+    runs-on: ubuntu-latest
+
+    # Run a local registry
+    services:
+      registry:
+        image: registry:2
+        ports:
+          - 5000:5000
+
+    steps:
+    - name: Checkout code
+      uses: actions/checkout@v2
+      with:
+        # Always clone the full depth so git-describe works.
+        fetch-depth: 0
+        submodules: true
+
+    - name: Set Action Name
+      run: echo "ACTION_NAME=run-drc-for-cell-gds-using-magic" >> $GITHUB_ENV
+
+    - name: Detect Push To Config
+      id: push_to
+      shell: python
+      env:
+        HAS_GCR_JSON_KEY: ${{ !!(secrets.GCR_JSON_KEY) }}
+      run: |
+        import os
+        gh_event = os.environ['GITHUB_EVENT_NAME']
+
+        i = []
+        print("Adding local service.")
+        i.append("localhost:5000/${{ env.ACTION_NAME }}")
+
+        if "${{ env.HAS_GCR_JSON_KEY }}":
+            print("Adding Google Container Repository (gcr.io)")
+            i.append("gcr.io/skywater-pdk/actions/${{ env.ACTION_NAME }}")
+
+        #print("Adding GitHub Container Repository (ghcr.io)")
+        #i.append("ghcr.io/${{ github.repository }}/${{ env.ACTION_NAME }}")
+
+        l = ",".join(i)
+        print("Final locations:", repr(l))
+        print("::set-output name=images::{}".format(l))
+
+    - name: Docker meta
+      id: docker_meta
+      uses: crazy-max/ghaction-docker-meta@v1
+      with:
+        images: ${{ steps.push_to.outputs.images }}
+        tag-sha: true
+
+    - name: Set up QEMU
+      uses: docker/setup-qemu-action@v1
+
+    - name: Set up Docker Buildx
+      uses: docker/setup-buildx-action@v1
+      with:
+        driver-opts: network=host
+
+    - name: Login to Google Container Registry
+      if: ${{ contains(steps.push_to.outputs.images, 'gcr.io') }}
+      uses: docker/login-action@v1
+      with:
+        registry: gcr.io
+        username: _json_key
+        password: ${{ secrets.GCR_JSON_KEY }}
+
+    - name: Login to GitHub Container Registry
+      if: ${{ contains(steps.push_to.outputs.images, 'ghcr.io') }}
+      uses: docker/login-action@v1
+      with:
+        username: ${{ github.repository_owner }}
+        password: ${{ github.token }}
+        registry: ghcr.io
 
     - name: Build and push
       uses: docker/build-push-action@v2
+      id: docker_build
       with:
         context: ${{ env.ACTION_NAME }}
         file: ${{ env.ACTION_NAME }}/Dockerfile
         push: true
-        tags: ghcr.io/${{ github.repository }}-${{ env.ACTION_NAME }}:latest
+        tags: |
+          ${{ steps.docker_meta.outputs.tags }}
+          localhost:5000/${{ env.ACTION_NAME }}:latest
+        labels: ${{ steps.docker_meta.outputs.labels }}
+
+    - name: Inspect
+      run: docker buildx imagetools inspect localhost:5000/${{ env.ACTION_NAME }}:latest
 
     - name: Image digest
       run: echo ${{ steps.docker_build.outputs.digest }}