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: removed redundant page DB calls from js action creation flow #37668

Merged

Conversation

sneha122
Copy link
Contributor

@sneha122 sneha122 commented Nov 25, 2024

Description

During action creation flow, page is fetched twice (making two independent DB calls) and taking significant time, this PR makes only 1 page DB call and passes the page object to subsequent calls, instead of fetching page again.

Fixes #37567
or
Fixes Issue URL

Warning

If no issue exists, please create an issue first, and check with the maintainers if the issue is valid.

Automation

/ok-to-test tags="@tag.JS, @tag.Datasource"

🔍 Cypress test results

Tip

🟢 🟢 🟢 All cypress tests have passed! 🎉 🎉 🎉
Workflow run: https://github.com/appsmithorg/appsmith/actions/runs/12084468852
Commit: 2cd1a84
Cypress dashboard.
Tags: @tag.JS, @tag.Datasource
Spec:


Fri, 29 Nov 2024 13:05:45 UTC

Communication

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

  • Yes
  • No

Summary by CodeRabbit

  • New Features

    • Enhanced action creation process with the introduction of a new metadata parameter for improved functionality.
    • Optimized cloning of applications and pages by reducing redundant database calls.
  • Bug Fixes

    • Ensured proper handling of the executeOnLoad property during action creation in cloning contexts.
  • Tests

    • Updated tests to reflect changes in action creation logic and verify new behaviors, including performance optimizations.

Copy link
Contributor

coderabbitai bot commented Nov 25, 2024

Walkthrough

The changes in this pull request primarily involve modifications to the createAction method across several classes in the application. An additional parameter, CreateActionMetaDTO, has been introduced to the method signature, enhancing the functionality during action creation. This parameter encapsulates metadata related to the action, potentially optimizing the process by reducing database calls and improving efficiency. The overall control flow and error handling within the affected methods remain consistent with previous implementations.

Changes

File Change Summary
app/server/appsmith-server/src/main/java/com/appsmith/server/fork/internal/ApplicationForkingServiceCEImpl.java Updated forkApplications method to include an additional parameter in layoutActionService.createAction.
app/server/appsmith-server/src/main/java/com/appsmith/server/newactions/clonepage/ActionClonePageServiceCEImpl.java Modified cloneEntities method to add a new parameter in the createAction call.
app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCE.java Updated createAction method signature to include a new parameter, CreateActionMetaDTO actionMetaDTO.
app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java Multiple updates to createAction and validateAndGenerateActionDomainBasedOnContext methods to incorporate the new CreateActionMetaDTO parameter.
app/server/appsmith-server/src/test/java/com/appsmith/server/services/ce/ActionServiceCE_Test.java Updated test method to reflect changes in createAction method signature and verify new behavior.

Assessment against linked issues

Objective Addressed Explanation
Optimize page fetch time during JS object action creation (#37567)

Possibly related PRs

Suggested labels

Bug, JS Objects, Javascript Product

Suggested reviewers

  • nidhi-nair
  • sondermanish
  • rishabhrathod01

🎉 In the land of code where actions play,
A new parameter joins the fray!
With createAction now more spry,
Cloning pages, oh my, oh my!
Efficiency blooms, like flowers in May,
Cheers to the changes, hip-hip-hooray! 🎈


📜 Recent review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 71f0d8e and 2cd1a84.

📒 Files selected for processing (1)
  • app/server/appsmith-server/src/test/java/com/appsmith/server/services/ActionCollectionServiceTest.java (2 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
  • app/server/appsmith-server/src/test/java/com/appsmith/server/services/ActionCollectionServiceTest.java

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 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 Integrations Pod General Issues related to the Integrations Pod that don't fit into other tags. Integrations Product Issues related to a specific integration Query & JS Pod Issues related to the query & JS Pod Task A simple Todo labels Nov 25, 2024
@sneha122 sneha122 added the ok-to-test Required label for CI label Nov 25, 2024
@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 25, 2024
@sneha122
Copy link
Contributor Author

/build-deploy-preview skip-tests=true

Copy link

Deploying Your Preview: https://github.com/appsmithorg/appsmith/actions/runs/12003842608.
Workflow: On demand build Docker image and deploy preview.
skip-tests: true.
env: ``.
PR: 37668.
recreate: .

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 (1)
app/server/appsmith-server/src/test/java/com/appsmith/server/services/ce/ActionServiceCE_Test.java (1)

1183-1183: LGTM! Consider documenting the new parameter.

The addition of the null parameter aligns with the PR objective to optimize page fetch time. However, the purpose of this parameter could be clearer.

Consider adding a comment explaining the purpose of the null parameter in the context of page fetch optimization.

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between a320605 and 9297770.

📒 Files selected for processing (5)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/fork/internal/ApplicationForkingServiceCEImpl.java (1 hunks)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/newactions/clonepage/ActionClonePageServiceCEImpl.java (1 hunks)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCE.java (2 hunks)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java (3 hunks)
  • app/server/appsmith-server/src/test/java/com/appsmith/server/services/ce/ActionServiceCE_Test.java (1 hunks)
🔇 Additional comments (9)
app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java (5)

341-342: Correct permission assignment based on action type.


345-350: Efficient reuse of newPage to eliminate redundant database calls.


354-356: Overloaded createAction method enhances performance by accepting newPage.


360-363: Optimizing method calls by passing newPage.


Line range hint 420-438: Streamlined page retrieval in validateAndGenerateActionDomainBasedOnContext.

app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCE.java (2)

5-5: LGTM!

Clean import addition following the existing import organization pattern.


27-28: Verify implementation of the new parameter across all service implementations

The interface change aligns with the optimization goal of reducing redundant page fetches. However, ensure that implementing classes are making effective use of the newPage parameter rather than passing null, which would defeat the optimization purpose.

✅ Verification successful

The previous pattern didn't work well with ast-grep, so I'm using ripgrep with more specific patterns to:

  1. Find actual implementations of the createAction method with the new parameter
  2. Find classes that implement or extend LayoutActionService
    This will help us verify how the new parameter is being used across implementations.

Now let's examine the actual implementation to see how the newPage parameter is being used in both the CE implementation and the main implementation.


Let's try a simpler pattern to see the method implementations and how they use the newPage parameter.


Implementation correctly utilizes the newPage parameter

The implementation in LayoutActionServiceCEImpl properly uses the newPage parameter in the validateAndGenerateActionDomainBasedOnContext call, and there's no evidence of null being passed. The parameter flows through the service hierarchy as intended, supporting the optimization goal.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for implementations passing null for the newPage parameter
ast-grep --pattern 'createAction($_, $_, $_, null)'

# Find all implementations of this interface
ast-grep --pattern 'class $_ implements $$$LayoutActionServiceCE'

Length of output: 121


Script:

#!/bin/bash
# Search for implementations of createAction method
rg -U "createAction\(.*?\bActionDTO\b.*?\bAppsmithEventContext\b.*?\bBoolean\b.*?\bNewPage\b.*?\)" -g "*.java" -A 5

# Find all classes that implement or extend LayoutActionService
rg "class\s+\w+(?:CE|Impl)?\s+(?:implements|extends)\s+.*?LayoutActionService.*?" -g "*.java"

Length of output: 594


Script:

#!/bin/bash
# Look for the implementation of createAction in LayoutActionServiceCEImpl
rg -U "public\s+Mono<ActionDTO>\s+createAction\([^)]+\)\s*\{[\s\S]+?(?=\n\s*\})" app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java

# Also check if LayoutActionServiceImpl overrides the method
rg -U "public\s+Mono<ActionDTO>\s+createAction\([^)]+\)\s*\{[\s\S]+?(?=\n\s*\})" app/server/appsmith-server/src/main/java/com/appsmith/server/services/LayoutActionServiceImpl.java

Length of output: 1042


Script:

#!/bin/bash
# Look for the implementation of createAction in LayoutActionServiceCEImpl
rg "createAction.*\(" -A 20 app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java

# Check if LayoutActionServiceImpl has any createAction implementation
rg "createAction.*\(" -A 20 app/server/appsmith-server/src/main/java/com/appsmith/server/services/LayoutActionServiceImpl.java

Length of output: 3040

app/server/appsmith-server/src/main/java/com/appsmith/server/fork/internal/ApplicationForkingServiceCEImpl.java (2)

Line range hint 1-624: Implementation follows reactive patterns effectively.

The forking implementation properly handles async operations, maintains transaction consistency, and has good error handling. The new parameter addition is well-integrated into the existing reactive chain.


317-318: 🛠️ Refactor suggestion

Verify the null parameter usage in createAction.

The new parameter is currently set to null, which aligns with the backward compatibility pattern but may not achieve the intended optimization of reducing redundant page DB calls.

Consider passing the already fetched page object instead of null to avoid redundant DB calls, as per the PR objective.

✅ Verification successful

Let me gather more information about the createAction method implementation.


Let me try a different search pattern to find the method definition.


Let me check the interface definition to understand the expected parameter type.


The null parameter for NewPage is correct in this context

The createAction method in LayoutActionServiceCE accepts NewPage as its fourth parameter, which is optional (can be null) based on the implementation pattern seen across the codebase. In the application forking flow, passing null is appropriate since we're not creating the action in the context of a new page.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check for other createAction calls that might need updating
ast-grep --pattern 'layoutActionService.createAction($_, $_, $_, $_)'

# Check the implementation of createAction
ast-grep --pattern 'createAction(ActionDTO $_, AppsmithEventContext $_, Boolean $_, $_)'

Length of output: 2107


Script:

#!/bin/bash
# Search for the createAction method definition in the LayoutActionService
ast-grep --pattern 'createAction(ActionDTO $_, AppsmithEventContext $_, Boolean $_, Page $_)'

# Search for any references to this method in interfaces or parent classes
rg "createAction.*Page\s+page\)" -A 5

Length of output: 135


Script:

#!/bin/bash
# Search for createAction method in LayoutActionService with broader pattern
rg "createAction.*ActionDTO.*Boolean" -A 10

# Also check for the interface definition
fd -e java LayoutActionService

Length of output: 2340


Script:

#!/bin/bash
# Check the interface definition for createAction
cat app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCE.java

# Also check NewPage usage
rg "class NewPage" -A 5

Length of output: 8380

@@ -54,7 +54,7 @@ public Mono<Void> cloneEntities(ClonePageMetaDTO clonePageMetaDTO) {
// Indicates that source of action creation is clone page action
cloneActionDTO.setSource(ActionCreationSourceTypeEnum.CLONE_PAGE);
copyNestedNonNullProperties(actionDTO, cloneActionDTO);
return layoutActionService.createAction(cloneActionDTO, eventContext, isJsAction);
return layoutActionService.createAction(cloneActionDTO, eventContext, isJsAction, null);
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

🛠️ Refactor suggestion

Pass clonePageMetaDTO.getClonedPageDTO() instead of null

The ClonePageMetaDTO contains the cloned page via getClonedPageDTO() and we can see it's already being used in the same method to set the page ID. Pass this page object to optimize the DB calls as intended.

-return layoutActionService.createAction(cloneActionDTO, eventContext, isJsAction, null);
+return layoutActionService.createAction(cloneActionDTO, eventContext, isJsAction, clonePageMetaDTO.getClonedPageDTO());
🔗 Analysis chain

Consider passing the actual page object instead of null

While the infrastructure change to accept the page parameter is in place, passing null here doesn't achieve the optimization goal of reducing redundant page fetches. The page object should be available from clonePageMetaDTO.getClonedPageDTO().

Let's verify if we can access the page object:

Consider this approach if the page object is available:

-return layoutActionService.createAction(cloneActionDTO, eventContext, isJsAction, null);
+return layoutActionService.createAction(cloneActionDTO, eventContext, isJsAction, clonePageMetaDTO.getClonedPageDTO());
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if ClonedPageDTO contains the complete page object
ast-grep --pattern 'class ClonePageMetaDTO {
  $$$
  getClonedPageDTO() {
    $$$
  }
  $$$
}'

Length of output: 96


Script:

#!/bin/bash
# Let's try a different approach to find the ClonePageMetaDTO class
rg -l "ClonePageMetaDTO" 

# Then check the ActionClonePageServiceCEImpl class to understand the context
rg -A 5 "createAction.*cloneActionDTO.*eventContext.*isJsAction" 

Length of output: 1553


Script:

#!/bin/bash
# Let's check the ClonePageMetaDTO class definition
rg -A 10 "class ClonePageMetaDTO" app/server/appsmith-server/src/main/java/com/appsmith/server/dtos/ClonePageMetaDTO.java

# And check how clonePageMetaDTO is used in the ActionClonePageServiceCEImpl
rg -B 5 -A 5 "clonePageMetaDTO" app/server/appsmith-server/src/main/java/com/appsmith/server/newactions/clonepage/ActionClonePageServiceCEImpl.java

Length of output: 1715

Copy link

Deploy-Preview-URL: https://ce-37668.dp.appsmith.com

Copy link
Contributor

@NilanshBansal NilanshBansal left a comment

Choose a reason for hiding this comment

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

@sneha122 can we please add a unit test to assert the removal of redundant page DB calls. Other changes look good to me.

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 (6)
app/server/appsmith-server/src/main/java/com/appsmith/server/dtos/CreateActionMetaDTO.java (2)

15-17: Add Javadoc for fields and consider nullable annotations.

Consider adding:

  1. Field documentation to improve maintainability
  2. @Nullable or @NotNull annotations to make null-safety explicit
 public class CreateActionMetaDTO {
+    /** Indicates if this is a JavaScript action */
+    @Nullable
     Boolean isJsAction;
+    /** Context of the Appsmith event triggering this action creation */
+    @Nullable
     AppsmithEventContext eventContext;
+    /** Associated page information */
+    @Nullable
     NewPage newPage;
 }

1-18: Consider reordering fields for better readability.

The field order could be improved by placing the most important/frequently used fields first. Consider moving newPage before eventContext since it's central to the optimization goal of reducing page fetches.

 public class CreateActionMetaDTO {
     Boolean isJsAction;
-    AppsmithEventContext eventContext;
     NewPage newPage;
+    AppsmithEventContext eventContext;
 }
app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java (2)

38-39: Remove unused import

The javax.swing.* import is not used in this server-side implementation and should be removed.

-import javax.swing.*;

438-446: Consider enhancing error handling in the pageMono chain

While the optimization is good, consider extracting the error handling into a separate method for better reusability and clarity.

-        Mono<NewPage> pageMono = newPage != null
-                ? Mono.just(newPage)
-                : newPageService
-                        .findById(action.getPageId(), aclPermission)
-                        .name(GET_PAGE_BY_ID)
-                        .tap(Micrometer.observation(observationRegistry))
-                        .switchIfEmpty(Mono.error(new AppsmithException(
-                                AppsmithError.NO_RESOURCE_FOUND, FieldName.PAGE, action.getPageId())))
-                        .cache();
+        Mono<NewPage> pageMono = newPage != null
+                ? Mono.just(newPage)
+                : fetchPageWithErrorHandling(action.getPageId(), aclPermission);
+
+    private Mono<NewPage> fetchPageWithErrorHandling(String pageId, AclPermission permission) {
+        return newPageService
+                .findById(pageId, permission)
+                .name(GET_PAGE_BY_ID)
+                .tap(Micrometer.observation(observationRegistry))
+                .switchIfEmpty(Mono.error(new AppsmithException(
+                        AppsmithError.NO_RESOURCE_FOUND, FieldName.PAGE, pageId)))
+                .cache();
+    }
app/server/appsmith-server/src/main/java/com/appsmith/server/fork/internal/ApplicationForkingServiceCEImpl.java (1)

313-322: Consider adding validation for CreateActionMetaDTO fields.

While the refactoring to use CreateActionMetaDTO is good for reducing redundant page fetches, consider adding null checks for the DTO fields to ensure robustness.

+    if (createActionMetaDTO.getEventContext() == null) {
+        createActionMetaDTO.setEventContext(
+            new AppsmithEventContext(AppsmithEventContextType.CLONE_PAGE)
+        );
+    }
     return layoutActionService.createAction(actionDTO, createActionMetaDTO);
app/server/appsmith-server/src/test/java/com/appsmith/server/services/ActionCollectionServiceTest.java (1)

930-977: LGTM: Well-structured test for page fetch optimization.

The test effectively verifies that the page is fetched only once during action creation, aligning with the PR's objective to optimize database calls. The test uses Mockito verification to ensure createAction is called exactly once with the correct parameters.

A minor suggestion to improve test readability:

-    public void testUpdateUnpublishedActionCollection_createSingleAction_fetchesPageFromDBOnlyOnce() {
+    public void testUpdateUnpublishedActionCollection_whenCreatingSingleAction_shouldFetchPageFromDBOnlyOnce() {
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 9297770 and 2f2d957.

📒 Files selected for processing (7)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/dtos/CreateActionMetaDTO.java (1 hunks)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/fork/internal/ApplicationForkingServiceCEImpl.java (2 hunks)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/newactions/clonepage/ActionClonePageServiceCEImpl.java (2 hunks)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCE.java (2 hunks)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java (5 hunks)
  • app/server/appsmith-server/src/test/java/com/appsmith/server/services/ActionCollectionServiceTest.java (2 hunks)
  • app/server/appsmith-server/src/test/java/com/appsmith/server/services/ce/ActionServiceCE_Test.java (2 hunks)
🚧 Files skipped from review as they are similar to previous changes (3)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/newactions/clonepage/ActionClonePageServiceCEImpl.java
  • app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCE.java
  • app/server/appsmith-server/src/test/java/com/appsmith/server/services/ce/ActionServiceCE_Test.java
🔇 Additional comments (5)
app/server/appsmith-server/src/main/java/com/appsmith/server/dtos/CreateActionMetaDTO.java (1)

10-18: LGTM! Well-structured DTO with appropriate Lombok annotations.

The class structure is clean and follows best practices with proper use of Lombok annotations for reducing boilerplate code.

app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java (2)

357-363: LGTM: Well-structured method refactoring

The new method signature effectively implements the optimization by allowing page object reuse through CreateActionMetaDTO.


Line range hint 367-424: LGTM: Clean implementation of optimized action creation

The refactored implementation maintains all existing functionality while reducing redundant page fetches through the new DTO structure.

app/server/appsmith-server/src/main/java/com/appsmith/server/fork/internal/ApplicationForkingServiceCEImpl.java (1)

26-26: LGTM!

Clean import addition for the new DTO class.

app/server/appsmith-server/src/test/java/com/appsmith/server/services/ActionCollectionServiceTest.java (1)

95-95: LGTM: Appropriate use of @SpyBean for verification.

The change from @Autowired to @SpyBean is correct as it allows verifying the interaction with layoutActionService in the new test.

Copy link

Failed server tests

  • com.external.plugins.MongoPluginRegexTest#
  • com.external.plugins.MongoPluginFormsTest#
  • com.external.plugins.MongoPluginStaleConnTest#
  • com.external.plugins.MongoPluginQueriesTest#
  • com.external.plugins.MongoPluginErrorsTest#
  • com.external.plugins.MongoPluginDatasourceTest#
  • com.external.plugins.MongoPluginDataTypeTest#
  • com.external.plugins.utils.MongoPluginUtilsTest#
  • com.external.plugins.utils.DatasourceUtilsTest#
  • com.external.plugins.MySqlPluginTest#
  • com.external.plugins.MySqlStaleConnectionErrorMessageTest#
  • com.external.plugins.MySQLDatasourceValidationTest#
  • com.external.plugins.MySQLPluginDataTypeTest#
  • com.external.utils.QueryUtilsTest#
  • com.external.plugins.ElasticSearchPluginTest#
  • com.external.plugins.DynamoPluginTest#
  • com.external.plugins.RedisPluginTest#
  • com.external.plugins.MssqlGetDBSchemaTest#
  • com.external.plugins.MssqlPluginTest#
  • com.external.plugins.FirestorePluginTest#
  • com.external.plugins.RedshiftPluginTest#
  • com.external.plugins.AmazonS3PluginTest#
  • com.external.utils.AmazonS3ErrorUtilsTest#
  • com.external.config.RowsBulkUpdateMethodTest#
  • com.external.config.MethodConfigTest#
  • com.external.config.RowsUpdateMethodTest#
  • com.external.config.RowsAppendMethodTest#
  • com.external.config.FileInfoMethodTest#
  • com.external.config.RowsBulkAppendMethodTest#
  • com.external.config.RowsGetMethodTest#
  • com.external.config.GetDatasourceMetadataMethodTest#
  • com.external.config.GetStructureMethodTest#
  • com.external.config.FileListMethodTest#
  • com.external.config.SheetsUtilTest#
  • com.external.plugins.GraphQLPluginTest#
  • com.external.plugins.SnowflakePluginTest#
  • com.external.plugins.SmtpPluginTest#
  • com.external.plugins.VisionCommandTest#
  • com.external.plugins.EmbeddingCommandTest#
  • com.external.plugins.ChatCommandTest#
  • com.external.plugins.OpenAIPluginTest#
  • com.external.plugins.AnthropicPluginTest#
  • com.external.plugins.GoogleAiPluginTest#
  • com.external.plugins.GenerateContentCommandTest#
  • com.external.plugins.services.FieldValidationHelperTest#
  • com.external.plugins.services.features.ImageClassificationServiceImplTest#
  • com.external.plugins.services.features.TextEntityExtractionServiceImplTest#
  • com.external.plugins.services.features.TextSummarizationServiceImplTest#
  • com.external.plugins.services.features.ImageCaptioningServiceImplTest#
  • com.external.plugins.services.features.TextGenerationServiceImplTest#
  • com.external.plugins.services.features.TextClassificationServiceImplTest#
  • com.external.plugins.services.features.ImageEntityExtractionServiceImplTest#
  • com.external.plugins.services.HeadersUtilTest#
  • com.external.plugins.services.AiFeatureServiceFactoryTest#
  • com.external.plugins.AwsLambdaPluginTest#
  • com.external.plugins.DatabricksPluginTest#
  • com.appsmith.git.converters.GsonDoubleToLongConverterTest#
  • com.appsmith.git.helpers.DSLTransformerHelperTest#
  • com.appsmith.git.helpers.FileUtilsImplTest#
  • GsonUnorderedToOrderedSerializationTest#
  • com.external.plugins.RestApiPluginTest#testHttpGetRequestRawBody

Copy link
Contributor

@NilanshBansal NilanshBansal left a comment

Choose a reason for hiding this comment

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

added comments

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 (1)
app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java (1)

434-440: Fix indentation in the else block

The indentation is inconsistent with the rest of the code.

-                : newPageService
-                        .findById(action.getPageId(), aclPermission)
-                        .name(GET_PAGE_BY_ID)
-                        .tap(Micrometer.observation(observationRegistry))
-                        .switchIfEmpty(Mono.error(new AppsmithException(
-                                AppsmithError.NO_RESOURCE_FOUND, FieldName.PAGE, action.getPageId())))
-                        .cache();
+                : newPageService
+                    .findById(action.getPageId(), aclPermission)
+                    .name(GET_PAGE_BY_ID)
+                    .tap(Micrometer.observation(observationRegistry))
+                    .switchIfEmpty(Mono.error(new AppsmithException(
+                        AppsmithError.NO_RESOURCE_FOUND, FieldName.PAGE, action.getPageId())))
+                    .cache();
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 2f2d957 and 71f0d8e.

📒 Files selected for processing (1)
  • app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java (4 hunks)
🔇 Additional comments (4)
app/server/appsmith-server/src/main/java/com/appsmith/server/services/ce/LayoutActionServiceCEImpl.java (4)

16-16: LGTM!

The import for CreateActionMetaDTO is correctly added.


351-356: Well-optimized page context handling!

The implementation efficiently reuses the fetched page object by passing it through CreateActionMetaDTO, eliminating redundant database calls.


361-363: LGTM!

Clean refactor of the method signature to use CreateActionMetaDTO while maintaining the existing functionality.


432-440: Excellent optimization of page fetching logic!

The conditional page fetching with caching effectively reduces database calls when the page object is already available.

Copy link
Contributor

@NilanshBansal NilanshBansal left a comment

Choose a reason for hiding this comment

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

LGTM

@sneha122 sneha122 merged commit 493abee into release Dec 3, 2024
42 checks passed
@sneha122 sneha122 deleted the fix/remove-js-action-creation-redundant-page-db-calls branch December 3, 2024 07:27
github-actions bot pushed a commit to Zeral-Zhang/appsmith that referenced this pull request Dec 9, 2024
…ppsmithorg#37668)

## Description
During action creation flow, page is fetched twice (making two
independent DB calls) and taking significant time, this PR makes only 1
page DB call and passes the page object to subsequent calls, instead of
fetching page again.


Fixes appsmithorg#37567 
_or_  
Fixes `Issue URL`
> [!WARNING]  
> _If no issue exists, please create an issue first, and check with the
maintainers if the issue is valid._

## Automation

/ok-to-test tags="@tag.JS, @tag.Datasource"

### 🔍 Cypress test results
<!-- This is an auto-generated comment: Cypress test results  -->
> [!TIP]
> 🟢 🟢 🟢 All cypress tests have passed! 🎉 🎉 🎉
> Workflow run:
<https://github.com/appsmithorg/appsmith/actions/runs/12084468852>
> Commit: 2cd1a84
> <a
href="https://internal.appsmith.com/app/cypress-dashboard/rundetails-65890b3c81d7400d08fa9ee5?branch=master&workflowId=12084468852&attempt=1"
target="_blank">Cypress dashboard</a>.
> Tags: `@tag.JS, @tag.Datasource`
> Spec:
> <hr>Fri, 29 Nov 2024 13:05:45 UTC
<!-- end of auto-generated comment: Cypress test results  -->


## Communication
Should the DevRel and Marketing teams inform users about this change?
- [ ] Yes
- [x] No


<!-- This is an auto-generated comment: release notes by coderabbit.ai
-->
## Summary by CodeRabbit

- **New Features**
- Enhanced action creation process with the introduction of a new
metadata parameter for improved functionality.
- Optimized cloning of applications and pages by reducing redundant
database calls.

- **Bug Fixes**
- Ensured proper handling of the `executeOnLoad` property during action
creation in cloning contexts.

- **Tests**
- Updated tests to reflect changes in action creation logic and verify
new behaviors, including performance optimizations.
<!-- end of auto-generated comment: release notes by coderabbit.ai -->

---------

Co-authored-by: “sneha122” <“[email protected]”>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Integrations Pod General Issues related to the Integrations Pod that don't fit into other tags. Integrations Product Issues related to a specific integration ok-to-test Required label for CI Query & JS Pod Issues related to the query & JS Pod skip-changelog Adding this label to a PR prevents it from being listed in the changelog Task A simple Todo
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Task]: Optimise page fetch time taking during Js object action creation
3 participants