Skip to content

Publish

Publish #20

Workflow file for this run

#
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
#
name: "Publish"
on:
workflow_dispatch:
inputs:
spark:
description: 'The Spark version of Spark image.'
required: true
default: '3.5.0'
type: choice
options:
- 3.5.0
- 3.4.2
- 3.4.1
- 3.4.0
- 3.3.3
- 3.3.2
- 3.3.1
- 3.3.0
publish:
description: 'Publish the image or not.'
default: false
type: boolean
required: true
repository:
description: The registry to be published (Available only when publish is true).
required: false
default: ghcr.io/apache/spark-docker
type: choice
options:
# GHCR: This required the write permission of apache/spark-docker (Spark Committer)
- ghcr.io/apache/spark-docker
# Dockerhub: This required the DOCKERHUB_TOKEN and DOCKERHUB_USER (Spark Committer)
- apache
jobs:
# We first build and publish the base image
run-base-build:
# if: startsWith(inputs.spark, '3.3')
strategy:
matrix:
scala: [2.12]
java: [11, 17]
image-type: ["scala"]
permissions:
packages: write
name: Run Base
secrets: inherit
uses: ./.github/workflows/main.yml
with:
spark: ${{ inputs.spark }}
scala: ${{ matrix.scala }}
java: ${{ matrix.java }}
publish: ${{ inputs.publish }}
repository: ${{ inputs.repository }}
image-type: ${{ matrix.image-type }}
# Then publish the all / python / r images
run-build:
needs: run-base-build
# if: startsWith(inputs.spark, '3.3')
strategy:
matrix:
scala: [2.12]
java: [11, 17]
image-type: ["all", "python", "r"]
permissions:
packages: write
name: Run
secrets: inherit
uses: ./.github/workflows/main.yml
with:
spark: ${{ inputs.spark }}
scala: ${{ matrix.scala }}
java: ${{ matrix.java }}
publish: ${{ inputs.publish }}
repository: ${{ inputs.repository }}
image-type: ${{ matrix.image-type }}