Spaces:
Running
Running
/// <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').contains('Create').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!") | |
}) | |
}) | |