busybox/workflow.yaml (47 lines of code) (raw):
# Copyright 2022 Google LLC
#
# Licensed 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.
main:
params: [args]
steps:
- init:
assign:
- projectId: ${sys.get_env("GOOGLE_CLOUD_PROJECT_ID")}
- region: "us-central1"
- jobId: ${"job-busybox-" + string(int(sys.now()))}
- logCreateBatchJob:
call: sys.log
args:
data: ${"Creating and running the batch job " + jobId}
- createAndRunBatchJob:
call: googleapis.batch.v1.projects.locations.jobs.create
args:
parent: ${"projects/" + projectId + "/locations/" + region}
jobId: ${jobId}
body:
taskGroups:
- taskSpec:
runnables:
- container:
imageUri: busybox
entrypoint: "/bin/sh"
commands:
- "-c"
- "echo task index: ${BATCH_TASK_INDEX} bucket: ${BUCKET}"
environment:
variables:
BUCKET: batch-test-bucket
taskCount: 3
logsPolicy:
destination: CLOUD_LOGGING
result: createAndRunBatchJobResponse
- logDeleteBatchJob:
call: sys.log
args:
data: ${"Deleting the batch job " + jobId}
- deleteBatchJob:
call: googleapis.batch.v1.projects.locations.jobs.delete
args:
name: ${"projects/" + projectId + "/locations/" + region + "/jobs/" + jobId}
result: deleteResult
- returnResult:
return:
jobId: ${jobId}
status: "OK"