PromucFlow_constructor/app/client/cypress/support/Pages/Templates.ts
Rahul Barwal 1bcae40616
chore: Add spec for create new app from template (#31311)
## Description
This pull request adds a cypress spec for create app from templates
option.


#### PR fixes following issue(s)
Fixes # (issue number)
> if no issue exists, please create an issue and ask the maintainers
about this first
>
>
#### Media
> A video or a GIF is preferred. when using Loom, don’t embed because it
looks like it’s a GIF. instead, just link to the video
>
>
#### Type of change
> Please delete options that are not relevant.
- Bug fix (non-breaking change which fixes an issue)
- New feature (non-breaking change which adds functionality)
- Breaking change (fix or feature that would cause existing
functionality to not work as expected)
- Chore (housekeeping or task changes that don't impact user perception)
- This change requires a documentation update
>
>
>
## Testing
>
#### How Has This Been Tested?
> Please describe the tests that you ran to verify your changes. Also
list any relevant details for your test configuration.
> Delete anything that is not relevant
- [ ] Manual
- [ ] JUnit
- [ ] Jest
- [ ] Cypress
>
>
#### Test Plan
> Add Testsmith test cases links that relate to this PR
>
>
#### Issues raised during DP testing
> Link issues raised during DP testing for better visiblity and tracking
(copy link from comments dropped on this PR)
>
>
>
## Checklist:
#### Dev activity
- [ ] My code follows the style guidelines of this project
- [ ] I have performed a self-review of my own code
- [ ] I have commented my code, particularly in hard-to-understand areas
- [ ] I have made corresponding changes to the documentation
- [ ] My changes generate no new warnings
- [ ] I have added tests that prove my fix is effective or that my
feature works
- [ ] New and existing unit tests pass locally with my changes
- [ ] PR is being merged under a feature flag


#### QA activity:
- [ ] [Speedbreak
features](https://github.com/appsmithorg/TestSmith/wiki/Guidelines-for-test-plans#speedbreakers-)
have been covered
- [ ] Test plan covers all impacted features and [areas of
interest](https://github.com/appsmithorg/TestSmith/wiki/Guidelines-for-test-plans#areas-of-interest-)
- [ ] Test plan has been peer reviewed by project stakeholders and other
QA members
- [ ] Manually tested functionality on DP
- [ ] We had an implementation alignment call with stakeholders post QA
Round 2
- [ ] Cypress test cases have been added and approved by SDET/manual QA
- [ ] Added `Test Plan Approved` label after Cypress tests were reviewed
- [ ] Added `Test Plan Approved` label after JUnit tests were reviewed


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

- **New Features**
- Enabled the creation of new applications directly from templates
without the need for feature flags.
- Enhanced user interface for selecting templates when creating new
applications.
- **Tests**
- Added client-side regression tests for creating applications from
templates.
- **Refactor**
- Streamlined the process for initiating the creation of an application
from a template in the UI.
<!-- end of auto-generated comment: release notes by coderabbit.ai -->
2024-02-28 14:42:35 +05:30

87 lines
2.9 KiB
TypeScript

import { ObjectsRegistry } from "../Objects/Registry";
// Edit mode modal
export class Templates {
private agHelper = ObjectsRegistry.AggregateHelper;
private homePage = ObjectsRegistry.HomePage;
public locators = {
_templatesTab: ".t--templates-tab",
_forkApp: ".t--fork-template",
_templateCard: "[data-testid='template-card']",
_templateViewForkButton: "[data-testid='template-fork-button']",
_buildingBlockCardOnCanvas: "[data-testid='t--canvas-building-block-item']",
_datasourceConnectPromptSubmitBtn:
"[data-testid='t--datasource-connect-prompt-submit-btn']",
_templatesSearchInput: "[data-testid='t--application-search-input']",
_resultsHeader: "[data-testid='t--application-templates-results-header']",
_templateViewGoBack: "[data-testid='t--template-view-goback']",
_templateDialogBox: "[data-testid=t--templates-dialog-component]",
_closeTemplateDialogBoxBtn: ".ads-v2-modal__content-header-close-button",
_requestForTemplateBtn: "span:contains('Request for a template')",
_tempaltesFilterItem: "[data-testid='t--templates-filter-item']",
_templateFilterItemSelectedIcon: `[data-testid="t--templates-filter-item-selected-icon"]`,
_templatesCardForkButton: "[data-testid='t--fork-template-button']",
};
FilterTemplatesByName(query: string) {
ObjectsRegistry.AggregateHelper.TypeText(
this.locators._templatesSearchInput,
query,
);
this.agHelper.Sleep();
}
GetTemplatesCardsList() {
return cy.get(this.locators._templateCard);
}
public SwitchToTemplatesTab() {
cy.url().then((url) => {
if (!url.endsWith("applications")) {
this.homePage.NavigateToHome();
}
this.agHelper.GetNClick(this.locators._templatesTab);
this.agHelper.AssertElementVisibility(
this.locators._requestForTemplateBtn,
true,
0,
60000,
); //giving more time here for templates page to fully load, since there is no intercept validation for same
});
}
RefreshTemplatesPage(
withDummyData: boolean,
templateFixture = "Templates/AllowPageImportTemplates.json",
) {
if (withDummyData) {
cy.fixture(templateFixture).then((templatesData) => {
cy.intercept(
{
method: "GET",
url: "/api/v1/app-templates",
},
{
statusCode: 200,
body: templatesData,
},
);
});
}
cy.intercept("GET", "/api/v1/app-templates/filters").as("fetchFilters");
this.agHelper.RefreshPage("fetchFilters");
this.agHelper.AssertElementVisibility(this.locators._templateCard);
}
FilterByFirst2Categories() {
return this.agHelper
.GetElement(this.locators._tempaltesFilterItem)
.then((categories) => {
const first2Categories = categories.slice(1, 3);
first2Categories.map((_, category) => {
cy.wrap(category).click();
});
});
}
}