Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: update deno to v2.1.2 #923

Open
wants to merge 8 commits into
base: main
Choose a base branch
from
Open

chore: update deno to v2.1.2 #923

wants to merge 8 commits into from

Conversation

Yohe-Am
Copy link
Contributor

@Yohe-Am Yohe-Am commented Nov 16, 2024

  • Updates deno to 2.1.2
  • Updates rust to 1.82.0

Summary by CodeRabbit

Based on the comprehensive summary of changes, here are the updated release notes:

  • New Features

    • Updated Deno version to 2.1.2
    • Updated Rust version to 1.82.0
  • Dependencies

    • Upgraded multiple dependencies across Rust, Deno, and TypeScript packages
    • Updated Cargo dependencies, including clap, url, and deno versions
  • Improvements

    • Enhanced error handling with more explicit type annotations
    • Streamlined installation process for development tools
    • Refined permissions management in various runtime environments
  • Chores

    • Updated GitHub Actions workflows
    • Modernized configuration files
    • Improved code formatting and type safety
  • Bug Fixes

    • Resolved potential issues with permissions and runtime configurations

@Yohe-Am Yohe-Am requested a review from a team November 16, 2024 22:47
Natoandro
Natoandro previously approved these changes Nov 17, 2024
Natoandro
Natoandro previously approved these changes Dec 9, 2024
@Yohe-Am Yohe-Am changed the title chore: update deno to v2.0.6 chore: update deno to v2.1.2 Dec 16, 2024
Copy link
Contributor

coderabbitai bot commented Jan 2, 2025

📝 Walkthrough

Walkthrough

This pull request introduces a comprehensive set of updates across multiple files in the project, focusing on version upgrades, dependency management, and code refinements. Key changes include updating Rust and Deno versions to 1.82.0 and 2.1.2 respectively, modifying GitHub Actions workflows to use a new installation method for the ghjk tool, and making numerous type annotations and error handling improvements across TypeScript and Rust files. The modifications span configuration files, runtime environments, and testing utilities, reflecting a systematic approach to maintaining and improving the project's codebase.

Changes

File/Path Change Summary
.ghjk/lock.json - Added two new entries for deno_ghrel port (v2.0.6 and v2.1.2)
- Updated rust_rustup port from 1.80.1 to 1.82.0
.github/workflows/* - Replaced metatypedev/setup-ghjk action with direct script installation
- Updated multiple workflows to include new installation commands for ghjk
Cargo.toml - Updated dependency versions for clap, clap_complete, url, deno, and deno_core
deno.jsonc - Changed nodeModulesDir from false to "none"
- Removed allowJs property
ghjk.ts - Removed V8_FORCE_DEBUG variable from dev environment
rust-toolchain.toml - Updated Rust toolchain from 1.80.1 to 1.82.0
tools/Dockerfile - Updated Rust version to 1.82.0
- Updated Deno version to 2.1.2
- Modified ghjk installation method
tools/consts.ts - Updated RUST_VERSION to 1.82.0
- Updated DENO_VERSION to 2.1.2
Multiple TypeScript files - Added type annotations for error handling (changing catch (e) to catch (e: any))
Rust source files - Added V8 flag initialization in various runtime contexts

Sequence Diagram

sequenceDiagram
    participant Developer
    participant CI/CD
    participant Build System
    participant Runtime
    participant Dependencies

    Developer->>CI/CD: Push changes
    CI/CD->>Build System: Install dependencies
    Build System->>Dependencies: Fetch updated versions
    Build System->>Runtime: Configure environment
    Runtime->>Runtime: Initialize V8 flags
    CI/CD->>Build System: Run tests and lint
    Build System-->>Developer: Report build status
Loading

The sequence diagram illustrates the high-level workflow of the changes, showing how the updated dependencies and configurations are integrated into the build and runtime processes.


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 3

🧹 Nitpick comments (49)
src/mt_deno/src/lib.rs (2)

246-252: **Performing type checks **

Calling check_specifiers for type validation is an excellent step. Consider whether partial failures or concurrency might need explicit handling or more granular error reporting.


272-273: **Passing desc_parser to test executor **

Passing the desc_parser is clear. As a minor suggestion, consider logging or handling parser configuration errors for enhanced debugging, if applicable.

tests/schema_validation/type_comparison_test.ts (1)

10-10: **Use of catch (err: any) **

Specifying any clarifies the shape of the caught exception. If feasible, consider a narrower type or a custom error interface to improve type safety and debugging clarity.

src/typegate/src/services/auth/protocols/internal.ts (1)

52-52: Consider using a more specific type than any in the catch block.

While this approach works, using unknown or Error (when certain) can improve type safety. Consider narrowing or casting the error instead of relying on the any type.

src/typegate/src/services/auth/protocols/jwt.ts (1)

60-67: Avoid using any for error handling.

Using unknown or a more specific type can help catch issues at compile time. It's often best to narrow or cast the error.

tests/utils/s3.ts (2)

40-40: Consider using a more specific type instead of any.
While catching errors as any is quick, it may obscure potential type checks. Consider using a more specific error type or a type guard if feasible.


58-58: Replicate the approach from the previous catch block.
Same feedback applies here. If you can narrow down the type of raised exceptions, you could make your error handling more robust.

tools/list-duplicates.ts (2)

41-41: Safe casting approach.
Casting type.injection as any is understandable here. If you have a stable interface, consider using a stricter type.


55-55: Same reasoning about any.
To prevent losing type information, confirm that type.injection has a known shape and, if possible, declare a dedicated interface for it.

src/typegate/src/services/graphql_service.ts (1)

123-145: Ensure comprehensive logging and consistent error responses.

All error branches now log and return a response with err.message. Ensure that sensitive details are never leaked into logs. Otherwise, this is a clear, centralized approach to error handling.

src/xtask/src/deno.rs (1)

54-79: Refine commented-out allowed commands.

The large block of commented commands can make maintenance cumbersome. If you no longer need them, consider removing them permanently.

src/typegate/src/services/artifact_service.ts (1)

37-37: Consider using unknown instead of any.

While specifying a type for the caught error is an improvement over not specifying one at all, using unknown in place of any can enhance type safety and reduce the risk of runtime type errors.

src/typegate/engine/src/ext.rs (1)

142-146: Remove or clarify commented code.

The commented-out permissions code might be confusing to future maintainers unless there is an intention to restore or replace it. Consider removing it entirely or adding an explanatory comment describing why it remains in the file and when it might be reintroduced.

Also applies to: 148-148

src/typegate/src/services/rest_service.ts (1)

Line range hint 92-129: Consistent renaming of error variables is clear and precise.

Renaming e to err promotes clarity in error handling. However, consider using unknown instead of any for stronger type safety in TypeScript. Beyond this, the multiple checks for BaseError, ResolverError, and BadContext remain logically sound, ensuring appropriate HTTP response codes and JSON responses for each case.

src/typegate/src/libs/jsonpath.ts (1)

203-203: Explicit error typing strengthens maintainability.

Replacing an untyped catch variable with catch (e: any) clarifies the nature of the error, though using unknown could provide even better type safety and help guard against unintentional usage of error properties.

src/typegate/engine/src/lib.rs (1)

Line range hint 165-191: Consider removing commented-out default allow_import entries or converting them into configuration.

Having large commented-out segments may cause confusion. If you anticipate using these default hosts, consider making them configurable or removing them altogether to keep your codebase clean and maintainable.

src/typegate/src/runtimes/prisma/hooks/run_migrations.ts (1)

110-110: Use a more precise error type to improve type-checking.

Catching errors as any sacrifices type safety. Consider using unknown and then narrowing or wrapping the error, ensuring you capture exact information about failures.

tests/e2e/cli/deploy_test.ts (2)

86-86: Consider narrowing the error type in the catch block.

Catching exceptions as any is generally discouraged; using unknown and then narrowing or type-guarding may improve error handling reliability.


142-142: Improve error typing.

Again, consider using unknown to avoid losing compile-time checks and enforce explicit type narrowing. This helps preserve important error details when handling edge cases.

src/typegate/engine/bindings.ts (21)

59-59: Use more specific typing for error handling.

Catching errors as any forfeits type safety. Prefer unknown and then perform runtime checks or cast to a known error interface.


84-84: Enhance error type usage in catch.

Using any can hide actual error structures. Switch to unknown and handle possible error cases explicitly.


108-108: Encourage explicit error typing.

Relying on any leads to potential maintainability issues. If possible, replace with unknown and narrow the type.


127-127: Improve error typing for better clarity.

Switch from any to unknown or a known error type to leverage TypeScript’s type checks.


149-149: Refine error handling approach.

Catching an any type can conceal important details; prefer unknown plus a type guard or instance check.


171-171: Strengthen type safety in error handling.

Change any to unknown for stricter compile-time checks, reducing potential runtime errors.


190-190: Favor narrower error types.

Catching errors as any may hide critical type specifics, consider using unknown.


211-211: Adopt more explicit error type.

Maintain code clarity by dropping any in favor of unknown or a specialized error type.


234-234: Increase error-type clarity.

Use unknown to encourage explicit checking or transformation of caught errors.


253-253: Use explicit error handling strategy.

Replace any with unknown, forcing callers to handle error details properly.


275-275: Refine catch error typing.

A narrower type than any helps ensure that error properties are validated before use.


297-302: Leverage rigorous error typing.

Both catch blocks here use any. Reviewing them for unknown usage can improve clarity and safety.


339-339: Favor safer error typing.

Handling errors as unknown encourages robust validation and prevents accidental reliance on undefined properties.


362-362: Improve error stability with narrower types.

Using unknown ensures that reading properties on the error is done in a controlled manner.


388-388: Enhance reliability with explicit error typing.

Switching from any to unknown can help avoid unexpected runtime failures.


412-412: Strengthen error safety.

unknown is preferable over any to guarantee proper type checks for errors.


431-431: Encourage a typed catch block.

Use unknown in place of any so that error checks become more deliberate.


454-454: Refactor catch clause for better type checks.

Rely on a properly typed approach rather than any, ensuring strong error validation.


473-473: Favor narrower error type to maintain clarity.

By removing any, you reduce accidental assumptions about error structure or fields.


496-496: Use typed errors for clarity & safety.

Switch from any to unknown to align with TypeScript best practices for error handling.


516-516: Adopt a narrower type in catch for consistency.

Maintain consistent error handling throughout the codebase by ditching any for unknown.

src/typegate/src/typegate/mod.ts (1)

215-215: Enhance unknown error messaging
Using err.toString() is acceptable for unknown errors, but to improve debuggability, consider adding more metadata (e.g., stack trace) to the error message or logs.

tests/utils/test.ts (1)

357-357: Maintain consistent error-typing in test assertions
Typing the caught error as any is fine for tests, but if possible, consider more specific error types to gain type safety and avoid masking real issues.

src/typegate/src/engine/planner/policies.ts (1)

28-28: Clarify type usage for PolicyResolverOutput
Switching from (unknown & {}) to (unknown & any) removes some of the safety introduced by stricter types. Consider whether any is required or if there is a more precise type that captures the intended usage.

.github/workflows/publish-website.yml (2)

32-32: Trailing spaces found
Remove the trailing spaces to avoid triggering linter warnings.

-      
+
🧰 Tools
🪛 yamllint (1.35.1)

[error] 32-3232: trailing spaces

(trailing-spaces)


34-34: Quote the GHJK_VERSION variable to prevent word splitting
ShellCheck warns about potential issues if the $GHJK_VERSION variable contains spaces. Even if unlikely, quoting is considered best practice.

- - run: curl -fsSL https://raw.github.com/metatypedev/ghjk/$GHJK_VERSION/install.sh | bash
+ - run: curl -fsSL "https://raw.github.com/metatypedev/ghjk/$GHJK_VERSION/install.sh" | bash
🧰 Tools
🪛 actionlint (1.7.4)

34-3434: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)

Cargo.toml (1)

62-62: Note about deprecated dependency

The comment indicates that serde_yaml is deprecated. Consider tracking this as a future improvement.

.github/workflows/tests.yml (1)

173-173: Remove trailing whitespace

There are trailing spaces on lines 173 and 284.

Also applies to: 284-284

🧰 Tools
🪛 yamllint (1.35.1)

[error] 173-173173: trailing spaces

(trailing-spaces)

.github/workflows/release.yml (1)

38-42: Consider using a composite action to reduce code duplication.

The ghjk installation steps are repeated in multiple jobs. Consider creating a composite action to encapsulate these steps for better maintainability.

Example composite action:

# .github/actions/setup-ghjk/action.yml
name: 'Setup GHJK'
description: 'Installs GHJK'
runs:
  using: "composite"
  steps:
    - run: curl -fsSL "https://raw.github.com/metatypedev/ghjk/${GHJK_VERSION}/install.sh" | bash
      shell: bash
    - run: echo "$HOME/.local/bin" >> "$GITHUB_PATH"
      shell: bash
    - run: echo "BASH_ENV=$HOME/.local/share/ghjk/env.sh" >> "$GITHUB_ENV"
      shell: bash
    - run: ghjk envs cook
      shell: bash

Usage:

steps:
  - uses: ./.github/actions/setup-ghjk

Also applies to: 106-109, 186-190, 326-329

🧰 Tools
🪛 actionlint (1.7.4)

39-3939: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)

src/typegate/src/engine/planner/args.ts (1)

802-802: Consider using a more specific error type than any.

While adding a type annotation is good, using any reduces type safety. Consider using unknown for better type safety, or if possible, a more specific error type.

-          } catch (e: any) {
+          } catch (e: unknown) {
             const msg = e.message;

If using unknown, you'll need to add a type guard:

} catch (e: unknown) {
  const msg = e instanceof Error ? e.message : String(e);
  throw new BadContext("Error while querying context: " + msg);
}
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 87b70e5 and 7d2be27.

⛔ Files ignored due to path filters (2)
  • Cargo.lock is excluded by !**/*.lock
  • deno.lock is excluded by !**/*.lock
📒 Files selected for processing (51)
  • .ghjk/lock.json (13 hunks)
  • .github/workflows/publish-website.yml (1 hunks)
  • .github/workflows/release.yml (4 hunks)
  • .github/workflows/tests.yml (5 hunks)
  • Cargo.toml (3 hunks)
  • deno.jsonc (1 hunks)
  • ghjk.ts (0 hunks)
  • import_map.json (1 hunks)
  • rust-toolchain.toml (1 hunks)
  • src/meta-cli/src/cli/typegate.rs (1 hunks)
  • src/metagen-client-rs/src/graphql.rs (2 hunks)
  • src/mt_deno/src/lib.rs (6 hunks)
  • src/substantial/src/backends/redis.rs (1 hunks)
  • src/typegate/engine/bindings.ts (21 hunks)
  • src/typegate/engine/src/ext.rs (1 hunks)
  • src/typegate/engine/src/lib.rs (3 hunks)
  • src/typegate/src/engine/planner/args.ts (1 hunks)
  • src/typegate/src/engine/planner/policies.ts (1 hunks)
  • src/typegate/src/libs/jsonpath.ts (1 hunks)
  • src/typegate/src/runtimes/deno/deno.ts (1 hunks)
  • src/typegate/src/runtimes/deno/deno_messenger.ts (0 hunks)
  • src/typegate/src/runtimes/deno/hooks/mod.ts (2 hunks)
  • src/typegate/src/runtimes/prisma/hooks/run_migrations.ts (1 hunks)
  • src/typegate/src/runtimes/python/hooks/mod.ts (1 hunks)
  • src/typegate/src/runtimes/typegate.ts (1 hunks)
  • src/typegate/src/services/artifact_service.ts (2 hunks)
  • src/typegate/src/services/auth/mod.ts (1 hunks)
  • src/typegate/src/services/auth/protocols/internal.ts (1 hunks)
  • src/typegate/src/services/auth/protocols/jwt.ts (1 hunks)
  • src/typegate/src/services/auth/protocols/oauth2.ts (1 hunks)
  • src/typegate/src/services/graphql_service.ts (2 hunks)
  • src/typegate/src/services/rest_service.ts (3 hunks)
  • src/typegate/src/typegate/mod.ts (1 hunks)
  • src/typegate/standalone/src/main.rs (1 hunks)
  • src/typegraph/deno/src/types.ts (0 hunks)
  • src/xtask/src/deno.rs (1 hunks)
  • tests/e2e/cli/deploy_test.ts (2 hunks)
  • tests/e2e/typegraph/validator_test.ts (1 hunks)
  • tests/planner/planner_test.ts (0 hunks)
  • tests/schema_validation/type_comparison_test.ts (1 hunks)
  • tests/utils/assert.ts (1 hunks)
  • tests/utils/s3.ts (2 hunks)
  • tests/utils/test.ts (1 hunks)
  • tools/Dockerfile (2 hunks)
  • tools/consts.ts (1 hunks)
  • tools/deps.ts (1 hunks)
  • tools/jsr/jsr-gen.ts (1 hunks)
  • tools/list-duplicates.ts (3 hunks)
  • tools/tasks/lint.ts (1 hunks)
  • tools/tree-view.ts (2 hunks)
  • tools/update.ts (2 hunks)
💤 Files with no reviewable changes (4)
  • src/typegraph/deno/src/types.ts
  • src/typegate/src/runtimes/deno/deno_messenger.ts
  • ghjk.ts
  • tests/planner/planner_test.ts
✅ Files skipped from review due to trivial changes (4)
  • src/substantial/src/backends/redis.rs
  • rust-toolchain.toml
  • import_map.json
  • tools/update.ts
🧰 Additional context used
🪛 actionlint (1.7.4)
.github/workflows/tests.yml

93-9393: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)


145-145145: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)


175-175175: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)


176-176176: shellcheck reported issue in this script: SC2088:warning:1:7: Tilde does not expand in quotes. Use $HOME

(shellcheck)


176-176176: shellcheck reported issue in this script: SC2086:info:1:24: Double quote to prevent globbing and word splitting

(shellcheck)


177-177177: shellcheck reported issue in this script: SC2086:info:1:47: Double quote to prevent globbing and word splitting

(shellcheck)


288-288288: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)


289-289289: shellcheck reported issue in this script: SC2088:warning:1:7: Tilde does not expand in quotes. Use $HOME

(shellcheck)


289-289289: shellcheck reported issue in this script: SC2086:info:1:24: Double quote to prevent globbing and word splitting

(shellcheck)


290-290290: shellcheck reported issue in this script: SC2086:info:1:47: Double quote to prevent globbing and word splitting

(shellcheck)

.github/workflows/publish-website.yml

34-3434: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)

.github/workflows/release.yml

39-3939: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)


106-106106: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)


187-187187: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)


326-326326: shellcheck reported issue in this script: SC2086:info:1:52: Double quote to prevent globbing and word splitting

(shellcheck)

🪛 yamllint (1.35.1)
.github/workflows/tests.yml

[error] 173-173173: trailing spaces

(trailing-spaces)


[error] 284-284284: trailing spaces

(trailing-spaces)

.github/workflows/publish-website.yml

[error] 32-3232: trailing spaces

(trailing-spaces)

.github/workflows/release.yml

[error] 37-3737: trailing spaces

(trailing-spaces)


[error] 185-185185: trailing spaces

(trailing-spaces)


[error] 324-324324: trailing spaces

(trailing-spaces)

🔇 Additional comments (44)
src/mt_deno/src/lib.rs (10)

44-44: Confirm usage of PermissionFlags [approved, verify]

Switching from PermissionsOptions to args::PermissionFlags aligns with the updated permission model. Check references throughout the codebase to ensure all calls are consistent and no unforeseen breakages occur.


67-67: **Consistent update to PermissionFlags **

The parameter type change here maintains consistency with the rest of the permission handling across the file.


80-80: **Correct pass-through of updated permissions **

Passing the permissions object to args::Flags is coherent with the refactored permission system. No issues noted.


235-235: **Validate condition for empty test modules **

The newly added permit_no_files check ensures that tests with no specifiers are disallowed unless explicitly permitted. Verify that this logic matches intended behavior and doesn’t block legit scenarios where tests may be optional.


238-238: **doc_tests integration **

Acquiring doc tests from file fetcher can streamline test coverage. No immediate issues spotted; looks good for ensuring doc-based tests are included.


239-239: **Consolidating target specifiers **

Grouping specifiers for both type checking and test execution is a clear approach, centralizing these references for downstream operations.


240-240: **Iterating over doc tests **

This loop is straightforward; doc tests are processed individually. No concerns with the iteration approach.


241-241: **Inserting doc tests into memory **

Using file_fetcher.insert_memory_files(doc_test) is clever. Verify that memory insertion is tested with various doc test scenarios to avoid potential caching issues.


261-267: **Isolated Permissions for tests **

Ensuring each test obtains a fresh Permissions object prevents unintended carry-over of granted or revoked permissions between tests. This design choice appears robust.


268-268: **Running test specifiers **

Invoking test_specifiers after preparing isolated permissions is logical. Properly orchestrates final test steps.

tests/utils/assert.ts (1)

23-23: **Catching error as any **

This improves TypeScript clarity in the retry loop. It’s appropriate for a broad catch-all in test code, though stricter definitions can further enhance maintainability.

tests/e2e/typegraph/validator_test.ts (1)

30-30: **Catching error as any **

In test cases, capturing any type of error is a practical approach for robust error debugging. Current usage is fine.

tools/tasks/lint.ts (1)

50-50: **Additional deno lint command **

Executing deno lint after deno check ensures thorough static analysis. This is a beneficial improvement, reinforcing code quality checks on each run.

deno.jsonc (1)

41-41: Verify compatibility of "nodeModulesDir": "none".

Ensure that Deno 2.1.2 fully supports "none" here, as opposed to a boolean setting. Confirm there's no side effect on the project’s workflows, particularly around dependency resolution.

tools/jsr/jsr-gen.ts (1)

5-5: Removal of unused import looks good.

The existsSync import appears unused, so removing it is a welcome cleanup step.

src/typegate/standalone/src/main.rs (1)

44-49: Ensure robust error handling and environment validation.

Calling init_v8_flags is beneficial for properly initializing the V8 environment, but make sure that errors or invalid flags from get_v8_flags_from_env are properly handled or at least logged. Currently, any malformed flags could potentially cause unexpected runtime behavior or crashes.

src/typegate/src/runtimes/deno/hooks/mod.ts (1)

67-67: Good practice specifying the error type.

Marking the error as any clarifies its expected type, improving readability and helping the compiler. You may consider narrowing the error type (e.g., unknown) to avoid propagating too broad a type. That said, this is acceptable given the dynamic nature of error handling here.

src/typegate/src/runtimes/python/hooks/mod.ts (1)

57-57: Appropriate explicit typing for error.

By defining the error parameter as any, you acknowledge that Python code validation might yield unstructured exceptions. Consider using a more specific type if possible to expedite debugging, though any may be necessary when dealing with multiple error shapes.

tools/tree-view.ts (3)

18-21: Imports updated to reflect correct types.

Switching from TypeGraphDS to Typegraph and adding Injection clarifies the intended structures and improves code correctness.


25-31: Refined function signature and usage of typed injection.

Updating the treeView function’s parameter type to Typegraph and enforcing the Injection type ensures greater consistency and expressiveness in the codebase.


72-72: Maintain clarity in typed arrays.

Using Typegraph[] instead of TypeGraphDS[] to match the updated data model avoids confusion and ensures correctness when iterating over or mapping this array.

src/meta-cli/src/cli/typegate.rs (1)

71-76: Good addition of V8 flags initialization.
Invoking init_v8_flags ensures that Deno's V8 engine respects environment-specific flags. This appears consistent with the rest of the changes updating Deno functionality in this PR.

tools/deps.ts (1)

55-55: URL update looks fine.
Switching to the raw.githubusercontent.com URL for deno-udd is consistent with the project standards for direct raw content links.

tools/list-duplicates.ts (1)

15-15: Imports reorganized to include red.
It's good practice to maintain consistent import ordering for better readability. This addition clarifies usage of red for highlighting duplicate names.

tools/consts.ts (1)

8-9: Great job on version synchronization!

The Rust and Deno version constants have been updated to align with the PR objectives. This keeps the project’s versions consistent with the rest of the codebase.

src/typegate/src/services/graphql_service.ts (1)

55-59: Nice catch on consistent error naming!

Renaming the caught error from e to err clarifies the error semantics. Good practice for easier debugging and maintainability.

src/typegate/src/services/auth/mod.ts (1)

75-85: Ensure undefined handling for auth.

Switching from null to undefined requires careful handling of missing auth protocols. Check if downstream usage expects null instead.

src/xtask/src/deno.rs (2)

48-52: Initialize V8 flags early to avoid runtime conflicts.

Calling init_v8_flags with environment flags is a solid step for stable performance. Confirm that these flags don't unexpectedly impact production builds or tests.


87-99: Harden import restrictions thoughtfully.

Restricting imports by default is safer. Just ensure that required packages or domains aren’t accidentally blocked.

src/typegate/src/services/artifact_service.ts (1)

109-113: Uniform error handling looks good.

The explicit check against BaseError and fallback to UnknownError is clear and maintains consistent error reporting for various error types.

src/typegate/engine/src/lib.rs (1)

223-243: Ensure consistent test coverage for new permission flags.

The changed permission flags in the test function now mirror the production code. Verify that tests are covering scenarios where reading, writing, and importing resources are involved, to ensure all permission flags work as intended.

src/typegate/src/services/auth/protocols/oauth2.ts (1)

167-167: Confirm usage of TypeScript override modifier
Using override clarifies that this authMiddleware method is intentionally overriding a base class method, which helps detect accidental method name mismatches. This is a good practice for maintainability and clarity.

src/typegate/src/runtimes/deno/deno.ts (1)

82-82: Consider robust error handling for secret retrieval
Currently, calling secretManager.secretOrFail(secretName) will throw if the secret doesn't exist. To prevent partial initialization, consider wrapping this in a try block or logging additional context about which secret triggered the error.

src/typegate/src/typegate/mod.ts (2)

202-203: Improved clarity for caught errors
Renaming the error variable to err and typing it as any makes it clear that the error could be of various types. This also aligns with consistent naming across the codebase.


206-211: Validate error types to prevent nested error possibilities
If err.errors[0] or err.failure are missing or invalid, the code might throw a new runtime error. Consider additional checks or narrower type definitions to guard against unexpected error shapes.

src/typegate/src/runtimes/typegate.ts (1)

337-337: Correct handling of nullish coalescing
Good fix! Adding parentheses ensures that the nullish coalescing operator correctly applies to q.modelName before concatenation. The updated expression is now more precise and avoids potential undefined concatenations.

src/metagen-client-rs/src/graphql.rs (2)

372-374: Boxed response for request failures
This change adds flexibility to the response object. However, ensure the performance overhead of boxing is acceptable. In typical usage, it shouldn’t be a major concern.


421-421: Boxed GraphQLResponse
Storing GraphQLResponse in a Box can simplify the enum memory layout. Just confirm that any references to the original unboxed variant are updated accordingly.

tools/Dockerfile (2)

56-57: LGTM: Installation method change

The switch to using a shell script for GHJK installation is consistent with the changes in the workflow files.


2-3: Verify compatibility with updated versions

The version updates align with the PR objectives. However, let's verify compatibility:

✅ Verification successful

Let me gather more information to verify the compatibility.


Let me gather more specific information about Rust and Deno version requirements.


Version updates are compatible with the codebase

The version updates in the Dockerfile (Rust 1.82.0 and Deno 2.1.2) are consistent with the versions defined in tools/consts.ts and used throughout the codebase. These versions are:

  • Used in the Dockerfile for building the container
  • Referenced in the tooling configuration
  • Used in the installation scripts via tools/installs.ts

No incompatibilities or version conflicts were found in the codebase.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check for any compatibility issues with the new versions

# Check if Rust 1.82.0 is the minimum required version
rg -A 2 "rust-version\s*=\s*\"1\." 

# Check for any explicit Deno version requirements
rg -A 2 "deno\s+[0-9]" 

Length of output: 653


Script:

#!/bin/bash
# Check Cargo.toml files for rust-version specification and dependencies
fd Cargo.toml --exec cat {}

# Check for any Deno configuration files
fd deno.json --exec cat {}
fd deno.lock --exec cat {}

# Look for any Deno version constraints in TypeScript files
rg "Deno.version" 

Length of output: 92101


Script:

#!/bin/bash
# Check for Rust version requirements in build files and configs
rg "rust-version|RUST_VERSION" -A 2

# Check for Deno version requirements in build files and configs
rg "deno-version|DENO_VERSION" -A 2

# Check for any Deno version constraints in TypeScript files
rg "Deno\.version|deno\s+[0-9]" -A 2 "*.ts"

Length of output: 2349

Cargo.toml (2)

41-42: Minor version updates look good

The updates to clap, clap_complete, and url dependencies are minor version bumps and should maintain backward compatibility.

Also applies to: 54-54


136-137: Verify deno upgrade impact

The upgrade from Deno v1.46.3 to v2.1.2 and deno_core from 0.307.0 to 0.323.0 is significant. Let's verify the changes:

✅ Verification successful

Based on the shell script results, I can now provide the final response:

Deno upgrade impact is minimal and safe

The codebase's usage of Deno APIs is limited to stable functionality that hasn't changed significantly between v1.46.3 and v2.1.2:

  • Basic environment operations (Deno.env)
  • File system operations (Deno.mkdir, Deno.remove, etc.)
  • Network functionality (Deno.serve, Deno.Command)
  • Standard utilities (Deno.inspect)

The deno_core usage is primarily for op definitions which remain compatible across the versions, with no usage of deprecated or removed APIs.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check for potential breaking changes

# Check for Deno API usage that might be affected
rg -A 3 "Deno\." src/
rg -A 3 "deno_core::" src/

# Check for any custom deno types
ast-grep --pattern 'interface $name extends Deno.$rest { $$$  }'

Length of output: 31996

.github/workflows/tests.yml (1)

32-32: LGTM: Added debug logging

Adding GHJK_LOG="debug" will help with troubleshooting CI issues.

.ghjk/lock.json (1)

734-744: Version updates look good!

The updates align with the PR objectives:

  • Added Deno v2.1.2 configuration
  • Updated Rust to v1.82.0

Also applies to: 2259-2259

tools/list-duplicates.ts Outdated Show resolved Hide resolved
.github/workflows/tests.yml Outdated Show resolved Hide resolved
.github/workflows/release.yml Outdated Show resolved Hide resolved
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 3

🧹 Nitpick comments (12)
tests/metagen/typegraphs/sample/py/client.py (5)

812-812: Consider adding docstrings to clarify the purpose of this method.

The newly added Post() method appears straightforward, but adding a brief docstring explaining its role in defining the schema would enhance maintainability and readability for future contributors.


967-975: Clarity and consistency: add docstrings to reflect the User structure.

The User TypedDict has fields referencing specialized types (like UserIdStringUuid). Consider adding docstrings or short comments about each field's usage or constraints, especially as the project evolves.


1044-1052: Initialization suggestions.

The mapping {"UserIdStringUuid": "String!", "PostSlugString": "String!", ...} is a minimal type-to-GraphQL mapping. If more types are added in the future, consider organizing them in a dedicated configuration or constants file to avoid repetition.


1063-1065: Check for symmetrical patterns in get_posts.

This block mirrors get_user. If you foresee more custom logic in the future (like complex filters), consider factoring out the common code into a helper function.


1089-1095: Use consistent naming across no-args calls.

composite_no_args is fine. Should you have multiple similar no-argument functions, keep consistent naming to reduce confusion in usage.

.github/workflows/tests.yml (3)

32-32: Check potential verbosity from GHJK_LOG debug setting.

While setting GHJK_LOG to debug aids troubleshooting, consider toggling it off or lowering verbosity outside of debug scenarios to prevent log clutter.


173-173: Remove trailing whitespace.

A minor YAML lint issue: line 173 has trailing spaces. It’s best practice to remove them for a cleaner version history and to satisfy lint checks.

-      
+
🧰 Tools
🪛 yamllint (1.35.1)

[error] 173-173: trailing spaces

(trailing-spaces)


284-284: Remove trailing whitespace.

Line 284 contains trailing spaces. This can break certain lint or YAML validation rules.

-      
+
🧰 Tools
🪛 yamllint (1.35.1)

[error] 284-284: trailing spaces

(trailing-spaces)

.github/workflows/release.yml (4)

37-37: Remove trailing whitespace.

Line 37 has trailing spaces. Removing unnecessary whitespace promotes cleaner diffs.

-      
+
🧰 Tools
🪛 yamllint (1.35.1)

[error] 37-37: trailing spaces

(trailing-spaces)


106-110: Consistent approach to ghjk setup.

Repetitive block for installing ghjk. If you have many workflows, consider centralizing this logic in a reusable Action or script to reduce duplication.


185-185: Remove trailing whitespace.

Line 185 has trailing spaces. Clear them to maintain consistent formatting.

-      
+
🧰 Tools
🪛 yamllint (1.35.1)

[error] 185-185: trailing spaces

(trailing-spaces)


324-324: Remove trailing whitespace.

Line 324 has trailing spaces. Consider cleaning these up to stay consistent with linting rules.

-      
+
🧰 Tools
🪛 yamllint (1.35.1)

[error] 324-324: trailing spaces

(trailing-spaces)

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 7d2be27 and cd7db98.

⛔ Files ignored due to path filters (2)
  • Cargo.lock is excluded by !**/*.lock
  • deno.lock is excluded by !**/*.lock
📒 Files selected for processing (8)
  • .github/workflows/release.yml (4 hunks)
  • .github/workflows/tests.yml (5 hunks)
  • Cargo.toml (4 hunks)
  • src/metagen-client-rs/Cargo.toml (1 hunks)
  • tests/metagen/typegraphs/sample/py/client.py (3 hunks)
  • tests/runtimes/deno/ts/math.ts (1 hunks)
  • tools/Dockerfile.dockerignore (1 hunks)
  • tools/list-duplicates.ts (3 hunks)
🚧 Files skipped from review as they are similar to previous changes (2)
  • tools/list-duplicates.ts
  • Cargo.toml
🧰 Additional context used
🪛 actionlint (1.7.4)
.github/workflows/tests.yml

176-176: shellcheck reported issue in this script: SC2088:warning:1:7: Tilde does not expand in quotes. Use $HOME

(shellcheck)


176-176: shellcheck reported issue in this script: SC2086:info:1:24: Double quote to prevent globbing and word splitting

(shellcheck)


177-177: shellcheck reported issue in this script: SC2086:info:1:47: Double quote to prevent globbing and word splitting

(shellcheck)


289-289: shellcheck reported issue in this script: SC2088:warning:1:7: Tilde does not expand in quotes. Use $HOME

(shellcheck)


289-289: shellcheck reported issue in this script: SC2086:info:1:24: Double quote to prevent globbing and word splitting

(shellcheck)


290-290: shellcheck reported issue in this script: SC2086:info:1:47: Double quote to prevent globbing and word splitting

(shellcheck)

🪛 yamllint (1.35.1)
.github/workflows/tests.yml

[error] 173-173: trailing spaces

(trailing-spaces)


[error] 284-284: trailing spaces

(trailing-spaces)

.github/workflows/release.yml

[error] 37-37: trailing spaces

(trailing-spaces)


[error] 185-185: trailing spaces

(trailing-spaces)


[error] 324-324: trailing spaces

(trailing-spaces)

🔇 Additional comments (25)
src/metagen-client-rs/Cargo.toml (2)

6-10: LGTM! Well-documented optimization strategy

The comments clearly explain the Docker cache optimization strategy, and the library configuration follows Rust conventions.


Line range hint 13-24: Verify dependency compatibility with Rust 1.82.0

The dependencies appear to be using recent versions. Let's verify their compatibility with Rust 1.82.0.

✅ Verification successful

Let me gather more information to verify the compatibility.


Dependencies are compatible with Rust 1.82.0

Based on the verification results:

  • All dependencies are using stable versions that are compatible with Rust 1.82.0
  • reqwest 0.12.9, serde 1.0.210, and other dependencies are recent releases from their respective stable branches
  • No MSRV (Minimum Supported Rust Version) constraints were found that would conflict with Rust 1.82.0
  • Only one deprecated package was found in the dependency tree (0.9.34+deprecated), but it's a transitive dependency and doesn't affect compatibility

The dependency versions look good and should work well with Rust 1.82.0. No compatibility issues were found.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check if dependencies are compatible with Rust 1.82.0
# Expected: No compatibility issues reported

# Check for any known compatibility issues with these dependencies
gh api graphql -f query='
{
  securityVulnerabilities(first: 10, ecosystem: RUST, package: "serde") {
    nodes {
      advisory {
        summary
        severity
        affectedVersions
      }
    }
  }
}'

# List any deprecated features or compatibility warnings
rg -A 2 'deprecated|WARN' Cargo.lock || true

Length of output: 802


Script:

#!/bin/bash
# Check Cargo.toml for MSRV (Minimum Supported Rust Version) specifications
rg -A 2 'rust-version|MSRV' Cargo.toml

# Check dependencies' versions in Cargo.lock
rg -A 2 'name = "(serde|reqwest|mime_guess|futures|tokio-util|derive_more|lazy_static)"' Cargo.lock

# Look for any compatibility warnings in the repository
rg -i 'requires?.*(rust|version).*[0-9]+\.[0-9]+' . --type rust

Length of output: 1267

tests/runtimes/deno/ts/math.ts (2)

4-5: Consider clarifying license usage for external code reference.
You reference an external code link in the file comments. Ensure compatibility with MPL-2.0 and add relevant attribution if required by the external project's license.


7-7: Verify pinned version of Big.js.
You're specifying Big.js at version 6.2.2, which may be outdated. Confirm that this version suits your needs and is free of known vulnerabilities or consider upgrading to the latest stable version for security patches and new features.

✅ Verification successful

Big.js version 6.2.2 is the latest available version

The project is already using the latest stable version (6.2.2) of Big.js from npm registry, so no upgrade is necessary at this time.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check for the latest version of Big.js on npm:
curl -s "https://registry.npmjs.org/big.js" | jq '."dist-tags"'

Length of output: 87

tests/metagen/typegraphs/sample/py/client.py (14)

940-940: Good practice: align naming conventions with usage context.

Declaring UserIdStringUuid = str is a quick way to alias a str type. Ensure that this naming convention is consistent across the entire codebase and that each usage of UserIdStringUuid remains self-explanatory.


945-953: TypedDict definitions look consistent.

These new lines correctly define the Post TypedDict with appropriate fields and type aliases. Although optional, consider adding docstrings or comments indicating the meaning of each field for improved clarity.


955-961: Keep input schema well-documented.

RootCompositeArgsFnInput is defined accurately. To avoid confusion, consider adding a comment or docstring clarifying its usage in method calls within the codebase (e.g., in composite_args).


999-1008: Avoid potential confusion with naming.

PostSelections is a clear, descriptive name for a selection set. Overall, the typed definitions are consistent. If at any point the structure grows more complex, consider grouping these definitions in a dedicated module.


1010-1019: Good maintainability approach in UserSelections.

This definition cleanly separates user field selections from PostSelections. The code is well-structured and consistent with the rest of the typed selection blocks.


1021-1030: Successful union approach for RootCompositeUnionFnOutputSelections.

The typed dict structure is well-defined, capturing union members that can refer to either post or user sub-selections. This helps keep complex union logic cohesive.


1031-1039: Check for future expansion.

RootMixedUnionFnOutputSelections merges multiple union possibilities. This is fine for current usage. If more variants appear in the future, ensure naming remains intuitive (e.g., rename if more complex types are introduced).


1055-1057: Validation checks for getUser selection.

The usage of selection_to_nodes is correct, but remember to add unit tests to confirm that invalid or missing fields in select raise proper exceptions.


1071-1073: scalarNoArgs usage is correct.

No arguments are required, so this direct approach is fine. Be sure to cover it in tests verifying the query’s return value for typical and edge-cases.


1077-1085: Arg-based mutation logic.

scalar_args can be expanded to use more specific typed dictionaries if needed. Currently, it’s properly referencing Post for argument structure. Consider verifying the shape of args in a test suite.


1097-1109: Argument handling in composite_args is well structured.

The typed input RootCompositeArgsFnInput is used effectively. This keeps the system strongly typed. A thorough integration test would ensure that the typed dictionary and selection objects remain in sync.


1111-1119: Union logic checks.

scalar_union merges different types under a single query node. Remain vigilant about shape mismatches in arguments or selections. If necessary, add logic for safer runtime type checks.


1121-1133: Solid union pattern in composite_union.

This method properly handles union variants. If you plan to expand variants in the future, ensure compatibility with the selection transformations in NodeDescs.


1135-1147: No issues in mixed_union.

The code is consistent with the structure used in other union-based queries. Just ensure the project’s unit or integration tests validate the multiple union scenarios.

.github/workflows/tests.yml (4)

91-97: Shell steps to install ghjk appear correct.

Replacing the setup-ghjk action with direct commands is valid. Just ensure secure handling of environment variables and that the installed version is pinned or verified for reproducible builds.


140-149: Repeat patterns in shell commands.

These lines reuse the method of installing ghjk. Watch for any drift in version references. Confirm that all references to $GHJK_VERSION are consistent.


176-179: Shell path expansions need double quoting and $HOME usage.

ShellCheck warns about tilde expansions within quotes. Use $HOME in place of ~ and wrap variables in quotes to avoid word splitting or glob expansion.

-      - run: echo "~/.local/bin" >> $GITHUB_PATH
-      - run: echo "BASH_ENV=~/.local/share/ghjk/env.sh" >> $GITHUB_ENV
+      - run: echo "$HOME/.local/bin" >> "$GITHUB_PATH"
+      - run: echo "BASH_ENV=$HOME/.local/share/ghjk/env.sh" >> "$GITHUB_ENV"
🧰 Tools
🪛 actionlint (1.7.4)

176-176: shellcheck reported issue in this script: SC2088:warning:1:7: Tilde does not expand in quotes. Use $HOME

(shellcheck)


176-176: shellcheck reported issue in this script: SC2086:info:1:24: Double quote to prevent globbing and word splitting

(shellcheck)


177-177: shellcheck reported issue in this script: SC2086:info:1:47: Double quote to prevent globbing and word splitting

(shellcheck)


289-292: Duplicate shell script improvements.

As above, use $HOME/.local/bin and quote variables to avoid expansions. This ensures consistency and satisfies ShellCheck and actionlint warnings.

-      - run: echo "~/.local/bin" >> $GITHUB_PATH
-      - run: echo "BASH_ENV=~/.local/share/ghjk/env.sh" >> $GITHUB_ENV
+      - run: echo "$HOME/.local/bin" >> "$GITHUB_PATH"
+      - run: echo "BASH_ENV=$HOME/.local/share/ghjk/env.sh" >> "$GITHUB_ENV"
🧰 Tools
🪛 actionlint (1.7.4)

289-289: shellcheck reported issue in this script: SC2088:warning:1:7: Tilde does not expand in quotes. Use $HOME

(shellcheck)


289-289: shellcheck reported issue in this script: SC2086:info:1:24: Double quote to prevent globbing and word splitting

(shellcheck)


290-290: shellcheck reported issue in this script: SC2086:info:1:47: Double quote to prevent globbing and word splitting

(shellcheck)

.github/workflows/release.yml (3)

39-43: Installation steps match the rest of the workflows.

Mirrors the pattern of manually installing ghjk in place of the old action. Looks consistent. Confirm that the environment variables are handled in the same way as other workflows.


186-191: Proper shell steps, but watch quoting.

Like previous comparisons, ensure $HOME is used instead of ~ to avoid ShellCheck SC2088. Also confirm that you double quote all expansions.


326-330: Installation consistency for ghjk.

The pattern continues: cURL, add local bin to path, set BASH_ENV, and run ghjk envs cook. This is acceptable, but consider a centralized snippet if used across multiple workflows.

@@ -9,6 +9,7 @@
!src/metagen/Cargo.toml
!src/metagen/src/fdk_rust/static/Cargo.toml
!src/metagen/src/client_rs/static/Cargo.toml
!src/metagen-client-rs/Cargo.toml
Copy link
Contributor

@coderabbitai coderabbitai bot Jan 3, 2025

Choose a reason for hiding this comment

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

💡 Codebase verification

Potential missing Cargo.toml inclusions in Dockerfile.dockerignore

Several Cargo.toml files in the src/ directory are not included in the .dockerignore file:

  • src/common/Cargo.toml
  • src/mt_deno/Cargo.toml
  • src/substantial/Cargo.toml
  • src/typegate/engine/Cargo.toml
  • src/typegate/standalone/Cargo.toml
  • src/typegraph/core/Cargo.toml

Additionally, there's an entry for a non-existent file:

  • src/metagen/src/client_rs/static/Cargo.toml

While the addition of src/metagen-client-rs/Cargo.toml is correct, the inconsistency in including all Cargo.toml files might affect build context optimization.

🔗 Analysis chain

LGTM! Addition follows established patterns

The inclusion of src/metagen-client-rs/Cargo.toml aligns with the existing pattern of including specific Cargo.toml files for build context optimization.

Let's verify the consistency of Cargo.toml inclusions:

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify that all Cargo.toml files in src/ are properly included in .dockerignore
# Expected: All Cargo.toml files in src/ should have corresponding entries in .dockerignore

# Find all Cargo.toml files in src/
echo "Cargo.toml files in src/:"
fd Cargo.toml src/

# Check .dockerignore entries
echo -e "\nCorresponding .dockerignore entries:"
rg '!src/.+Cargo\.toml' tools/Dockerfile.dockerignore

Length of output: 732

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Most of those Cargo.toml files are included since their whole parent dirs are included. We only single out the toml file when we need to include it not to break the workspace but don't need the crate in the image.

Copy link
Contributor

Choose a reason for hiding this comment

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

@Yohe-Am, understood! Thank you for clarifying the rationale behind singling out or including Cargo.toml files in the Dockerfile.dockerignore. That makes sense given how you only need to include the file to maintain workspace integrity without bringing the entire crate into the image.


✏️ Learnings added
Learnt from: Yohe-Am
PR: metatypedev/metatype#923
File: tools/Dockerfile.dockerignore:12-12
Timestamp: 2025-01-05T23:21:16.767Z
Learning: We only single out the Cargo.toml file when we need to include it to avoid breaking the workspace, but we do not include the rest of that crate’s code if we don't need it in the Docker image.

Note: Learnings are effective only in the context of similar code segments. To apply general coding guidelines, please configure review instructions. You can manage existing learnings in the app.

Comment on lines +23 to +30
export function maxAsync({ numbers: values }: MinInput): Promise<number> {
let maxValue = new Big(values[0]);
for (const value of values) {
if ((new Big(value)).gt(maxValue)) {
maxValue = value;
}
}
return Promise.resolve(Number(maxValue));
Copy link
Contributor

Choose a reason for hiding this comment

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

⚠️ Potential issue

Resolve type confusion and add boundary checks in maxAsync.
This function also mixes Big instances with number types and lacks safety checks for an empty array. Fixing these issues prevents unexpected runtime errors and aligns the logic with min.

Proposed changes:

export function maxAsync({ numbers: values }: MinInput): Promise<number> {
+  if (values.length === 0) {
+    return Promise.reject("Cannot compute max of an empty array");
+  }
  let maxValue = new Big(values[0]);
  for (const value of values) {
-    if ((new Big(value)).gt(maxValue)) {
-      maxValue = value;
+    const bigVal = new Big(value);
+    if (bigVal.gt(maxValue)) {
+      maxValue = bigVal;
     }
  }
  return Promise.resolve(Number(maxValue));
}
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
export function maxAsync({ numbers: values }: MinInput): Promise<number> {
let maxValue = new Big(values[0]);
for (const value of values) {
if ((new Big(value)).gt(maxValue)) {
maxValue = value;
}
}
return Promise.resolve(Number(maxValue));
export function maxAsync({ numbers: values }: MinInput): Promise<number> {
if (values.length === 0) {
return Promise.reject("Cannot compute max of an empty array");
}
let maxValue = new Big(values[0]);
for (const value of values) {
const bigVal = new Big(value);
if (bigVal.gt(maxValue)) {
maxValue = bigVal;
}
}
return Promise.resolve(Number(maxValue));
}

Comment on lines +13 to +20
export function min({ numbers: values }: MinInput): number {
let minValue = new Big(values[0]);
for (const value of values) {
if ((new Big(value)).lt(minValue)) {
minValue = value;
}
}
return Number(minValue);
Copy link
Contributor

Choose a reason for hiding this comment

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

⚠️ Potential issue

Fix inconsistent usage of Big type and handle empty arrays.
Within the min function, you assign minValue to a Big instance initially, then switch to a plain number. Also, there's no guard for an empty array. These issues may result in type confusion and potential runtime errors.

Consider applying this refactor:

export function min({ numbers: values }: MinInput): number {
+  if (values.length === 0) {
+    throw new Error("Cannot compute min of an empty array");
+  }
  let minValue = new Big(values[0]);
  for (const value of values) {
-    if ((new Big(value)).lt(minValue)) {
-      minValue = value;
+    const bigVal = new Big(value);
+    if (bigVal.lt(minValue)) {
+      minValue = bigVal;
     }
  }
  return Number(minValue);
}
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
export function min({ numbers: values }: MinInput): number {
let minValue = new Big(values[0]);
for (const value of values) {
if ((new Big(value)).lt(minValue)) {
minValue = value;
}
}
return Number(minValue);
export function min({ numbers: values }: MinInput): number {
if (values.length === 0) {
throw new Error("Cannot compute min of an empty array");
}
let minValue = new Big(values[0]);
for (const value of values) {
const bigVal = new Big(value);
if (bigVal.lt(minValue)) {
minValue = bigVal;
}
}
return Number(minValue);
}

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 2

🔭 Outside diff range comments (1)
tools/list-duplicates.ts (1)

Line range hint 81-104: Remove commented-out code.

Instead of keeping the old file-based input code commented out, it should be removed. If needed, the code can be retrieved from version control history.

♻️ Duplicate comments (1)
.github/workflows/tests.yml (1)

289-291: ⚠️ Potential issue

Fix shell script security issues.

Same issues as found in the test-website job.

🧰 Tools
🪛 actionlint (1.7.4)

289-289: shellcheck reported issue in this script: SC2088:warning:1:7: Tilde does not expand in quotes. Use $HOME

(shellcheck)


289-289: shellcheck reported issue in this script: SC2086:info:1:24: Double quote to prevent globbing and word splitting

(shellcheck)


290-290: shellcheck reported issue in this script: SC2086:info:1:47: Double quote to prevent globbing and word splitting

(shellcheck)

🧹 Nitpick comments (3)
src/typegate/src/runtimes/s3.ts (1)

96-96: Prefer explicit S3 object type over any.

While using any might quickly silence type complaints, it undermines the benefits of static typing. If the AWS SDK provides a specific shape for res.Contents, please consider using that shape (for example, Object or ObjectList from aws-sdk/client-s3) to ensure you have correct types across the codebase.

-keys: (res.Contents ?? []).map((c: any) => ({
+keys: (res.Contents ?? []).map((c: Object) => ({
    key: c.Key,
    size: c.Size,
}))
tools/list-duplicates.ts (2)

22-23: Consider encapsulating counters in a result object.

Using global mutable state can make the code harder to test and debug. Consider refactoring to return these metrics as part of a result object from listDuplicates.

-let whereTypeCount = 0;
-let optionalTypeCount = 0;
+interface DuplicateAnalysis {
+  whereTypeCount: number;
+  optionalTypeCount: number;
+  duplicates: Map<string, readonly [number, TypeNode][]>;
+}
+
-export function listDuplicates(tg: TypeGraphDS, rootIdx = 0) {
+export function listDuplicates(tg: TypeGraphDS, rootIdx = 0): DuplicateAnalysis {
+  let whereTypeCount = 0;
+  let optionalTypeCount = 0;
   // ... existing code ...
+  return {
+    whereTypeCount,
+    optionalTypeCount,
+    duplicates: bins
+  };
}

50-51: Consider extracting duplicate injection handling logic.

The injection handling code is duplicated. Consider extracting it into a helper function for better maintainability.

+function formatInjection(type: TypeNode): string {
+  // deno-lint-ignore no-explicit-any
+  return "injection" in type ? ` (injection ${(type.injection as any).source})` : "";
+}

// Then use it in both places:
-const injection = "injection" in type
-  // deno-lint-ignore no-explicit-any
-  ? ` (injection ${(type.injection as any).source})`
-  : "";
+const injection = formatInjection(type);

Also applies to: 64-65

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between cd7db98 and b924886.

📒 Files selected for processing (5)
  • .github/workflows/release.yml (5 hunks)
  • .github/workflows/tests.yml (5 hunks)
  • src/meta-cli/src/macros.rs (1 hunks)
  • src/typegate/src/runtimes/s3.ts (1 hunks)
  • tools/list-duplicates.ts (4 hunks)
🧰 Additional context used
🪛 actionlint (1.7.4)
.github/workflows/tests.yml

176-176: shellcheck reported issue in this script: SC2088:warning:1:7: Tilde does not expand in quotes. Use $HOME

(shellcheck)


176-176: shellcheck reported issue in this script: SC2086:info:1:24: Double quote to prevent globbing and word splitting

(shellcheck)


177-177: shellcheck reported issue in this script: SC2086:info:1:47: Double quote to prevent globbing and word splitting

(shellcheck)


289-289: shellcheck reported issue in this script: SC2088:warning:1:7: Tilde does not expand in quotes. Use $HOME

(shellcheck)


289-289: shellcheck reported issue in this script: SC2086:info:1:24: Double quote to prevent globbing and word splitting

(shellcheck)


290-290: shellcheck reported issue in this script: SC2086:info:1:47: Double quote to prevent globbing and word splitting

(shellcheck)

🪛 yamllint (1.35.1)
.github/workflows/tests.yml

[error] 173-173: trailing spaces

(trailing-spaces)


[error] 284-284: trailing spaces

(trailing-spaces)

.github/workflows/release.yml

[error] 37-37: trailing spaces

(trailing-spaces)


[error] 185-185: trailing spaces

(trailing-spaces)


[error] 324-324: trailing spaces

(trailing-spaces)

⏰ Context from checks skipped due to timeout of 90000ms (7)
  • GitHub Check: bulid-docker (linux/arm64, custom-arm)
  • GitHub Check: test-website
  • GitHub Check: test-full
  • GitHub Check: lint-compat (macos-14, aarch64-apple-darwin, false)
  • GitHub Check: bulid-docker (linux/amd64, custom-ubuntu-large)
  • GitHub Check: lint-compat (macos-13, x86_64-apple-darwin, false)
  • GitHub Check: pre-commit
🔇 Additional comments (6)
src/meta-cli/src/macros.rs (1)

13-17: Confirm the 'static trait object usage for concurrency and error chaining.

This update properly boxes the error as a trait object that is both Send and Sync, which is beneficial when errors need to be passed across threads. However, confirm that forcing 'static is necessary and doesn’t accidentally cut off useful error context or references. If this accommodation is intended for concurrency or error propagation, then the change is sound. Otherwise, consider whether 'static is strictly required.

tools/list-duplicates.ts (2)

8-8: LGTM! Usage documentation updated correctly.

The usage comment and import organization accurately reflect the changes in input handling method.

Also applies to: 15-15


30-42: LGTM! Type processing logic is sound.

The implementation correctly:

  • Handles type structure hashing
  • Tracks duplicate names consistently
  • Counts specific type patterns
.github/workflows/tests.yml (2)

176-178: ⚠️ Potential issue

Fix shell script security issues.

The commands need proper quoting and should use $HOME instead of tilde.

Apply this fix:

-      - run: echo "~/.local/bin" >> $GITHUB_PATH
-      - run: echo "BASH_ENV=~/.local/share/ghjk/env.sh" >> $GITHUB_ENV
+      - run: echo "$HOME/.local/bin" >> "$GITHUB_PATH"
+      - run: echo "BASH_ENV=$HOME/.local/share/ghjk/env.sh" >> "$GITHUB_ENV"

Likely invalid or redundant comment.

🧰 Tools
🪛 actionlint (1.7.4)

176-176: shellcheck reported issue in this script: SC2088:warning:1:7: Tilde does not expand in quotes. Use $HOME

(shellcheck)


176-176: shellcheck reported issue in this script: SC2086:info:1:24: Double quote to prevent globbing and word splitting

(shellcheck)


177-177: shellcheck reported issue in this script: SC2086:info:1:47: Double quote to prevent globbing and word splitting

(shellcheck)


Line range hint 61-61: Verify version tagging strategy change.

The prerelease condition now checks for 'rc' instead of previous version tags.

Let's check the existing tags to ensure this change aligns with the project's versioning strategy:

✅ Verification successful

I don't see any prerelease condition checking for 'rc' or 'alpha' in the provided workflow file. Let me check other workflow files that might contain version tagging logic.


I found the relevant prerelease condition in the release.yml workflow file. The condition is used in the check-bump job to determine if a release should be marked as prerelease:

prerelease: ${{ contains(steps.latest-tag.outputs.tag, 'dev') || contains(steps.latest-tag.outputs.tag, 'rc') }}

Let me check if there are any other files that might be affected by this version tagging strategy.


Let me try a different search approach without file type restrictions.


Let me check the actual content of these files to see if they're related to version tagging.


Based on the analysis of the workflow files and codebase, I can now provide a final response:

Version tagging strategy change is aligned with the project's conventions

The change from 'alpha' to 'rc' in the prerelease condition is consistent with the project's versioning strategy. The release workflow (.github/workflows/release.yml) already handles both 'rc' and 'dev' tags as prereleases:

prerelease: ${{ contains(steps.latest-tag.outputs.tag, 'dev') || contains(steps.latest-tag.outputs.tag, 'rc') }}

This change appears to be an intentional shift from alpha to release candidate (rc) versioning, which is a common progression in semantic versioning.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check existing version tags
git tag -l "v*" | grep -E 'alpha|rc|dev'

Length of output: 42


Script:

#!/bin/bash
# Let's check the workflow file to understand the version tagging logic
cat .github/workflows/tests.yml

Length of output: 12203


Script:

#!/bin/bash
# Let's check all workflow files for version tagging logic
fd -e yml -e yaml . .github/workflows/ --exec cat {}

Length of output: 31379


Script:

#!/bin/bash
# Search for files containing version tag related patterns
rg -l "alpha|rc|dev" --type yaml --type rust --type typescript

Length of output: 99


Script:

#!/bin/bash
# Search for files containing version tag related patterns
rg -l "alpha|rc|dev" --type yaml

Length of output: 670


Script:

#!/bin/bash
# Check content of relevant workflow and configuration files
echo "=== .gitlab-ci.yml ==="
cat .gitlab-ci.yml
echo -e "\n=== whiz.yaml ==="
cat whiz.yaml

Length of output: 1862

.github/workflows/release.yml (1)

37-43: LGTM! Consistent and secure installation commands.

All instances of the ghjk installation commands are properly implemented with correct quoting and environment variable usage.

Also applies to: 106-110, 185-191, 324-330

🧰 Tools
🪛 yamllint (1.35.1)

[error] 37-37: trailing spaces

(trailing-spaces)

Comment on lines +112 to +118
const tgs: TypeGraphDS[] = JSON.parse(raw);

for (const tg of tgs) {
listDuplicates(tg, rootIdx);
}

console.log({ whereTypeCount, optionalTypeCount });
Copy link
Contributor

Choose a reason for hiding this comment

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

🛠️ Refactor suggestion

Add error handling for JSON parsing and improve counter logging.

Two improvements needed:

  1. Add error handling for JSON parsing
  2. The global counters don't properly handle multiple TypeGraphs as they accumulate across all graphs
-const tgs: TypeGraphDS[] = JSON.parse(raw);
+let tgs: TypeGraphDS[];
+try {
+  tgs = JSON.parse(raw);
+} catch (e) {
+  console.error("Failed to parse input JSON:", e.message);
+  Deno.exit(1);
+}

+let totalWhereTypeCount = 0;
+let totalOptionalTypeCount = 0;

 for (const tg of tgs) {
-  listDuplicates(tg, rootIdx);
+  const result = listDuplicates(tg, rootIdx);
+  totalWhereTypeCount += result.whereTypeCount;
+  totalOptionalTypeCount += result.optionalTypeCount;
 }

-console.log({ whereTypeCount, optionalTypeCount });
+console.log({
+  totalWhereTypeCount,
+  totalOptionalTypeCount,
+  processedGraphs: tgs.length
+});

Committable suggestion skipped: line range outside the PR's diff.

Comment on lines +91 to +96

# - uses: metatypedev/setup-ghjk@318209a9d215f70716a4ac89dbeb9653a2deb8bc
- run: curl -fsSL "https://raw.github.com/metatypedev/ghjk/$GHJK_VERSION/install.sh" | bash
- run: echo "$HOME/.local/bin" >> "$GITHUB_PATH"
- run: echo "BASH_ENV=$HOME/.local/share/ghjk/env.sh" >> "$GITHUB_ENV"
- run: ghjk envs cook
Copy link
Contributor

Choose a reason for hiding this comment

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

💡 Codebase verification

Installation script URL needs to be updated to use raw.githubusercontent.com

The installation commands are secure, but there's an issue with the URL domain that needs to be fixed:

  • The current URL uses raw.github.com which should be raw.githubusercontent.com
  • The script exists at the correct version (v0.2.1) and contains expected shell script content
  • The GHJK_VERSION environment variable is properly defined in the workflow

Please update the curl command to use the correct domain:

- run: curl -fsSL "https://raw.githubusercontent.com/metatypedev/ghjk/$GHJK_VERSION/install.sh" | bash
🔗 Analysis chain

LGTM! Installation commands look secure.

The installation commands are properly quoted and use environment variables correctly.

Let's verify the installation script's availability and integrity:


The previous attempt failed because:

  1. The GHJK_VERSION variable was empty, resulting in an invalid URL
  2. The domain was incorrect (should be raw.githubusercontent.com)

Let's verify these aspects first.


The previous findings show:

  1. GHJK_VERSION is defined as "v0.2.1" in the workflows
  2. The raw GitHub URL is accessible
  3. We need to use raw.githubusercontent.com instead of raw.github.com

Let's verify the script contents with the correct URL and version.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Verify the installation script's availability and contents
curl -sSL "https://raw.github.com/metatypedev/ghjk/$GHJK_VERSION/install.sh" | grep -E '^[^#].*bash|sh'

Length of output: 90


Script:

#!/bin/bash
# Let's first check if GHJK_VERSION is defined in the workflow file
grep -r "GHJK_VERSION" .github/workflows/

# Also check the raw URL format and domain
curl -I "https://raw.githubusercontent.com/metatypedev/ghjk/main/install.sh"

Length of output: 2632


Script:

#!/bin/bash
# Let's verify the installation script with the correct URL and version
curl -sSL "https://raw.githubusercontent.com/metatypedev/ghjk/v0.2.1/install.sh" | grep -E '^[^#].*bash|sh'

# Also check if GHJK_VERSION is defined in the workflow under review
cat .github/workflows/tests.yml | grep -A 5 "env:"

Length of output: 956

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.

2 participants