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
|
|
|
|
cy.get('#chat-textarea').type('Hi, what can you do? A single sentence only please.', {
|
|
|
|
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
|
|
|
|
cy.get('.chat-assistant', { timeout: 120_000 }) // .chat-assistant is created after the first token is received
|
|
|
|
.find('div[aria-label="Generation Info"]', { timeout: 120_000 }) // Generation Info is created after the stop token is received
|
|
|
|
.should('exist');
|
|
|
|
});
|
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
|
|
|
|
cy.get('#chat-textarea').type('Hi, what can you do? A single sentence only please.', {
|
|
|
|
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
|
|
|
|
cy.get('.chat-assistant', { timeout: 120_000 }) // .chat-assistant is created after the first token is received
|
|
|
|
.find('div[aria-label="Generation Info"]', { timeout: 120_000 }) // Generation Info is created after the stop token is received
|
|
|
|
.should('exist');
|
|
|
|
// spy on requests
|
|
|
|
const spy = cy.spy();
|
2024-05-17 03:41:37 +00:00
|
|
|
cy.intercept('GET', '/api/v1/chats/*', 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-05-17 03:41:37 +00:00
|
|
|
cy.wrap({}, { timeout: 5000 }).should(() => {
|
|
|
|
// Check if the request was made twice (once for to replace chat object and once more due to change event)
|
|
|
|
expect(spy).to.be.callCount(2);
|
|
|
|
});
|
2024-05-14 13:14:47 +00:00
|
|
|
});
|
2024-04-26 21:32:09 +00:00
|
|
|
});
|
|
|
|
});
|