Skip to content

Publish (Java 17 only) #9

Publish (Java 17 only)

Publish (Java 17 only) #9

#
# 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 (Java 17 only)"
on:
workflow_dispatch:
inputs:
spark:
description: 'The Spark version of Spark image.'
required: true
default: '4.1.0-preview1'
type: choice
options:
- 4.1.0-preview1
- 4.0.1
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:
strategy:
matrix:
scala: [2.13]
java: [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
strategy:
matrix:
scala: [2.13]
java: [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 }}