Чтобы ответить прямо, открытие / просмотр прямого объявления пользовательских команд не поддерживается (может быть, кто-то может исправить, если это поддерживает).Я обычно следую за группировкой пользовательских команд в отдельных файлах.Например,
Файл: cypress/support/sample_command.ts
/// <reference types="Cypress" />
import * as PageElements from "../resources/selectors.json";
import * as Pages from "../resources/urls.json";
let xml: XMLDocument
let data: HTMLCollection
Cypress.Commands.add(
"getWorkflowXML",
(wfPath: string): Cypress.Chainable<HTMLCollection> => {
var url = Cypress.env("url") + wfPath;
return cy.request({
log: true,
url: url,
auth: {
user: Cypress.env("userName"),
pass: Cypress.env("password")
}
}).then(response => {
expect(response)
.property("status")
.to.equal(200);
xml = Cypress.$.parseXML(response.body);
data = xml.getElementsByTagName("java");
return data;
});
}
);
declare global {
namespace Cypress {
interface Chainable {
/**
* Get Workflow XML through XHR call
* @memberof Cypress.Chainable
* @param wfPath
*/
getWorkflowXML: (wfPath: string) => Cypress.Chainable<HTMLCollection>;
}
}
}
Затем в файле cypress/support/index.js
я бы импортировал командный файл:
import './sample_command'
Этот способ дает мнелучшая отслеживаемость, вместо объявления всех команд прямо под index.d.ts
.
Ссылка:
- https://docs.cypress.io/api/cypress-api/custom-commands.html#Syntax
- https://github.com/cypress-io/add-cypress-custom-command-in-typescript