Optional app.yml manifest for Snowflake App Runtime¶
The optional app.yml manifest tells the remote build how to install, build,
run, and package your application, along with optional profile metadata. When
you don’t provide it, Snowflake auto-detects build and run behavior from your
project layout (for example, package.json for Node.js). Hand-edit app.yml when
you need to customize those install, build, run, or packaging steps, or to set the
app’s display profile. Name the file app.yml and place it in your application
source.
Note
Cortex Code CLI and Cortex Code Desktop generate this file automatically when scaffolding Snowflake App Runtime projects.
For deploy configuration, the Snowflake CLI uses a separate snowflake.yml
project file that snow app setup creates and snow app deploy reads. See
Getting started with Snowflake App Runtime and
snow app setup.
app.yml reference¶
Top-level structure¶
All top-level keys are optional. Snowflake ignores unknown keys.
Keys¶
install¶
Commands Snowflake runs during the install phase, before the build. Each
entry under commands is an argv-style list, passed directly without a
shell. Use install for setup steps such as installing dependencies.
build¶
Commands Snowflake runs during the build phase. Each entry under commands
is an argv-style list.
run¶
The entry-point command that starts the application container. command
is an argv-style list.
artifacts¶
Copy rules that move files produced by the build into the final package. Each entry has these fields:
src: Glob pattern, relative to the build working directory, that matches the files to copy. The pattern supports**for recursive matching (provided by the doublestar library). For example,dist/**matches every file underdistat any depth.dest: Destination path within the package. Setdestto.to flatten matched files into the package root by basename. Setdestto any other path to preserve the directory structure of the matched files relative to the glob base, rooted atdest.
Only files that match the glob are copied; directories themselves aren’t
copied. To include a directory tree, use **.
profile¶
Presentation metadata surfaced alongside the deployed service.
icon: Relative path to a.pngor.svgfile inside the package. The path must not contain...label: Short display label.description: Longer human-readable description.
The label and description values appear in the
additional_properties column of SHOW APPLICATION SERVICES.
Validation during remote build¶
When your project includes app.yml and you run a remote build (for example
snow app deploy or an artifact build that reads uploaded source), Snowflake
loads and validates the manifest from the stage. If the file is missing,
Snowflake can still auto-detect build and run behavior from your project layout.
If app.yml is present but invalid, the build fails before a new package
version is published. Common causes include:
- YAML syntax errors.
- Invalid
profile.iconvalues (path traversal, absolute paths, or unsupported image formats).
The error message includes parser details, for example:
Application service manifest (app.yaml) cannot be parsed. '<details>'.