78 lines
2.8 KiB
JavaScript
78 lines
2.8 KiB
JavaScript
context('FileUploader', () => {
|
|
before(() => {
|
|
cy.login();
|
|
cy.visit('/app');
|
|
});
|
|
|
|
function open_upload_dialog() {
|
|
cy.window().its('frappe').then(frappe => {
|
|
new frappe.ui.FileUploader();
|
|
});
|
|
}
|
|
|
|
it('upload dialog api works', () => {
|
|
open_upload_dialog();
|
|
cy.get_open_dialog().should('contain', 'Drag and drop files');
|
|
cy.hide_dialog();
|
|
});
|
|
|
|
it('should accept dropped files', () => {
|
|
open_upload_dialog();
|
|
|
|
cy.get_open_dialog().find('.file-upload-area').attachFile('example.json', {
|
|
subjectType: 'drag-n-drop',
|
|
});
|
|
|
|
cy.get_open_dialog().find('.file-name').should('contain', 'example.json');
|
|
cy.intercept('POST', '/api/method/upload_file').as('upload_file');
|
|
cy.get_open_dialog().findByRole('button', {name: 'Upload'}).click();
|
|
cy.wait('@upload_file').its('response.statusCode').should('eq', 200);
|
|
cy.get('.modal:visible').should('not.exist');
|
|
});
|
|
|
|
it('should accept uploaded files', () => {
|
|
open_upload_dialog();
|
|
|
|
cy.get_open_dialog().findByRole('button', {name: 'Library'}).click();
|
|
cy.findByPlaceholderText('Search by filename or extension').type('example.json');
|
|
cy.get_open_dialog().findAllByText('example.json').first().click();
|
|
cy.intercept('POST', '/api/method/upload_file').as('upload_file');
|
|
cy.get_open_dialog().findByRole('button', {name: 'Upload'}).click();
|
|
cy.wait('@upload_file').its('response.body.message')
|
|
.should('have.property', 'file_name', 'example.json');
|
|
cy.get('.modal:visible').should('not.exist');
|
|
});
|
|
|
|
it('should accept web links', () => {
|
|
open_upload_dialog();
|
|
|
|
cy.get_open_dialog().findByRole('button', {name: 'Link'}).click();
|
|
cy.get_open_dialog()
|
|
.findByPlaceholderText('Attach a web link')
|
|
.type('https://github.com', { delay: 100, force: true });
|
|
cy.intercept('POST', '/api/method/upload_file').as('upload_file');
|
|
cy.get_open_dialog().findByRole('button', {name: 'Upload'}).click();
|
|
cy.wait('@upload_file').its('response.body.message')
|
|
.should('have.property', 'file_url', 'https://github.com');
|
|
cy.get('.modal:visible').should('not.exist');
|
|
});
|
|
|
|
it('should allow cropping and optimization for valid images', () => {
|
|
open_upload_dialog();
|
|
|
|
cy.get_open_dialog().find('.file-upload-area').attachFile('sample_image.jpg', {
|
|
subjectType: 'drag-n-drop',
|
|
});
|
|
|
|
cy.get_open_dialog().findAllByText('sample_image.jpg').should('exist');
|
|
cy.get_open_dialog().find('.btn-crop').first().click();
|
|
cy.get_open_dialog().findByRole('button', {name: 'Crop'}).click();
|
|
cy.get_open_dialog().findAllByRole('checkbox', {name: 'Optimize'}).should('exist');
|
|
cy.get_open_dialog().findAllByLabelText('Optimize').first().click();
|
|
|
|
cy.intercept('POST', '/api/method/upload_file').as('upload_file');
|
|
cy.get_open_dialog().findByRole('button', {name: 'Upload'}).click();
|
|
cy.wait('@upload_file').its('response.statusCode').should('eq', 200);
|
|
cy.get('.modal:visible').should('not.exist');
|
|
});
|
|
});
|