CI-friendly Godot export_presets.cfg checks for Android, desktop, web, and release-readiness settings.
Project description
Godot Export Preset Doctor
Release-readiness checks for Godot export_presets.cfg, focused on Android, CI export hygiene, debug flags, signing safety, package identity, ABIs, icons, and missing export paths.
The tool is a companion to export workflows. It does not build the game; it catches risky preset drift before a release job runs godot --headless --export-release.
Use it when a release preset changes, when setting up a new export target, or before cutting a public build from CI.
Install
python -m pip install -e .
From PyPI:
python -m pip install godot-export-preset-doctor
Quick Start
godot-export-doctor C:\Projects\MyGame
godot-export-doctor . --platform Android
godot-export-doctor . --platform Android --required-android-abi arm64-v8a
godot-export-doctor . --format sarif --output export-doctor.sarif
godot-export-doctor matrix . --expected-platform Android --expected-platform Web --format markdown
godot-export-doctor leaks . --format html --output reports\export-leaks.html
Use --fail-on none while exploring a report:
godot-export-doctor examples\bad-export-project --fail-on none
Real Workflow: Gate Release Presets In CI
Run the checker before a Godot export step so preset drift fails early:
godot-export-doctor . --platform Android --fail-on warning --format sarif --output reports\export-doctor.sarif
This is especially useful for:
- catching debug flags that were left enabled in release-like presets;
- checking Android package id, version, icon, and ABI readiness;
- spotting local keystore paths or literal credential values before reports are shared;
- confirming export paths exist and match the expected target.
For a first pass on an existing project, avoid failing the build while you review findings:
godot-export-doctor . --platform Android --fail-on none --format json --output reports\export-doctor.json
Require a specific Android ABI without creating a config file:
godot-export-doctor . --platform Android --required-android-abi arm64-v8a --fail-on warning
What It Checks
- Missing
export_presets.cfg. - Missing preset name, platform, or export path.
- Android package id, version code/name, enabled ABI, and launcher icon readiness.
- Release-like presets with debug options enabled.
- Hard-coded password, token, secret, or keystore-like values.
- Missing or duplicated expected export platforms in a release matrix.
- Broad export filters that may include debug/test/source files.
- Local-looking export, include, or exclude paths that should not be shared in CI artifacts.
- JSON and SARIF output for scripts and CI, with plain-language rule explanations.
Commands
check is the default command and keeps the original release-readiness behavior:
godot-export-doctor check . --platform Android --format sarif --output reports\export.sarif
For older scripts, this is equivalent to:
godot-export-doctor . --platform Android --format sarif --output reports\export.sarif
matrix gives a compact table of export presets and warns when an expected
platform is missing or duplicated:
godot-export-doctor matrix . --expected-platform Android --expected-platform Web --format markdown
leaks checks broad export filters against common development-file patterns and
flags local-looking paths in preset fields:
godot-export-doctor leaks . --format html --output reports\export-leaks.html --fail-on none
Configuration
Create .godot-export-doctor.toml:
format = "text"
fail_on = "warning"
platform = "Android"
required_android_abis = ["arm64-v8a"]
allowed_secret_patterns = ["<.+>"]
CLI flags override config values.
Output
Text:
godot-export-doctor .
JSON:
godot-export-doctor . --format json --output export-report.json
JSON reports include report metadata, a rule catalog, and findings with readable titles and explanations. This makes CI artifacts easier to review without looking up every rule id.
Markdown or HTML matrix report:
godot-export-doctor matrix . --expected-platform Android --expected-platform Web --format html --output export-matrix.html
SARIF:
godot-export-doctor . --format sarif --output export-doctor.sarif
CI Example
- run: python -m pip install godot-export-preset-doctor
- run: godot-export-doctor . --platform Android --fail-on warning --format sarif --output reports/export-doctor.sarif
- run: godot-export-doctor matrix . --expected-platform Android --expected-platform Web --format markdown --output reports/export-matrix.md --fail-on warning
- run: godot-export-doctor leaks . --format html --output reports/export-leaks.html --fail-on warning
Documentation
- Android release checklist
- Rule reference
- Security guide
- Configuration
- CI integration
- Troubleshooting
Development
python -m pip install -e .
python -m unittest discover -s tests -v
godot-export-doctor examples\bad-export-project --fail-on none
Design Notes
The checker is intentionally static. It reads Godot config files and reports conservative findings that are useful in local development and CI. It does not need the Godot editor, Android SDK, or network access.
Examples and fixtures are generic by design. They should be safe to publish without exposing private project details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file godot_export_preset_doctor-0.1.8.tar.gz.
File metadata
- Download URL: godot_export_preset_doctor-0.1.8.tar.gz
- Upload date:
- Size: 20.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
629fd2653843293f697a3114c0d8192bc5cc5b890e50e48c9b199a456a005456
|
|
| MD5 |
3f46c7fb6108272d748b9b9853246341
|
|
| BLAKE2b-256 |
1191c15767c30dc80bb76b7b16c58a26460ec2054d869311a63a84ca572ffabe
|
Provenance
The following attestation bundles were made for godot_export_preset_doctor-0.1.8.tar.gz:
Publisher:
publish-export-preset-doctor.yml on NonniGB/godot-production-toolkit
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
godot_export_preset_doctor-0.1.8.tar.gz -
Subject digest:
629fd2653843293f697a3114c0d8192bc5cc5b890e50e48c9b199a456a005456 - Sigstore transparency entry: 1838630391
- Sigstore integration time:
-
Permalink:
NonniGB/godot-production-toolkit@65fe4fccd566b62559b0f96037f5c7558fea2bf8 -
Branch / Tag:
refs/tags/godot-export-preset-doctor-v0.1.8 - Owner: https://github.com/NonniGB
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-export-preset-doctor.yml@65fe4fccd566b62559b0f96037f5c7558fea2bf8 -
Trigger Event:
push
-
Statement type:
File details
Details for the file godot_export_preset_doctor-0.1.8-py3-none-any.whl.
File metadata
- Download URL: godot_export_preset_doctor-0.1.8-py3-none-any.whl
- Upload date:
- Size: 18.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
012c65e21c6e09bbfaff69ebf44fe280601b213a81567c658cf2e1f1b66954af
|
|
| MD5 |
879dd5576071a9b62d5bca179ae94a06
|
|
| BLAKE2b-256 |
2c714312cb3c426e4cde59537534aa512436feacc9392a39adf63b5fc311c4d3
|
Provenance
The following attestation bundles were made for godot_export_preset_doctor-0.1.8-py3-none-any.whl:
Publisher:
publish-export-preset-doctor.yml on NonniGB/godot-production-toolkit
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
godot_export_preset_doctor-0.1.8-py3-none-any.whl -
Subject digest:
012c65e21c6e09bbfaff69ebf44fe280601b213a81567c658cf2e1f1b66954af - Sigstore transparency entry: 1838630473
- Sigstore integration time:
-
Permalink:
NonniGB/godot-production-toolkit@65fe4fccd566b62559b0f96037f5c7558fea2bf8 -
Branch / Tag:
refs/tags/godot-export-preset-doctor-v0.1.8 - Owner: https://github.com/NonniGB
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-export-preset-doctor.yml@65fe4fccd566b62559b0f96037f5c7558fea2bf8 -
Trigger Event:
push
-
Statement type: