2024-04-26 21:32:09 +00:00
|
|
|
// eslint-disable-next-line @typescript-eslint/triple-slash-reference
|
|
|
|
/// <reference path="../support/index.d.ts" />
|
|
|
|
|
|
|
|
// These tests run through the chat flow.
|
|
|
|
describe('Settings', () => {
|
|
|
|
// Wait for 2 seconds after all tests to fix an issue with Cypress's video recording missing the last few frames
|
|
|
|
after(() => {
|
|
|
|
// eslint-disable-next-line cypress/no-unnecessary-waiting
|
|
|
|
cy.wait(2000);
|
|
|
|
});
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
// Login as the admin user
|
|
|
|
cy.loginAdmin();
|
|
|
|
// Visit the home page
|
|
|
|
cy.visit('/');
|
|
|
|
});
|
|
|
|
|
|
|
|
context('Ollama', () => {
|
|
|
|
it('user can select a model', () => {
|
|
|
|
// Click on the model selector
|
|
|
|
cy.get('button[aria-label="Select a model"]').click();
|
|
|
|
// Select the first model
|
2024-05-02 21:20:53 +00:00
|
|
|
cy.get('button[aria-label="model-item"]').first().click();
|
2024-04-26 21:32:09 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('user can perform text chat', () => {
|
|
|
|
// Click on the model selector
|
|
|
|
cy.get('button[aria-label="Select a model"]').click();
|
|
|
|
// Select the first model
|
2024-05-02 21:20:53 +00:00
|
|
|
cy.get('button[aria-label="model-item"]').first().click();
|
2024-04-26 21:32:09 +00:00
|
|
|
// Type a message
|
2024-10-19 06:54:35 +00:00
|
|
|
cy.get('#chat-input').type('Hi, what can you do? A single sentence only please.', {
|
2024-04-26 21:32:09 +00:00
|
|
|
force: true
|
|
|
|
});
|
|
|
|
// Send the message
|
|
|
|
cy.get('button[type="submit"]').click();
|
|
|
|
// User's message should be visible
|
|
|
|
cy.get('.chat-user').should('exist');
|
|
|
|
// Wait for the response
|
2024-08-11 15:22:33 +00:00
|
|
|
// .chat-assistant is created after the first token is received
|
|
|
|
cy.get('.chat-assistant', { timeout: 10_000 }).should('exist');
|
|
|
|
// Generation Info is created after the stop token is received
|
|
|
|
cy.get('div[aria-label="Generation Info"]', { timeout: 120_000 }).should('exist');
|
2024-04-26 21:32:09 +00:00
|
|
|
});
|
2024-05-14 13:14:47 +00:00
|
|
|
|
|
|
|
it('user can share chat', () => {
|
|
|
|
// Click on the model selector
|
|
|
|
cy.get('button[aria-label="Select a model"]').click();
|
|
|
|
// Select the first model
|
|
|
|
cy.get('button[aria-label="model-item"]').first().click();
|
|
|
|
// Type a message
|
2024-10-19 06:54:35 +00:00
|
|
|
cy.get('#chat-input').type('Hi, what can you do? A single sentence only please.', {
|
2024-05-14 13:14:47 +00:00
|
|
|
force: true
|
|
|
|
});
|
|
|
|
// Send the message
|
|
|
|
cy.get('button[type="submit"]').click();
|
|
|
|
// User's message should be visible
|
|
|
|
cy.get('.chat-user').should('exist');
|
|
|
|
// Wait for the response
|
2024-08-11 15:22:33 +00:00
|
|
|
// .chat-assistant is created after the first token is received
|
|
|
|
cy.get('.chat-assistant', { timeout: 10_000 }).should('exist');
|
|
|
|
// Generation Info is created after the stop token is received
|
|
|
|
cy.get('div[aria-label="Generation Info"]', { timeout: 120_000 }).should('exist');
|
2024-05-14 13:14:47 +00:00
|
|
|
// spy on requests
|
|
|
|
const spy = cy.spy();
|
2024-08-11 21:30:25 +00:00
|
|
|
cy.intercept('POST', '/api/v1/chats/**/share', spy);
|
2024-05-14 13:14:47 +00:00
|
|
|
// Open context menu
|
|
|
|
cy.get('#chat-context-menu-button').click();
|
|
|
|
// Click share button
|
|
|
|
cy.get('#chat-share-button').click();
|
|
|
|
// Check if the share dialog is visible
|
|
|
|
cy.get('#copy-and-share-chat-button').should('exist');
|
2024-08-11 21:30:25 +00:00
|
|
|
// Click the copy button
|
|
|
|
cy.get('#copy-and-share-chat-button').click();
|
|
|
|
cy.wrap({}, { timeout: 5_000 }).should(() => {
|
|
|
|
// Check if the share request was made
|
|
|
|
expect(spy).to.be.callCount(1);
|
2024-05-17 04:21:19 +00:00
|
|
|
});
|
2024-05-14 13:14:47 +00:00
|
|
|
});
|
2024-05-20 07:56:18 +00:00
|
|
|
|
|
|
|
it('user can generate image', () => {
|
|
|
|
// Click on the model selector
|
|
|
|
cy.get('button[aria-label="Select a model"]').click();
|
|
|
|
// Select the first model
|
|
|
|
cy.get('button[aria-label="model-item"]').first().click();
|
|
|
|
// Type a message
|
2024-10-19 06:54:35 +00:00
|
|
|
cy.get('#chat-input').type('Hi, what can you do? A single sentence only please.', {
|
2024-05-20 07:56:18 +00:00
|
|
|
force: true
|
|
|
|
});
|
|
|
|
// Send the message
|
|
|
|
cy.get('button[type="submit"]').click();
|
|
|
|
// User's message should be visible
|
|
|
|
cy.get('.chat-user').should('exist');
|
|
|
|
// Wait for the response
|
2024-08-11 15:22:33 +00:00
|
|
|
// .chat-assistant is created after the first token is received
|
|
|
|
cy.get('.chat-assistant', { timeout: 10_000 }).should('exist');
|
|
|
|
// Generation Info is created after the stop token is received
|
|
|
|
cy.get('div[aria-label="Generation Info"]', { timeout: 120_000 }).should('exist');
|
2024-05-20 07:56:18 +00:00
|
|
|
// Click on the generate image button
|
|
|
|
cy.get('[aria-label="Generate Image"]').click();
|
|
|
|
// Wait for image to be visible
|
|
|
|
cy.get('img[data-cy="image"]', { timeout: 60_000 }).should('be.visible');
|
|
|
|
});
|
2024-04-26 21:32:09 +00:00
|
|
|
});
|
|
|
|
});
|