Skip to content

fix(docs-sync): stop overwriting the generated root _meta.json#352

Open
acastellana wants to merge 1 commit into
v0.40-devfrom
docs/fix-sync-meta-overwrite
Open

fix(docs-sync): stop overwriting the generated root _meta.json#352
acastellana wants to merge 1 commit into
v0.40-devfrom
docs/fix-sync-meta-overwrite

Conversation

@acastellana

@acastellana acastellana commented Jun 11, 2026

Copy link
Copy Markdown

Problem

sync-docs.yml rsyncs the generated, category-based docs/api-references/_meta.json into genlayer-docs — and then immediately overwrites it with a hardcoded heredoc containing the pre-grouping flat command list (init, up, deploy, …). Those keys haven't matched the directory layout since the commands were grouped into category folders, so every sync shipped a broken sidebar to docs.genlayer.com (most entries pointed at nothing, and whole command groups were missing from the LLM exports there).

genlayerlabs/genlayer-docs#426 fixed the meta manually on the docs side; this PR removes the cause so the next release sync doesn't regress it.

Changes

  • .github/workflows/sync-docs.yml: delete the heredoc — the rsynced generated _meta.json is correct.
  • scripts/generate-cli-docs.mjs: make the generated root meta complete — "index": "Overview" first, then the category groups, then any ungrouped top-level commands (currently estimate-fees, finalize, finalize-batch) so they get explicit nav entries.
  • docs/api-references/ snapshot: regenerated against current main (node scripts/generate-cli-docs.mjs after npm run build) — picks up the new estimate-fees command page and latest help text.

Verification

Ran the generator locally against a fresh build; the emitted root _meta.json is:

{
  "index": "Overview",
  "environment": "Environment",
  "configuration": "Configuration",
  "contracts": "Contracts",
  "transactions": "Transactions",
  "accounts": "Accounts",
  "staking": "Staking",
  "localnet": "Localnet",
  "estimate-fees": "estimate-fees",
  "finalize": "finalize",
  "finalize-batch": "finalize-batch"
}

which matches the directory layout the workflow rsyncs (67 pages generated).

🤖 Generated with Claude Code

Summary by CodeRabbit

  • New Features

    • Added three new CLI commands: estimate-fees, finalize, and finalize-batch
    • Added optional parameters (--fees, --fee-value, --valid-until) to deploy and write commands
  • Documentation

    • Updated CLI API reference documentation with new command references
    • Updated version to 0.39.1
    • Enhanced transaction receipt status documentation

The sync-docs workflow rsynced the generated category-based
docs/api-references/_meta.json into genlayer-docs and then immediately
overwrote it with a hardcoded heredoc containing the pre-grouping flat
command list (init, up, deploy, ...). Those keys no longer match the
directory layout, so the genlayer-docs sidebar rendered broken entries
on every sync (fixed manually in genlayer-docs#426; this removes the
cause).

Also make the generated root meta complete:
- add "index": "Overview" for the generated index.mdx
- append ungrouped top-level commands (estimate-fees, finalize,
  finalize-batch) so they get explicit nav entries instead of relying
  on Nextra's implicit append

Snapshot under docs/api-references regenerated against current main
(picks up the new estimate-fees command and latest help text).

Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
@github-actions github-actions Bot changed the base branch from main to v0.40-dev June 11, 2026 15:26
@github-actions

Copy link
Copy Markdown

This PR targeted main, which is only the default/static branch.

I retargeted it to v0.40-dev, the active development branch. Pushes to v0.40-dev automatically fast-forward main.

@coderabbitai

coderabbitai Bot commented Jun 11, 2026

Copy link
Copy Markdown

Review Change Stack

No actionable comments were generated in the recent review. 🎉

ℹ️ Recent review info
⚙️ Run configuration

Configuration used: defaults

Review profile: CHILL

Plan: Pro

Run ID: 07bed510-f628-4bda-9b8d-6f943f455875

📥 Commits

Reviewing files that changed from the base of the PR and between 2100255 and ae7fd72.

📒 Files selected for processing (10)
  • .github/workflows/sync-docs.yml
  • docs/api-references/_meta.json
  • docs/api-references/contracts/deploy.mdx
  • docs/api-references/contracts/write.mdx
  • docs/api-references/estimate-fees.mdx
  • docs/api-references/finalize-batch.mdx
  • docs/api-references/finalize.mdx
  • docs/api-references/index.mdx
  • docs/api-references/transactions/receipt.mdx
  • scripts/generate-cli-docs.mjs
💤 Files with no reviewable changes (1)
  • .github/workflows/sync-docs.yml

📝 Walkthrough

Walkthrough

This PR documents three new CLI commands (estimate-fees, finalize, finalize-batch) and updates existing command documentation with new fee-related options. The doc generation script is refactored to automatically populate root-level command metadata, and the workflow is simplified to rely on that script instead of manually generating metadata files.

Changes

CLI Documentation for Fee and Finalize Commands

Layer / File(s) Summary
Root metadata generation and structure
scripts/generate-cli-docs.mjs, docs/api-references/_meta.json
Script now initializes rootMeta with default index entry and scans generated pages to add ungrouped root-level commands to metadata. Root _meta.json updated with new entries for estimate-fees, finalize, and finalize-batch.
New estimate-fees and finalize command documentation
docs/api-references/estimate-fees.mdx, docs/api-references/finalize.mdx, docs/api-references/finalize-batch.mdx
Three new CLI command reference pages added: estimate-fees with contract/method arguments and RPC/JSON options; finalize for single-transaction finalization; finalize-batch for batch finalization.
Updated existing command documentation and index
docs/api-references/index.mdx, docs/api-references/contracts/deploy.mdx, docs/api-references/contracts/write.mdx, docs/api-references/transactions/receipt.mdx
CLI version bumped to 0.39.1 with new command entries. Deploy and write commands documented with three new optional flags: --fees, --fee-value, --valid-until. Receipt docs clarify transaction status values and FINALIZED default.
Workflow simplification
.github/workflows/sync-docs.yml
Removed manual generation of pages/api-references/genlayer-cli/_meta.json from workflow; metadata is now fully managed by generate-cli-docs.mjs.

Estimated code review effort

🎯 2 (Simple) | ⏱️ ~12 minutes

Possibly related PRs

  • genlayerlabs/genlayer-cli#247: Touches the same CLI-doc generation pipeline and _meta.json workflow to alter root/navigation metadata production.

Suggested reviewers

  • cristiam86

Poem

🐰 Three new commands emerge from the warren,
Fee estimation and finalization so bold,
The script now speaks for metadata's fortune,
Root-level dancers, our workflow unfolds!
🌟

🚥 Pre-merge checks | ✅ 4 | ❌ 1

❌ Failed checks (1 warning)

Check name Status Explanation Resolution
Docstring Coverage ⚠️ Warning Docstring coverage is 0.00% which is insufficient. The required threshold is 80.00%. Write docstrings for the functions missing them to satisfy the coverage threshold.
✅ Passed checks (4 passed)
Check name Status Explanation
Description Check ✅ Passed Check skipped - CodeRabbit’s high-level summary is enabled.
Title check ✅ Passed The title accurately identifies the main objective: fixing the docs-sync process by stopping the overwriting of the generated root _meta.json file, which is the core issue addressed in this PR.
Linked Issues check ✅ Passed Check skipped because no linked issues were found for this pull request.
Out of Scope Changes check ✅ Passed Check skipped because no linked issues were found for this pull request.

✏️ Tip: You can configure your own custom pre-merge checks in the settings.

✨ Finishing Touches
📝 Generate docstrings
  • Create stacked PR
  • Commit on current branch
🧪 Generate unit tests (beta)
  • Create PR with unit tests
  • Commit unit tests in branch docs/fix-sync-meta-overwrite

Warning

There were issues while running some tools. Please review the errors and either fix the tool's configuration or disable the tool if it's a critical failure.

🔧 ESLint

If the error stems from missing dependencies, add them to the package.json file. For unrecoverable errors (e.g., due to private dependencies), disable the tool in the CodeRabbit configuration.

ESLint install failed. For unrecoverable errors, disable the tool in CodeRabbit configuration.


Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

Comment @coderabbitai help to get the list of available commands and usage tips.

@chatgpt-codex-connector chatgpt-codex-connector Bot left a comment

Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

💡 Codex Review

Here are some automated review suggestions for this pull request.

Reviewed commit: ae7fd726f6

ℹ️ About Codex in GitHub

Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you

  • Open a pull request for review
  • Mark a draft as ready
  • Comment "@codex review".

If Codex has suggestions, it will comment; otherwise it will react with 👍.

Codex can also answer questions or update the PR. Try commenting "@codex address that feedback".

| | --rpc &lt;rpcUrl&gt; | RPC URL for the network | No | |
| | --fees &lt;json&gt; | Fee estimate options JSON passed to genlayer-js estimateTransactionFees. | No | |
| | --json | Print the fee estimate as JSON without spinner output | No | |
| | --include-report | Include simulation fee accounting/report in the generated estimate output | No | |

Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

P2 Badge Include variadic --args in estimate-fees docs

When users run estimate-fees in simulation mode for a contract method that takes arguments, the CLI accepts --args <args...> (src/commands/contracts/index.ts:163-168), but this newly added options table omits that option and only documents --rpc, --fees, --json, and --include-report. This leaves the generated reference incomplete for the main case where [contractAddress] [method] needs calldata arguments.

Useful? React with 👍 / 👎.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant