mirror of
https://github.com/ueberdosis/tiptap.git
synced 2024-12-12 16:59:01 +08:00
72 lines
1.8 KiB
JavaScript
72 lines
1.8 KiB
JavaScript
// ***********************************************
|
|
// This example commands.js shows you how to
|
|
// create various custom commands and overwrite
|
|
// existing commands.
|
|
//
|
|
// For more comprehensive examples of custom
|
|
// commands please read more here:
|
|
// https://on.cypress.io/custom-commands
|
|
// ***********************************************
|
|
//
|
|
//
|
|
// -- This is a parent command --
|
|
// Cypress.Commands.add("login", (email, password) => { ... })
|
|
//
|
|
//
|
|
// -- This is a child command --
|
|
// Cypress.Commands.add("drag", { prevSubject: 'element'}, (subject, options) => { ... })
|
|
//
|
|
//
|
|
// -- This is a dual command --
|
|
// Cypress.Commands.add("dismiss", { prevSubject: 'optional'}, (subject, options) => { ... })
|
|
//
|
|
//
|
|
// -- This will overwrite an existing command --
|
|
// Cypress.Commands.overwrite("visit", (originalFn, url, options) => { ... })
|
|
|
|
function defaults(object, name, value) {
|
|
if (!object) {
|
|
return {
|
|
[name]: value,
|
|
}
|
|
}
|
|
|
|
if (object[name] === undefined) {
|
|
return {
|
|
...object,
|
|
[name]: value,
|
|
}
|
|
}
|
|
|
|
return object
|
|
}
|
|
|
|
Cypress.Commands.overwrite('trigger', (originalFn, element, text, options) => {
|
|
if (text === 'keydown') {
|
|
const isMac = Cypress.platform === 'darwin'
|
|
const { modKey, ...rest } = options
|
|
|
|
if (modKey) {
|
|
const newOptions = {
|
|
...defaults(rest, 'force', true),
|
|
...(isMac ? { metaKey: modKey } : { ctrlKey: modKey }),
|
|
}
|
|
|
|
return originalFn(element, text, newOptions)
|
|
}
|
|
}
|
|
|
|
return originalFn(element, text, options)
|
|
})
|
|
|
|
Cypress.Commands.overwrite('type', (originalFn, element, text, options) => {
|
|
const newOptions = defaults(options, 'force', true)
|
|
|
|
return originalFn(element, text, newOptions)
|
|
})
|
|
|
|
Cypress.Commands.overwrite('click', (originalFn, element, text, options) => {
|
|
const newOptions = defaults(options, 'force', true)
|
|
|
|
return originalFn(element, text, newOptions)
|
|
}) |