adds tests to add components and change props on them
This commit is contained in:
parent
3ee5111d6f
commit
59aaf33278
|
@ -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)
|
||||||
|
}
|
|
@ -81,4 +81,16 @@ Cypress.Commands.add("createUser", (username, password, level) => {
|
||||||
|
|
||||||
// Save
|
// Save
|
||||||
cy.contains('Save').click()
|
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()
|
||||||
})
|
})
|
|
@ -2,6 +2,7 @@
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import { buildStyle } from "../../helpers.js"
|
import { buildStyle } from "../../helpers.js"
|
||||||
export let value = ""
|
export let value = ""
|
||||||
|
export let name = ""
|
||||||
export let textAlign = "left"
|
export let textAlign = "left"
|
||||||
export let width = "160px"
|
export let width = "160px"
|
||||||
export let placeholder = ""
|
export let placeholder = ""
|
||||||
|
@ -25,6 +26,7 @@
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<input
|
<input
|
||||||
|
{name}
|
||||||
class:centerPlaceholder
|
class:centerPlaceholder
|
||||||
type="text"
|
type="text"
|
||||||
value={displayValue}
|
value={displayValue}
|
||||||
|
|
|
@ -36,7 +36,8 @@
|
||||||
{...handlevalueKey(value)}
|
{...handlevalueKey(value)}
|
||||||
on:change={val => handleChange(key, val)}
|
on:change={val => handleChange(key, val)}
|
||||||
onChange={val => handleChange(key, val)}
|
onChange={val => handleChange(key, val)}
|
||||||
{...props} />
|
{...props}
|
||||||
|
name={key} />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue