2024-08-20 04:05:09 -07:00
|
|
|
import { overrideFeatureFlag } from '../../composables/featureFlags';
|
|
|
|
import { BasePage } from '../base';
|
|
|
|
|
|
|
|
const AI_ASSISTANT_FEATURE = {
|
|
|
|
name: 'aiAssistant',
|
|
|
|
experimentName: '021_ai_debug_helper',
|
|
|
|
enabledFor: 'variant',
|
|
|
|
disabledFor: 'control',
|
|
|
|
};
|
|
|
|
|
2025-01-08 00:36:44 -08:00
|
|
|
/**
|
|
|
|
* @deprecated Use functional composables from @composables instead.
|
|
|
|
* If a composable doesn't exist for your use case, please create a new one in:
|
|
|
|
* cypress/composables
|
|
|
|
*
|
|
|
|
* This class-based approach is being phased out in favor of more modular functional composables.
|
|
|
|
* Each getter and action in this class should be moved to individual composable functions.
|
|
|
|
*/
|
2024-08-20 04:05:09 -07:00
|
|
|
export class AIAssistant extends BasePage {
|
|
|
|
url = '/workflows/new';
|
|
|
|
|
|
|
|
getters = {
|
|
|
|
askAssistantFloatingButton: () => cy.getByTestId('ask-assistant-floating-button'),
|
|
|
|
askAssistantSidebar: () => cy.getByTestId('ask-assistant-sidebar'),
|
|
|
|
askAssistantSidebarResizer: () =>
|
|
|
|
this.getters.askAssistantSidebar().find('[class^=_resizer][data-dir=left]').first(),
|
|
|
|
askAssistantChat: () => cy.getByTestId('ask-assistant-chat'),
|
|
|
|
placeholderMessage: () => cy.getByTestId('placeholder-message'),
|
|
|
|
closeChatButton: () => cy.getByTestId('close-chat-button'),
|
|
|
|
chatInputWrapper: () => cy.getByTestId('chat-input-wrapper'),
|
|
|
|
chatInput: () => cy.getByTestId('chat-input'),
|
|
|
|
sendMessageButton: () => cy.getByTestId('send-message-button'),
|
|
|
|
chatMessagesAll: () => cy.get('[data-test-id^=chat-message]'),
|
|
|
|
chatMessagesAssistant: () => cy.getByTestId('chat-message-assistant'),
|
|
|
|
chatMessagesUser: () => cy.getByTestId('chat-message-user'),
|
|
|
|
chatMessagesSystem: () => cy.getByTestId('chat-message-system'),
|
2024-09-03 01:43:24 -07:00
|
|
|
quickReplies: () => cy.getByTestId('quick-replies'),
|
|
|
|
quickReplyButtons: () => this.getters.quickReplies().find('button'),
|
2024-08-20 04:05:09 -07:00
|
|
|
newAssistantSessionModal: () => cy.getByTestId('new-assistant-session-modal'),
|
|
|
|
codeDiffs: () => cy.getByTestId('code-diff-suggestion'),
|
|
|
|
applyCodeDiffButtons: () => cy.getByTestId('replace-code-button'),
|
|
|
|
undoReplaceCodeButtons: () => cy.getByTestId('undo-replace-button'),
|
|
|
|
codeReplacedMessage: () => cy.getByTestId('code-replaced-message'),
|
|
|
|
nodeErrorViewAssistantButton: () =>
|
|
|
|
cy.getByTestId('node-error-view-ask-assistant-button').find('button').first(),
|
2024-09-23 08:38:35 -07:00
|
|
|
credentialEditAssistantButton: () => cy.getByTestId('credential-edit-ask-assistant-button'),
|
2024-09-23 04:05:15 -07:00
|
|
|
codeSnippet: () => cy.getByTestId('assistant-code-snippet-content'),
|
2024-08-20 04:05:09 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
actions = {
|
2024-09-05 01:54:35 -07:00
|
|
|
enableAssistant: () => {
|
2024-08-20 04:05:09 -07:00
|
|
|
overrideFeatureFlag(AI_ASSISTANT_FEATURE.experimentName, AI_ASSISTANT_FEATURE.enabledFor);
|
|
|
|
cy.enableFeature(AI_ASSISTANT_FEATURE.name);
|
|
|
|
},
|
2024-09-05 01:54:35 -07:00
|
|
|
disableAssistant: () => {
|
2024-08-20 04:05:09 -07:00
|
|
|
overrideFeatureFlag(AI_ASSISTANT_FEATURE.experimentName, AI_ASSISTANT_FEATURE.disabledFor);
|
|
|
|
cy.disableFeature(AI_ASSISTANT_FEATURE.name);
|
|
|
|
},
|
2024-09-05 01:54:35 -07:00
|
|
|
sendMessage: (message: string) => {
|
|
|
|
this.getters.chatInput().type(message).type('{enter}');
|
|
|
|
},
|
|
|
|
closeChat: () => {
|
|
|
|
this.getters.closeChatButton().click();
|
|
|
|
this.getters.askAssistantChat().should('not.be.visible');
|
|
|
|
},
|
|
|
|
openChat: () => {
|
|
|
|
this.getters.askAssistantFloatingButton().click();
|
|
|
|
this.getters.askAssistantChat().should('be.visible');
|
|
|
|
},
|
2024-08-20 04:05:09 -07:00
|
|
|
};
|
|
|
|
}
|