PromucFlow_constructor/app/client/test/factories/Actions/API.ts

82 lines
1.8 KiB
TypeScript
Raw Normal View History

import * as Factory from "factory.ts";
import { PaginationType, type ApiAction } from "entities/Action";
import { PluginPackageName, PluginType } from "entities/Plugin";
import { PluginIDs } from "test/factories/MockPluginsState";
chore: Unify ID extraction regex from browser url (#33925) ## Description Regex update to make it compatible to extract identifiers for both Mongo ObjectIds and UUIDs. This will help us to keep the unified logic required in `pg` branch. ## Automation /ok-to-test tags="@tag.Datasource, @tag.GenerateCRUD, @tag.ImportExport, @tag.Fork, @tag.Workspace, @tag.Sanity" ### :mag: 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/9405554200> > Commit: 3959703aab1d10e28d3b80057793476467126929 > Cypress dashboard url: <a href="https://internal.appsmith.com/app/cypress-dashboard/rundetails-65890b3c81d7400d08fa9ee5?branch=master&workflowId=9405554200&attempt=2" target="_blank">Click here!</a> <!-- 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 URL path handling to support both UUID and Mongo ObjectIds. - **Refactor** - Replaced hardcoded page IDs with dynamic variables across multiple test files for improved maintainability and flexibility. - **Tests** - Updated test cases to use dynamic page IDs, ensuring consistency and easier updates in the future. <!-- end of auto-generated comment: release notes by coderabbit.ai -->
2024-06-11 09:44:54 +00:00
const pageId = "0123456789abcdef00000000";
export const APIFactory = Factory.Sync.makeFactory<ApiAction>({
name: Factory.each((i) => `Api${i + 1}`),
id: "api_id",
baseId: "api_base_id",
chore: Unify ID extraction regex from browser url (#33925) ## Description Regex update to make it compatible to extract identifiers for both Mongo ObjectIds and UUIDs. This will help us to keep the unified logic required in `pg` branch. ## Automation /ok-to-test tags="@tag.Datasource, @tag.GenerateCRUD, @tag.ImportExport, @tag.Fork, @tag.Workspace, @tag.Sanity" ### :mag: 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/9405554200> > Commit: 3959703aab1d10e28d3b80057793476467126929 > Cypress dashboard url: <a href="https://internal.appsmith.com/app/cypress-dashboard/rundetails-65890b3c81d7400d08fa9ee5?branch=master&workflowId=9405554200&attempt=2" target="_blank">Click here!</a> <!-- 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 URL path handling to support both UUID and Mongo ObjectIds. - **Refactor** - Replaced hardcoded page IDs with dynamic variables across multiple test files for improved maintainability and flexibility. - **Tests** - Updated test cases to use dynamic page IDs, ensuring consistency and easier updates in the future. <!-- end of auto-generated comment: release notes by coderabbit.ai -->
2024-06-11 09:44:54 +00:00
pageId: pageId,
pluginId: PluginIDs[PluginPackageName.REST_API],
pluginType: PluginType.API,
workspaceId: "workspaceId",
applicationId: "applicationId",
actionConfiguration: {
timeoutInMillisecond: 10000,
paginationType: PaginationType.NONE,
headers: [
{
key: "",
value: "",
},
{
key: "",
value: "",
},
],
encodeParamsToggle: true,
queryParameters: [
{
key: "",
value: "",
},
{
key: "",
value: "",
},
],
body: "",
bodyFormData: [],
httpMethod: "GET",
httpVersion: "HTTP11",
pluginSpecifiedTemplates: [
{
value: true,
},
],
formData: {
apiContentType: "none",
},
},
cacheResponse: "",
datasource: {
userPermissions: [],
name: "DEFAULT_REST_DATASOURCE",
pluginId: PluginIDs[PluginPackageName.REST_API],
workspaceId: "workspaceId",
invalids: [],
messages: [],
isValid: true,
datasourceConfiguration: { url: "www.mock-api.appsmith.com" },
},
dynamicBindingPathList: [],
runBehaviour: "MANUAL",
invalids: [],
isValid: true,
jsonPathKeys: [],
messages: [],
userPermissions: [
"read:actions",
"delete:actions",
"execute:actions",
"manage:actions",
],
confirmBeforeExecute: false,
chore: Introduce action isDirty map (#39872) ## Description The server now adds a isDirty map in the action object to signify if any aspect of the action is not saved (is dirty) This is needed for the EE change https://github.com/appsmithorg/appsmith-ee/pull/6713 https://www.notion.so/appsmith/Implement-save-button-for-AI-Query-1b9fe271b0e2808285dcc797ad281141?pvs=4 ## Automation /ok-to-test tags="@tag.Datasource" ### :mag: 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/14029254723> > Commit: 4321d95d427a1dfd07aedecd3731390ed0a4688e > <a href="https://internal.appsmith.com/app/cypress-dashboard/rundetails-65890b3c81d7400d08fa9ee5?branch=master&workflowId=14029254723&attempt=1" target="_blank">Cypress dashboard</a>. > Tags: `@tag.Datasource` > Spec: > <hr>Mon, 24 Mar 2025 07:51:29 UTC <!-- end of auto-generated comment: Cypress test results --> ## Communication Should the DevRel and Marketing teams inform users about this change? - [ ] Yes - [ ] No <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit ## Summary by CodeRabbit - **New Features** - Added a capability that improves how the app retrieves a specific action from a collection based on unique identifiers, ensuring smoother interaction. - Enhanced state management in actions by introducing a new property to track the update status of schema generation, supporting more robust workflow handling. <!-- end of auto-generated comment: release notes by coderabbit.ai -->
2025-03-24 08:38:43 +00:00
isDirtyMap: {
SCHEMA_GENERATION: false,
},
});