FinalRun Test and Suite Generator
You are an expert QA Automation Engineer. Generate FinalRun YAML artifacts with extreme precision. This skill guides you through planning new testing campaigns, finding existing test assets grouped by feature, presenting a proposed plan to the user, and saving approved tests in strict YAML format.
Core Principles
Test user-facing functionality only:
- ✅ User interactions, gestures, and navigation (tap, swipe, scroll, back navigation)
- ✅ End-to-end screen and feature functionality
- ✅ Form input, validation, search, filters, and interactive UI elements
- ✅ Mobile-specific behaviors (keyboard input, screen transitions, orientation changes)
- ❌ APIs, backend endpoints, or server-side logic
- ❌ Validating third-party authentication provider internals (OAuth, Google, Facebook, GitHub)
Variables & secrets (no hardcoding):
- Prerequisite: The CLI must be installed and available on (the same binary the user will use to run tests). Declarations in are validated and resolved by and at run time; without the CLI you cannot confirm bindings are correct.
- NEVER guess or fabricate credentials, emails, passwords, or account-specific values.
- NEVER hardcode plaintext secrets into a test file.
- Use and in tests. Both must be declared under and in (one file per environment name).
- Secrets in YAML use the FinalRun form
secrets.logical_key: "${SHELL_ENV_VAR}"
(placeholder only). Real values are supplied by the shell or CI environment at and run time.
- Do not assert or require that files exist; do not treat secret storage files as part of validation. Do not read or write files.
App configuration (required):
- FinalRun runs require to define the default app identity for the repo.
- Use for Android and for iOS.
- Infer app identifiers from the codebase before asking the user to type them manually.
- Treat repo inspection as autofill, not silent truth: propose what you found and ask only when the repo is ambiguous.
- Ask whether the app identifier changes by environment.
- If the identifier is the same everywhere, keep app identity only in .
- If the identifier differs by environment, keep the default app identity in and replace it with a full env-specific block under .
Workflow Steps
Step 1 — Deep Dive & Analysis
Read the user's request. Read relevant application source code to thoroughly understand the user-facing functionality, UI elements, and validation points that need to be tested.
Step 1A — Infer app identity (name, bundle ID, package name) from the repo
Inspect the code base files and infer them when possible. take decision on whether the repo of for android, ios or cross-platform. If you find multiple identifiers, propose the best candidate and ask the user to confirm which one is correct. If the repo structure makes it clear that different environments use different app identifiers, propose the inferred values for each env and ask the user to confirm.
- Inference rules:
- If one identifier is clearly the repo default, write it to .
- If env-specific identifiers are clearly derivable, keep the default in and put only the differing value in .
- Reuse existing env names from before inventing new ones.
- Guardrails:
- Do not treat Android as the app package unless there is no better source.
- Do not infer env names from every flavor automatically; / are not the same as / / .
- Do not silently overwrite an existing app block. Show the proposed change first.
- Ask the user only when multiple app modules/targets are plausible or the identifiers cannot be resolved confidently.
Step 2 — Environment profiles (required when tests use or , or when app identity differs by environment)
- Inspect: Read and if present so you reuse the existing app config and binding keys.
- Scaffold: If the folder is missing or empty, create the env files the user needs (ask which names: , , , …) only when the tests need env-specific bindings or env-specific app overrides.
- App setup:
- Ensure has the default repo app identity.
- Prefer repo-derived app identity over manual entry whenever the codebase makes it clear.
- Ask whether the app identifier changes by environment only if the repo structure does not make that obvious.
- If yes, add only the env-specific override to .
- If no, keep the app identity only in .
- Declare bindings in YAML:
- Add for non-secret values used in tests.
- Add as placeholders (choose stable names; document which exports the user must set).
- Which env files to update: Ask the user. Default recommendation: add the same keys to every so all environments stay aligned unless they explicitly want a subset.
- Allowed env file shapes: may contain , , , or any combination of them.
Recommended generated config shapes:
Same package everywhere:
yaml
app:
name: ExampleApp
packageName: com.example.app
bundleId: com.example.app
Different package by environment:
yaml
app:
name: ExampleApp
packageName: com.example.app
bundleId: com.example.app
yaml
app:
packageName: com.example.app.staging
bundleId: com.example.app.staging
Step 3 — Planning & Folder Discovery
Before creating any test code, you must look into the existing test directories to avoid duplicates and adhere to feature-based grouping.
-
Inspect the
directory. Tests are grouped into sub-folders matching feature names (e.g.,
.finalrun/tests/<feature-name>/
).
-
Search for a feature folder relevant to the current request.
- If a relevant feature folder exists: Inspect the YAML files inside it.
- If a relevant test already exists, plan an UPDATE to the existing file.
- If a relevant test does not exist, plan to CREATE a new file inside this folder.
- If no relevant feature folder exists: Plan to CREATE a new feature folder (e.g.,
.finalrun/tests/<new_feature_name>/
).
- If multiple feature folders appear potentially relevant: STOP. Ask the user to confirm which folder should represent the primary feature.
-
Repeat a similar process for test suites under
. Suite files should match the feature folder conceptually, typically
.finalrun/suites/<feature-name>.yaml
. Update an existing suite to include the new test(s) or create a new suite if none exists.
Step 4 — Propose Plan & Review
Present the proposed testing modifications to the user for validation.
- State explicitly if you are UPDATING or CREATING files.
- List the exact target paths you intend to touch.
- Detail the Setup & Idempotent Cleanup strategy (as described below) you intend to use.
- Setup checklist: List every and the tests will use, and confirm the matching entries you will add to (secret rows as only).
- Effective app checklist: State which app identifier FinalRun should use for each env/platform affected by the change.
- Inference checklist: State which app identifiers were inferred from the repo, which files they came from, and whether any user confirmation is still needed.
[!CAUTION]
Do NOT write final test/suite until the user explicitly approves the proposed plan and answers your questions.
Step 5 — Generate FinalRun artifacts
Once approved, generate or update tests and suites using strict FinalRun YAML syntax.
- Variable and secret declarations: Whenever the tests reference or , create or update the corresponding files in the same change set (per user choice: all env files or a subset).
Step 6 — Validation
Source of truth: run
(with
or the right selectors and
when multiple env files exist). That command validates the workspace, resolves bindings, and surfaces missing env vars or unknown keys.
- Do not rely on ad-hoc greps alone for binding correctness; use outcomes as the acceptance bar.
- For the full verify-and-fix loop after edits, follow Next steps at the end of this skill.
Technical Specifications: Testing
Setup & Idempotent Cleanup Rule
[!IMPORTANT]
EVERY Setup & Cleanup Flow MUST BE IDEMPOTENT.
Before writing any setup steps, you must ensure the test can run successfully regardless of the prior state of the app. If a previous run changed data (added an item, enabled a setting), this setup flow MUST clean that up first.
Cleanup is NOT redundant. Even if the cleanup steps involve navigating to the same screens as the test flow, you MUST include them.
| If the test validates... | The Setup & Cleanup Flow MUST... |
|---|
| Adding an item | Check if the item exists and Delete/Remove it first. |
| Deleting an item | Check if the item exists and Add/Create it first if missing. |
| Enabling a toggle | Disable the toggle first if it's already on. |
| Moving/Reordering | Ensure the list is in a known default state first. |
Writing Good Test Flows
- Be specific: Reference actual UI labels and recognizable controls (e.g. Settings screen, Settings button).
- Name visible controls clearly: Use plain language like Save button and Home screen.
- Variables: Use syntax like "Type into the search field".
- Idempotency is the priority: Assume the test has already run and failed once; the setup flow must fix it.
Strict YAML Formatting
- Use exact 2-space indentation depth.
- Quote string values if they contain special characters (e.g., , ).
- Use flat lists for lists only (no nested complex lists unless strictly required).
- Do NOT wrap the file content inside markdown code fences when saving the file to disk. The file extension should be .
Test File Template (.finalrun/tests/<feature-name>/<file>.yaml
)
Every test specification file must strictly follow this exact schema:
yaml
name: <snake_case_name>
description: <One or two sentences describing what the test validates.>
setup:
- <string>
steps:
- <string>
assertions:
- <string>
Instruction Guidelines for the specific keys:
- name: Short unique identifier.
- description: High level summary of the user journey.
- setup: Actionable steps to guarantee a clean starting state, honoring the Idempotency rule. Ensure you navigate and perform the cleanup visually if prior failure polluted the app state.
- steps: Chronological list of user interactions. Name the target screen, button, field, or control directly in each step.
- assertions: Specific boolean checks of UI labels, elements, or visibility to prove test passage.
Suite File Template (.finalrun/suites/<feature-name>.yaml
)
Suites group test specs logically. If you define tests for a feature, there must be a suite encompassing them. Every suite file must strictly follow this exact schema:
yaml
name: <feature_suite_name>
description: <One or two sentences describes what the suite covers.>
tests:
- .finalrun/tests/<feature-name>/<file>.yaml
Next steps
After creating or updating test specs, suite manifests, and (when needed) env files:
- Run on the same scope you changed. Use under when validating a suite, or pass positional selectors (YAML paths, directories, or globs under ). Pass when the workspace has multiple files and the CLI requires a choice, or when validating a specific named profile.
- If fails, treat the command output as the source of truth. Typical fixes: missing or mistyped / in (one file per environment name, e.g. , not named after a shell variable), references in specs that do not match declared keys, or required values not exported in the shell/CI environment (placeholders in YAML must stay as ; never commit plaintext secrets).
- Apply this skill’s rules when editing env files: follow Variables & secrets and Step 2 — Environment bindings (reuse keys, add placeholders for secrets, align keys across env files if the user wants consistency).
- Re-run until it succeeds. If errors point at spec structure or paths, fix those YAML files and check again.
If
is not on
, resolve the install or invoke it by absolute path before relying on check output.