Optional app.yml manifest for Snowflake App Runtime

The optional app.yml manifest tells the build phase 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

install:
  commands:
    - [<command>, <arg>, ...]
build:
  commands:
    - [<command>, <arg>, ...]
run:
  command: [<command>, <arg>, ...]
artifacts:
  - src: <glob_pattern>
    dest: <destination_path>
profile:
  icon: <relative_path_to_icon>
  label: <display_label>
  description: <description_text>

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.

install:
  commands:
    - [npm, ci]

build

Commands Snowflake runs during the build phase. Each entry under commands is an argv-style list.

build:
  commands:
    - [npm, run, build]

run

The entry-point command that starts the application container. command is an argv-style list.

run:
  command: [node, server.js]

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 under dist at any depth.
  • dest: Destination path within the package. Set dest to . to flatten matched files into the package root by basename. Set dest to any other path to preserve the directory structure of the matched files relative to the glob base, rooted at dest.

Only files that match the glob are copied; directories themselves aren’t copied. To include a directory tree, use **.

artifacts:
  - src: "dist/**"
    dest: "."
  - src: "package.json"
    dest: "."

profile

Presentation metadata surfaced alongside the deployed service.

  • icon: Relative path to a .png or .svg file 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.

profile:
  icon: assets/logo.png
  label: Customer Portal
  description: Web UI for the customer-facing portal.

Validation during the build phase

When your project includes app.yml and you run snow app deploy, Snowflake loads and validates the manifest from uploaded source during the build phase. 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.icon values (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>'.

Example

install:
  commands:
    - [npm, ci]
build:
  commands:
    - [npm, run, build]
run:
  command: [node, dist/server.js]
artifacts:
  - src: "dist/**"
    dest: "."
profile:
  icon: assets/logo.png
  label: Customer Portal
  description: Customer portal web UI.