croissant-editor / cypress /e2e /uploadCsv.cy.js
marcenacp's picture
Initial commit
cb5b71d
raw
history blame
2.5 kB
/// <reference types="cypress" />
import 'cypress-file-upload';
import 'cypress-iframe';
describe('Editor loads a local CSV as a resource', () => {
it('should display the form: Overview, Metadata, Resources, & Record Sets', () => {
// Streamlit starts on :8501.
cy.visit('http://localhost:8501')
cy.get('button', {timeout: 10000}).contains('Create', {timeout: 10000}).click()
cy.get('input[aria-label="Name:red[*]"]').type('MyDataset').blur()
cy.get('[data-testid="stMarkdownContainer"]')
.contains('Metadata')
.click()
cy.get('input[aria-label="URL:red[*]"]').type('https://mydataset.com', {force: true})
cy.get('[data-testid="stMarkdownContainer"]').contains('Resources').click()
// Drag and drop mimicking: streamlit/e2e/specs/st_file_uploader.spec.js.
cy.fixture('base.csv').then((fileContent) => {
const file = {
fileContent,
fileName: 'base.csv', mimeType: 'text/csv',
}
cy.get(
"[data-testid='stFileUploadDropzone']",
).attachFile(file, {
force: true,
subjectType: "drag-n-drop",
events: ["dragenter", "drop"],
})
})
cy.get('.uploadedFileData').contains('base.csv')
cy.get('button').contains('Upload').click()
// The file is uploaded, so we can click on it to see the details.
// Waiting a few seconds to wait for the resource to download.
cy.wait(2000)
cy.enter('[title="components.tree.tree_component"]').then(getBody => {
getBody().find('li').should('be.visible').click()
})
// For example, we see the first rows:
cy.contains('First rows of data:')
// On the record set page, we see the record set.
cy.get('[data-testid="stMarkdownContainer"]').contains('RecordSets').click()
cy.contains('base.csv_record_set (2 fields)').click()
// We also see the fields with the proper types.
cy.get('[data-testid="stDataFrameResizable"]').contains("column1")
cy.get('[data-testid="stDataFrameResizable"]').contains("https://schema.org/Text")
cy.get('[data-testid="stDataFrameResizable"]').contains("column2")
cy.get('[data-testid="stDataFrameResizable"]').contains("https://schema.org/Integer")
// I can edit the details of the fields.
cy.contains('Edit fields details').click()
cy.get('input[aria-label="Description"]').last().type('This is a nice custom description!{enter}')
cy.get('[data-testid="glide-cell-2-1"]').contains("This is a nice custom description!")
})
})