GitHub Actions
GitHub Actions is a continuous integration and continuous delivery (CI/CD) platform that allows you to automate your build, test, and deployment pipeline. You can create workflows that build and test every pull request to your repository, or deploy merged pull requests to production.
Recently, GitHub added the ability to use GitHub Models in actions as well.
The combo of Actions and Models allows you to run GenAIScript as part of your CI/CD.
Samples
Section titled “Samples”GitHub Models Permissions
Section titled “GitHub Models Permissions”To use Models in a GitHub Action, you need to set the permissions for the action to include models: read.
permissions: models: readGenAIScript has built-in support for GitHub Models, so you can use it directly in your GitHub Actions workflow.
Using the CLI
Section titled “Using the CLI”The simplest way to use GenAIScript in a GitHub Action is to run the CLI directly.
You can do this by adding a step to your workflow that runs the genaiscript command.
- uses: actions/setup-node@v4 # make sure node.js is installed- name: Run GenAIScript run: npx -y genaiscript run ... env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}Make sure to include the GITHUB_TOKEN in the environment variables so that GenAIScript can authenticate with GitHub Models.
---run: npx -y genaiscript run ...env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}Custom Actions
Section titled “Custom Actions ”GitHub supports packaging tasks as custom actions, typically in a dedicated repository. This is a great way to package an AI script and share it with others.
- name: Run AI Script uses: <owner>/<repo>@<tag> with: github_token: ${{ secrets.GITHUB_TOKEN }}The GenAIScript CLI provides a command to generate/update the boilerplate code to package a script as a Docker container action so that it can be used in GitHub Actions regardless of the language used to write the script.
To get started,
Create a new repository for your action.
Open a terminal in the root of your repository.
Run the command to generate the action boilerplate:
Terminal window npx -y genaiscript configure action
The action boilerplate generator will override the following files:
action.ymlAction metadata fileDockerfileDockerfile for the actionREADME.mdDocumentation for the action.gitignoreFiles to ignore in the repository.github/workflows/ci.ymlCI workflow to test the actionpackage.jsonPackage configuration for the actiondevcontainer/devcontainer.jsonDevcontainer configuration for VS Codedevcontainer/DockerfileDevcontainer Dockerfile for VS Code. Must be kept in sync with the action Dockerfile.
To update the action boilerplate, you can run the same command again:
npm run configureMetadata
Section titled “Metadata”The action.yml file contains metadata about the action. It is mined from various part of your project:
- The
nameis derived from the script id. - The
descriptionis derived from the scripttitle. - The
inputsare derived from the script parameters (see below).
Note that the script.description is used to populate the README.md file.
Inputs
Section titled “Inputs”The inputs section of the action.yml file is automatically generated from the script parameters.
Each parameter is converted to an input with the same name, and the type is inferred from the parameter type.
script({ title: "A poem generator", accept: "none", parameters: { topic: "nature" }})$`Write a poem about ${env.vars.topic}`.The generate action.yml will look like this:
name: poemdescription: Write a poem about natureinputs: topic: description: The topic of the poem required: false default: natureThere are also additional fields that are common to all GenAIScript actions:
files: Specify a file path to populate theenv.filesvariable. To remove this field, setaccept: "none"in the script.github_token: This is required to authenticate with GitHub Models. It will becomeINPUT_GITHUB_TOKENwhen the container is created and GenAIScript will pick it up automatically.github_issue: The current GitHub issue or pull request number.debug: The filter to control debug logging messages.
Outputs
Section titled “Outputs”The action populates a few output fields.
text: this is the generated text from the script.data: this is the structure output parsed and stringified as JSON. This field is populated if you provide a responseSchema in the script and if the LLM is able to generate a response that matches the schema.
Branding
Section titled “Branding”The script branding field is used to customize the appearance of the action in the GitHub UI.
script({ branding: { icon: "pencil", color: "blue", },})Containers
Section titled “Containers”By default, GenAIScript uses node:lts-alpine as the base image for the action container.
You can change this by specifying a different base image in the cli.
npx -y genaiscript configure action ... --image <image>GenAIScript will also create a devcontainer so that you can develop the action in the (almost same) containerized environment as when it runs in the GitHub Action.
ffmpeg, playwright and other packages
Section titled “ffmpeg, playwright and other packages”To keep the action container small, GenAIScript does not include ffmpeg, playwright or other packages by default.
You can add them to the container by specifying them in the cli command.
npx -y genaiscript configure action ... --ffmpeg --playwrightYou can also add any other packages you need by specifying them in the cli command.
npx -y genaiscript configure action ... --apks <package1> <package2>Testing the Action
Section titled “Testing the Action”Your script should be testable locally using the npm run dev command. Feel free to edit it in package.json.
npm run devOr if you want to simulate the GitHub Action environment,
you can set the INPUT_<parameter> variables in the environment.
INPUT_TOPIC=nature genaiscript run poemGitHub Workspace vs Action Workspace
Section titled “GitHub Workspace vs Action Workspace”When running the action in a container, the content of the action repository
is first copied in the /github/action directory. GitHub clones the repository to the /github/workspace directory.
The Dockerfile ENTRYPOINT is configured to launch the genaiscript cli in the /github/action directory
and then it sniffs for the GITHUB_WORKSPACE environment variable to determine the working directory
and changes the cwd to it.
This mode is enabled by the --github-workspace flag in the cli command.