123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- // 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
- cy.get('button[aria-label="model-item"]').first().click();
- });
- it('user can perform text 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-input').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
- // .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');
- });
- 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-input').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
- // .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');
- // spy on requests
- const spy = cy.spy();
- cy.intercept('POST', '/api/v1/chats/**/share', spy);
- // 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');
- // 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);
- });
- });
- 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
- cy.get('#chat-input').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
- // .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');
- // 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');
- });
- });
- });
|