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: Format appsmithctl code #37532

Merged
merged 2 commits into from
Nov 19, 2024
Merged

chore: Format appsmithctl code #37532

merged 2 commits into from
Nov 19, 2024

Conversation

sharat87
Copy link
Member

@sharat87 sharat87 commented Nov 18, 2024

Formatting just before merging appsmithctl code into RTS.

Automation

/test sanity

🔍 Cypress test results

Tip

🟢 🟢 🟢 All cypress tests have passed! 🎉 🎉 🎉
Workflow run: https://github.com/appsmithorg/appsmith/actions/runs/11890257914
Commit: 5c83801
Cypress dashboard.
Tags: @tag.Sanity
Spec:


Mon, 18 Nov 2024 10:46:20 UTC

Communication

Should the DevRel and Marketing teams inform users about this change?

  • Yes
  • No

Summary by CodeRabbit

Release Notes

  • New Features

    • Added constants for backup and restore paths, database dump file names, and email notifications related to backup errors.
    • Introduced a new function for running restore operations.
  • Bug Fixes

    • Enhanced error handling and logging for backup and restore processes.
  • Documentation

    • Improved clarity in console log messages across various utilities.
  • Refactor

    • Standardized string formatting and code structure for better readability and maintainability across multiple files, including consistent use of double quotes and improved error handling formatting.
  • Tests

    • Expanded test coverage for backup utilities and improved formatting for better readability in test cases.

Copy link
Contributor

coderabbitai bot commented Nov 18, 2024

Walkthrough

The changes in this pull request primarily focus on formatting and consistency improvements across various JavaScript files related to backup and database operations. Key modifications include standardizing string quotation marks from single quotes to double quotes, enhancing readability through consistent indentation and line breaks, and adding semicolons where necessary. Additionally, several files have undergone minor structural adjustments to maintain clarity without altering the core functionality or control flow.

Changes

File Path Change Summary
deploy/docker/fs/opt/appsmith/utils/bin/backup.js Standardized string quotes to double quotes; no functional changes.
deploy/docker/fs/opt/appsmith/utils/bin/backup.test.js Formatting adjustments; added test cases for database name retrieval; improved readability.
deploy/docker/fs/opt/appsmith/utils/bin/check_replica_set.js Reformatted import statements and error handling for clarity; no functional changes.
deploy/docker/fs/opt/appsmith/utils/bin/constants.js Added semicolons; restructured export statement; added multiple constants.
deploy/docker/fs/opt/appsmith/utils/bin/export_db.js Changed single quotes to double quotes; modified escape sequences for console output.
deploy/docker/fs/opt/appsmith/utils/bin/import_db.js Standardized string quotes; added semicolons; improved formatting; no functional changes.
deploy/docker/fs/opt/appsmith/utils/bin/logger.js Changed string quotes to double quotes; no functional changes.
deploy/docker/fs/opt/appsmith/utils/bin/mailer.js Reformatted error handling and string quotes; no functional changes.
deploy/docker/fs/opt/appsmith/utils/bin/mongo_shell_utils.js Changed string quotes to double quotes; reformatted return statement for readability.
deploy/docker/fs/opt/appsmith/utils/bin/move-to-postgres.mjs Added spaces for readability; no functional changes.
deploy/docker/fs/opt/appsmith/utils/bin/restore.js Standardized string quotes; improved console log formatting; no functional changes.
deploy/docker/fs/opt/appsmith/utils/bin/utils.js Updated string quotes; minor control flow adjustments; no functional changes.
deploy/docker/fs/opt/appsmith/utils/bin/utils.test.js Restructured arguments in test cases for readability; no functional changes.
deploy/docker/fs/opt/appsmith/utils/bin/version.js Reformatted import statement and error handling; no functional changes.

Possibly related PRs

Suggested labels

ok-to-test

Suggested reviewers

  • mohanarpit
  • pratapaprasanna
  • ApekshaBhosale
  • trishaanand

🎉 In the land of code, where functions play,
Formatting changes brighten the way.
Double quotes shine, semicolons align,
Readability reigns, making code divine!
With tests that now cover the paths we tread,
Our backup scripts flourish, no worries ahead! 🌟


🪧 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 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.

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.

@github-actions github-actions bot added the skip-changelog Adding this label to a PR prevents it from being listed in the changelog label Nov 18, 2024
@sharat87
Copy link
Member Author

@coderabbitai review

Copy link
Contributor

coderabbitai bot commented Nov 18, 2024

✅ Actions performed

Review triggered.

Note: CodeRabbit is an incremental review system and does not re-review already reviewed commits. This command is applicable only when automatic reviews are paused.

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: 1

🧹 Outside diff range and nitpick comments (10)
deploy/docker/fs/opt/appsmith/utils/bin/utils.js (3)

42-61: Add input validation for environment variables

While the logic is sound, consider adding validation for malformed environment variables:

 let dbUrl = "";
 try {
   let env_array = fs
     .readFileSync(Constants.ENV_PATH, "utf8")
     .toString()
     .split("\n");
   for (let i in env_array) {
     if (
       env_array[i].startsWith("APPSMITH_MONGODB_URI") ||
       env_array[i].startsWith("APPSMITH_DB_URL")
     ) {
-      dbUrl = env_array[i].toString().split("=")[1].trim();
+      const parts = env_array[i].toString().split("=");
+      if (parts.length === 2) {
+        dbUrl = parts[1].trim();
+      }
       break;
     }
   }
 } catch (err) {
   console.error("Error reading the environment file:", err);
 }

121-125: Use template literals for better readability

Consider using template literals for string concatenation:

-      const output = (
-        outChunks.join("").trim() +
-        "\n" +
-        errChunks.join("").trim()
-      ).trim();
+      const output = `${outChunks.join("").trim()}\n${errChunks.join("").trim()}`.trim();

168-171: Add error handling for JSON parsing

Consider adding try-catch for JSON parsing:

 async function getCurrentAppsmithVersion() {
+  try {
     return (
       JSON.parse(await fsPromises.readFile("/opt/appsmith/info.json", "utf8"))
         .version ?? ""
     );
+  } catch (error) {
+    console.error("Error reading version info:", error);
+    return "";
+  }
 }
deploy/docker/fs/opt/appsmith/utils/bin/move-to-postgres.mjs (1)

50-58: Consider making the temporary directory path configurable.

The hardcoded path /tmp/db-tmp might not be suitable for all environments. Consider making this configurable through an environment variable.

+const TMP_DB_PATH = process.env.MONGO_TMP_PATH || "/tmp/db-tmp";
-  fs.mkdirSync("/tmp/db-tmp", { recursive: true });
+  fs.mkdirSync(TMP_DB_PATH, { recursive: true });

   mongoServer = spawn(
     "mongod",
-    ["--bind_ip_all", "--dbpath", "/tmp/db-tmp", "--port", "27500"],
+    ["--bind_ip_all", "--dbpath", TMP_DB_PATH, "--port", "27500"],

Also applies to: 63-68

deploy/docker/fs/opt/appsmith/utils/bin/backup.test.js (6)

21-21: Fix typo in test description

The test description contains a typo: "Checkx" should be "Checks".

-  it("Checkx the constant is 2 GB", () => {
+  it("Checks the constant is 2 GB", () => {

31-31: Fix duplicate word in test description

The test description contains a duplicate word: "hould".

-  it("Should not hould throw Error when the available size is >= MIN_REQUIRED_DISK_SPACE_IN_BYTES", () => {
+  it("Should not throw Error when the available size is >= MIN_REQUIRED_DISK_SPACE_IN_BYTES", () => {

41-41: Complete the truncated test description

The test description is incomplete: "Generates t".

-  it("Generates t", async () => {
+  it("Generates temporary backup directory path", async () => {

64-64: Remove debug console.log statements

Remove unnecessary console.log statements from test cases. These should not be part of the final test code.

Also applies to: 86-86, 133-133, 144-144, 155-155, 166-166, 177-177, 187-187, 197-197, 250-250


255-284: Group MongoDB URI parsing tests in a describe block

Consider grouping these related tests under a describe block for better organization.

+describe("MongoDB URI parsing", () => {
   test("Get DB name from Mongo URI 1", async () => {
     // ... existing test code
   });
   
   // ... other MongoDB URI tests
+});

8-284: Consider improving test descriptions for clarity

While the test coverage is comprehensive, consider making test descriptions more descriptive of what they're actually testing. For example:

  • "Backup Archive Limit when env APPSMITH_BACKUP_ARCHIVE_LIMIT is null" could be "Should return default limit (4) when APPSMITH_BACKUP_ARCHIVE_LIMIT is not set"
  • "Test backup encryption function" could be "Should correctly encrypt backup archive with provided password"

This makes it easier to understand test failures and maintain the test suite.

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between c70adf7 and f743a48.

📒 Files selected for processing (14)
  • deploy/docker/fs/opt/appsmith/utils/bin/backup.js (5 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/backup.test.js (1 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/check_replica_set.js (2 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/constants.js (1 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/export_db.js (2 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/import_db.js (3 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/logger.js (3 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/mailer.js (2 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/mongo_shell_utils.js (2 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/move-to-postgres.mjs (6 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/restore.js (3 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/utils.js (7 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/utils.test.js (2 hunks)
  • deploy/docker/fs/opt/appsmith/utils/bin/version.js (2 hunks)
✅ Files skipped from review due to trivial changes (9)
  • deploy/docker/fs/opt/appsmith/utils/bin/backup.js
  • deploy/docker/fs/opt/appsmith/utils/bin/check_replica_set.js
  • deploy/docker/fs/opt/appsmith/utils/bin/constants.js
  • deploy/docker/fs/opt/appsmith/utils/bin/export_db.js
  • deploy/docker/fs/opt/appsmith/utils/bin/logger.js
  • deploy/docker/fs/opt/appsmith/utils/bin/mailer.js
  • deploy/docker/fs/opt/appsmith/utils/bin/mongo_shell_utils.js
  • deploy/docker/fs/opt/appsmith/utils/bin/utils.test.js
  • deploy/docker/fs/opt/appsmith/utils/bin/version.js
🧰 Additional context used
📓 Learnings (1)
deploy/docker/fs/opt/appsmith/utils/bin/move-to-postgres.mjs (2)
Learnt from: abhvsn
PR: appsmithorg/appsmith#36556
File: deploy/docker/fs/opt/appsmith/utils/bin/move-to-postgres.mjs:159-164
Timestamp: 2024-11-12T08:11:36.416Z
Learning: When transforming the `_class` field in `move-to-postgres.mjs`, if `mapClassToType` returns `null`, retain the original `_class` value in the `type` field to preserve important MongoDB information.
Learnt from: abhvsn
PR: appsmithorg/appsmith#36556
File: deploy/docker/fs/opt/appsmith/utils/bin/move-to-postgres.mjs:159-164
Timestamp: 2024-11-12T08:11:43.278Z
Learning: When transforming the `_class` field in `move-to-postgres.mjs`, if `mapClassToType` returns `null`, retain the original `_class` value in the `type` field to preserve important MongoDB information.
🪛 Biome
deploy/docker/fs/opt/appsmith/utils/bin/import_db.js

[error] 60-60: Change to an optional chain.

Unsafe fix: Change to an optional chain.

(lint/complexity/useOptionalChain)

deploy/docker/fs/opt/appsmith/utils/bin/move-to-postgres.mjs

[error] 197-197: Avoid the delete operator which can impact performance.

Unsafe fix: Use an undefined assignment instead.

(lint/performance/noDelete)

deploy/docker/fs/opt/appsmith/utils/bin/restore.js

[error] 150-150: Change to an optional chain.

Unsafe fix: Change to an optional chain.

(lint/complexity/useOptionalChain)


[error] 42-42: isNaN is unsafe. It attempts a type coercion. Use Number.isNaN instead.

See the MDN documentation for more details.
Unsafe fix: Use Number.isNaN instead.

(lint/suspicious/noGlobalIsNan)

🔇 Additional comments (6)
deploy/docker/fs/opt/appsmith/utils/bin/utils.js (2)

4-4: Good use of the node: prefix for fs module

Using the node: prefix is a security best practice that prevents dependency confusion attacks.


180-200: Well-structured MongoDB connection handling

Good implementation of MongoDB connection string preprocessing with proper handling of different scenarios and optimizations for localhost connections.

deploy/docker/fs/opt/appsmith/utils/bin/move-to-postgres.mjs (4)

9-10: LGTM: Import statements and warning message formatting.

The changes maintain code consistency while preserving the original functionality.

Also applies to: 34-36


169-176: LGTM: Object key sorting implementation.

The replacer function maintains a consistent order of keys, which is crucial for reproducible migrations.


195-197: Retain delete operator for data transformation.

While static analysis flags the delete operator for performance concerns, its use here is appropriate for data transformation. The alternative of setting undefined would leave remnants in the JSON output.

Note: This aligns with the previous learning about preserving MongoDB information through proper type field handling.

🧰 Tools
🪛 Biome

[error] 197-197: Avoid the delete operator which can impact performance.

Unsafe fix: Use an undefined assignment instead.

(lint/performance/noDelete)


93-107: Verify migration version check implementation.

The migration version check is a critical safeguard. Let's verify its implementation across the codebase.

Also applies to: 119-127

deploy/docker/fs/opt/appsmith/utils/bin/backup.test.js Outdated Show resolved Hide resolved
@sharat87
Copy link
Member Author

@CodeRabbit review

Copy link
Contributor

coderabbitai bot commented Nov 18, 2024

✅ Actions performed

Review triggered.

Note: CodeRabbit is an incremental review system and does not re-review already reviewed commits. This command is applicable only when automatic reviews are paused.

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: 0

🧹 Outside diff range and nitpick comments (5)
deploy/docker/fs/opt/appsmith/utils/bin/backup.test.js (5)

21-24: Fix typo in test description

Change "Checkx" to "Checks" in the test description.

-  it("Checkx the constant is 2 GB", () => {
+  it("Checks the constant is 2 GB", () => {

31-39: Fix typo in test description

Remove the duplicate "hould" in the test description.

-  it("Should not hould throw Error when the available size is >= MIN_REQUIRED_DISK_SPACE_IN_BYTES", () => {
+  it("Should not throw Error when the available size is >= MIN_REQUIRED_DISK_SPACE_IN_BYTES", () => {

41-46: Complete the test description

The test description is incomplete. It should describe what is being generated.

-  it("Generates t", async () => {
+  it("Generates temporary backup directory path", async () => {

245-274: Refactor MongoDB URI tests using test.each

Consider refactoring these similar test cases using Jest's test.each for better maintainability.

+const mongoUriTestCases = [
+  {
+    uri: "mongodb+srv://admin:password@test.cluster.mongodb.net/my_db_name?retryWrites=true&minPoolSize=1&maxPoolSize=10&maxIdleTimeMS=900000&authSource=admin",
+    expected: "my_db_name"
+  },
+  {
+    uri: "mongodb+srv://admin:password@test.cluster.mongodb.net/test123?retryWrites=true&minPoolSize=1&maxPoolSize=10&maxIdleTimeMS=900000&authSource=admin",
+    expected: "test123"
+  },
+  {
+    uri: "mongodb+srv://admin:password@test.cluster.mongodb.net/test123",
+    expected: "test123"
+  },
+  {
+    uri: "mongodb://appsmith:pAssW0rd!@localhost:27017/appsmith",
+    expected: "appsmith"
+  }
+];
+
+test.each(mongoUriTestCases)("Get DB name from Mongo URI: $expected", ({ uri, expected }) => {
+  const dbName = utils.getDatabaseNameFromMongoURI(uri);
+  expect(dbName).toEqual(expected);
+});

10-10: Remove unnecessary console.log statements

Test cases should not contain debug console.log statements unless they serve a specific purpose. Consider removing them to keep the test output clean.

Also applies to: 64-64, 86-86, 133-133, 144-144, 155-155, 166-166, 177-177, 187-187, 240-240

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between f743a48 and 5c83801.

📒 Files selected for processing (1)
  • deploy/docker/fs/opt/appsmith/utils/bin/backup.test.js (1 hunks)

@sharat87 sharat87 added the ok-to-test Required label for CI label Nov 18, 2024
@sharat87 sharat87 marked this pull request as ready for review November 18, 2024 10:53
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
ok-to-test Required label for CI skip-changelog Adding this label to a PR prevents it from being listed in the changelog
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants