Skip to main content

Validate Godot save-game fixtures and catch compatibility drift before release.

Project description

Godot Save Schema Guard

Validate Godot save-game fixtures against explicit schemas and catch incompatible save format changes before release.

The first release focuses on JSON saves because they are deterministic to validate outside the engine. It is meant to be a release gate: do not break player saves.

Install

python -m pip install -e .

When published:

python -m pip install godot-save-schema-guard

Quick Start

godot-save-guard validate saves\fixtures --schema schemas\save.schema.json
godot-save-guard validate examples\fixtures --schema examples\schema\save.schema.json --format markdown --output SAVE_COMPATIBILITY.md
godot-save-guard migrate saves\v1 --output-dir migrated\v2 --command "godot --headless --script tools/migrate_save.gd --input {input} --output {output}"
godot-save-guard migrate-chain saves\v1 --chain migrations.toml --output-dir migrated --dry-run

What It Checks

  • Invalid JSON fixtures.
  • Missing top-level version.
  • Missing required schema properties.
  • Numeric type drift such as "100" where a number is expected.
  • Type mismatches.
  • Unexpected properties when additionalProperties is false.
  • Migration command failures.
  • Ordered migration chains from older save versions to the current format.
  • Report metadata and plain-language rule explanations for compatibility findings.

Documentation

Development

python -m pip install -e .
python -m unittest discover -s tests -v
godot-save-guard validate examples\fixtures --schema examples\schema\save.schema.json --fail-on none

Fixtures are generic and intentionally small so the repository is safe to publish.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

godot_save_schema_guard-0.1.2.tar.gz (11.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

godot_save_schema_guard-0.1.2-py3-none-any.whl (11.2 kB view details)

Uploaded Python 3

File details

Details for the file godot_save_schema_guard-0.1.2.tar.gz.

File metadata

  • Download URL: godot_save_schema_guard-0.1.2.tar.gz
  • Upload date:
  • Size: 11.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for godot_save_schema_guard-0.1.2.tar.gz
Algorithm Hash digest
SHA256 40f5ab06e02230278675084b02a3b781c55360ed1726deb82c68791a08016b44
MD5 a36eaef07dbc3090b1177a78118e4265
BLAKE2b-256 24fe2372c598a6b37b73c5cba8c21f401ef459a83546a1589906b80b0d12fb83

See more details on using hashes here.

Provenance

The following attestation bundles were made for godot_save_schema_guard-0.1.2.tar.gz:

Publisher: publish-save-schema-guard.yml on NonniGB/godot-production-toolkit

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file godot_save_schema_guard-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for godot_save_schema_guard-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 6370a790715329cc6b18cef71ff2900951290424afb3c25f3e5fb7edd29436fd
MD5 df7376593d48521d24b28713d72d31fe
BLAKE2b-256 231dccdb23f64e4b6390fb3069c30fec41866a771ab4f18d08b5c6ec5f1915a8

See more details on using hashes here.

Provenance

The following attestation bundles were made for godot_save_schema_guard-0.1.2-py3-none-any.whl:

Publisher: publish-save-schema-guard.yml on NonniGB/godot-production-toolkit

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page