Merge pull request #2043 from NotTheEconomist/patch-1

Fix broken API references in universe/python
This commit is contained in:
Helder Correia 2022-04-07 21:17:26 +00:00 committed by GitHub
commit 768c3c51dc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 94 additions and 7 deletions

View File

@ -2,28 +2,60 @@
package python package python
import ( import (
"universe.dagger.io/docker" "dagger.io/dagger"
"dagger.io/dagger/core"
"universe.dagger.io/docker"
"universe.dagger.io/alpine" "universe.dagger.io/alpine"
) )
// Run a python script in a container // Run a python script in a container
#Run: { #Run: {
// Contents of the python script // Contents of the python script
script: string script: {
// A directory containing one or more bash scripts
directory: dagger.#FS
// Name of the file to execute
filename: string
_directory: directory
_filename: filename
} | {
// Script contents
contents: string
_filename: "run.py"
_write: core.#WriteFile & {
input: dagger.#Scratch
path: _filename
"contents": contents
}
_directory: _write.output
}
// arguments to the script
args: [...string]
// where to mount the script inside the container
_mountpoint: "/run/python"
// FIXME: don't pass the script as argument: write to filesystme instead
docker.#Run & { docker.#Run & {
command: { command: {
name: "python" name: "python3"
flags: "-c": script "args": ["\(_mountpoint)/\(script._filename)"] + args
} }
// As a convenience, image defaults to a ready-to-use python environment // As a convenience, image defaults to a ready-to-use python environment
image: docker.#Image | *_defaultImage input: docker.#Image | *_defaultImage.output
_defaultImage: alpine.#Image & { _defaultImage: alpine.#Build & {
packages: python: version: "3" packages: python: version: "3"
} }
mounts: "Python script": {
contents: script._directory
dest: _mountpoint
}
} }
} }

View File

@ -0,0 +1,2 @@
with open('out.txt', 'w') as f:
f.write("Hello, world\n")

View File

@ -0,0 +1,9 @@
setup() {
load '../../bats_helpers'
common_setup
}
@test "python" {
dagger "do" -p ./test.cue test
}

View File

@ -0,0 +1,44 @@
package python
import (
"dagger.io/dagger"
"dagger.io/dagger/core"
"universe.dagger.io/python"
)
dagger.#Plan & {
actions: test: {
// Run a script from source directory + filename
runFile: {
dir: _load.output
_load: core.#Source & {
path: "./data"
include: ["*.py"]
}
run: python.#Run & {
export: files: "/out.txt": _
script: {
directory: dir
filename: "helloworld.py"
}
}
output: run.export.files."/out.txt" & "Hello, world\n"
}
// Run a script from string
runString: {
run: python.#Run & {
export: files: "/output.txt": _
script: contents: #"""
with open("output.txt", 'w') as f:
f.write("Hello, inlined world!\n")
"""#
}
output: run.export.files."/output.txt" & "Hello, inlined world!\n"
}
}
}