adds tests to add components and change props on them

This commit is contained in:
kevmodrome 2020-06-11 12:56:16 +02:00
parent 3ee5111d6f
commit 59aaf33278
4 changed files with 69 additions and 1 deletions

View File

@ -0,0 +1,53 @@
context('Create Model', () => {
before(() => {
cy.visit('localhost:4001/_builder')
// https://on.cypress.io/type
cy.createApp('Model App', 'Model App Description')
cy.createModel('dog', 'name', 'age')
cy.addRecord('bob', '15')
})
// https://on.cypress.io/interacting-with-elements
it('should add a container', () => {
cy.contains('frontend').click()
cy.get('.switcher > :nth-child(2)').click()
cy.contains('Container').click()
})
it('should add a headline', () => {
cy.addHeadlineComponent('An Amazing headline!')
getIframeBody().contains('An Amazing headline!')
})
it('change the background color of the headline', () => {
cy.contains('Background').click()
cy.get('input[name="background"]')
.type('rgb(102, 51, 153)')
cy.contains('Design').click()
getIframeBody().contains('An Amazing headline!').should('have.css', 'background-color', 'rgb(102, 51, 153)')
})
})
const getIframeDocument = () => {
return cy
.get('iframe')
// Cypress yields jQuery element, which has the real
// DOM element under property "0".
// From the real DOM iframe element we can get
// the "document" element, it is stored in "contentDocument" property
// Cypress "its" command can access deep properties using dot notation
// https://on.cypress.io/its
.its('0.contentDocument').should('exist')
}
const getIframeBody = () => {
// get the document
return getIframeDocument()
// automatically retries until body is loaded
.its('body').should('not.be.undefined')
// wraps "body" DOM element to allow
// chaining more Cypress commands, like ".find(...)"
.then(cy.wrap)
}

View File

@ -81,4 +81,16 @@ Cypress.Commands.add("createUser", (username, password, level) => {
// Save
cy.contains('Save').click()
})
Cypress.Commands.add("addHeadlineComponent", (text) => {
// Create User
cy.get('.switcher > :nth-child(2)').click()
cy.contains('Text').click()
cy.contains('Headline').click()
cy.get('.tabs > :nth-child(2)').click()
cy.get('input[type="text"]')
.type(text)
cy.contains('Design').click()
})

View File

@ -2,6 +2,7 @@
import { onMount } from "svelte"
import { buildStyle } from "../../helpers.js"
export let value = ""
export let name = ""
export let textAlign = "left"
export let width = "160px"
export let placeholder = ""
@ -25,6 +26,7 @@
</script>
<input
{name}
class:centerPlaceholder
type="text"
value={displayValue}

View File

@ -36,7 +36,8 @@
{...handlevalueKey(value)}
on:change={val => handleChange(key, val)}
onChange={val => handleChange(key, val)}
{...props} />
{...props}
name={key} />
</div>
</div>