UNPKG

cy-mobile-commands

Version:

Mobile testing helper for Cypress

371 lines (369 loc) 13.2 kB
/// <reference types="cypress" /> declare type Method = 'ACL' | 'BIND' | 'CHECKOUT' | 'CONNECT' | 'COPY' | 'DELETE' | 'GET' | 'HEAD' | 'LINK' | 'LOCK' | 'M-SEARCH' | 'MERGE' | 'MKACTIVITY' | 'MKCALENDAR' | 'MKCOL' | 'MOVE' | 'NOTIFY' | 'OPTIONS' | 'PATCH' | 'POST' | 'PROPFIND' | 'PROPPATCH' | 'PURGE' | 'PUT' | 'REBIND' | 'REPORT' | 'SEARCH' | 'SOURCE' | 'SUBSCRIBE' | 'TRACE' | 'UNBIND' | 'UNLINK' | 'UNLOCK' | 'UNSUBSCRIBE' | 'acl' | 'bind' | 'checkout' | 'connect' | 'copy' | 'delete' | 'get' | 'head' | 'link' | 'lock' | 'm-search' | 'merge' | 'mkactivity' | 'mkcalendar' | 'mkcol' | 'move' | 'notify' | 'options' | 'patch' | 'post' | 'propfind' | 'proppatch' | 'purge' | 'put' | 'rebind' | 'report' | 'search' | 'source' | 'subscribe' | 'trace' | 'unbind' | 'unlink' | 'unlock' | 'unsubscribe'; export declare namespace CyHttpMessages { interface BaseMessage { body?: any; headers: { [key: string]: string; }; url: string; method?: Method; httpVersion?: string; } type IncomingResponse = BaseMessage & { statusCode: number; statusMessage: string; }; type IncomingHttpResponse = IncomingResponse & { /** * Continue the HTTP response, merging the supplied values with the real response. */ send(status: number, body?: string | number | object, headers?: { [key: string]: string; }): void; send(body: string | object, headers?: { [key: string]: string; }): void; send(staticResponse: StaticResponse): void; /** * Continue the HTTP response to the browser, including any modifications made to `res`. */ send(): void; /** * Wait for `delay` milliseconds before sending the response to the client. */ delay: (delay: number) => IncomingHttpResponse; /** * Serve the response at `throttleKbps` kilobytes per second. */ throttle: (throttleKbps: number) => IncomingHttpResponse; }; type IncomingRequest = BaseMessage & { responseTimeout?: number; /** * Set if redirects should be followed when this request is made. By default, requests will * not follow redirects before yielding the response (the 3xx redirect is yielded) */ followRedirect?: boolean; /** * If set, `cy.wait` can be used to await the request/response cycle to complete for this * request via `cy.wait('@alias')`. */ alias?: string; }; interface IncomingHttpRequest extends IncomingRequest { /** * Destroy the request and respond with a network error. */ destroy(): void; /** * Control the response to this request. * If a function is passed, the request will be sent outgoing, and the function will be called * with the response from the upstream server. * If a `StaticResponse` is passed, it will be used as the response, and no request will be made * to the upstream server. */ reply(interceptor?: StaticResponse | HttpResponseInterceptor): void; /** * Shortcut to reply to the request with a body and optional headers. */ reply(body: string | object, headers?: { [key: string]: string; }): void; /** * Shortcut to reply to the request with an HTTP status code and optional body and headers. */ reply(status: number, body?: string | object, headers?: { [key: string]: string; }): void; /** * Respond to this request with a redirect to a new `location`. * @param statusCode HTTP status code to redirect with. Default: 302 */ redirect(location: string, statusCode?: number): void; } } export interface DictMatcher<T> { [key: string]: T; } /** * Matches a string using glob (`*`) matching. */ export declare type GlobPattern = string; /** * Interceptor for an HTTP request. If a Promise is returned, it will be awaited before passing the * request to the next handler (if there is one), otherwise the request will be passed to the next * handler synchronously. */ export declare type HttpRequestInterceptor = (req: CyHttpMessages.IncomingHttpRequest) => void | Promise<void>; /** * Interceptor for an HTTP response. If a Promise is returned, it will be awaited before passing the * request to the next handler (if there is one), otherwise the request will be passed to the next * handler synchronously. */ export declare type HttpResponseInterceptor = (res: CyHttpMessages.IncomingHttpResponse) => void | Promise<void>; /** * Matches a single number or any of an array of acceptable numbers. */ export declare type NumberMatcher = number | number[]; /** * Request/response cycle. */ export interface Interception { id: string; routeHandlerId: string; log: any; request: CyHttpMessages.IncomingRequest; /** * Was `cy.wait()` used to wait on this request? * @internal */ requestWaited: boolean; response?: CyHttpMessages.IncomingResponse; responseHandler?: HttpResponseInterceptor; /** * The error that occurred during this request. */ error?: Error; /** * Was `cy.wait()` used to wait on the response to this request? * @internal */ responseWaited: boolean; state: InterceptionState; } export declare type InterceptionState = 'Received' | 'Intercepted' | 'ResponseReceived' | 'ResponseIntercepted' | 'Complete' | 'Errored'; export interface Route { alias?: string; log: any; options: RouteMatcherOptions; handler: RouteHandler; hitCount: number; requests: { [key: string]: Interception; }; command: any; } export interface RouteMap { [key: string]: Route; } /** * A `RouteMatcher` describes a filter for HTTP requests. */ export declare type RouteMatcher = StringMatcher | RouteMatcherOptions; export declare type RouteMatcherOptions = RouteMatcherOptionsGeneric<StringMatcher>; export interface RouteMatcherOptionsGeneric<S> { /** * Match against the username and password used in HTTP Basic authentication. */ auth?: { username: S; password: S; }; /** * Match against HTTP headers on the request. */ headers?: DictMatcher<S>; /** * Match against the requested HTTP hostname. */ hostname?: S; /** * If 'true', only HTTPS requests will be matched. * If 'false', only HTTP requests will be matched. */ https?: boolean; /** * If `true`, will match the supplied `url` against incoming `path`s. * Requires a `url` argument. Cannot be used with a `path` argument. */ matchUrlAgainstPath?: boolean; /** * Match against the request's HTTP method. * @default '*' */ method?: S; /** * Match on request path after the hostname, including query params. */ path?: S; /** * Matches like `path`, but without query params. */ pathname?: S; /** * Match based on requested port, or pass an array of ports * to match against any in that array. */ port?: NumberMatcher; /** * Match on parsed querystring parameters. */ query?: DictMatcher<S>; /** * Match against the full request URL. * If a string is passed, it will be used as a substring match, * not an equality match. */ url?: S; } export declare type RouteHandlerController = HttpRequestInterceptor; export declare type RouteHandler = string | StaticResponse | RouteHandlerController | object; /** * Describes a response that will be sent back to the browser to fulfill the request. */ export declare type StaticResponse = GenericStaticResponse<string, string | object> & { /** * Milliseconds to delay before the response is sent. * @deprecated Use `delay` instead of `delayMs`. */ delayMs?: number; }; export interface GenericStaticResponse<Fixture, Body> { /** * Serve a fixture as the response body. */ fixture?: Fixture; /** * Serve a static string/JSON object as the response body. */ body?: Body; /** * HTTP headers to accompany the response. * @default {} */ headers?: { [key: string]: string; }; /** * The HTTP status code to send. * @default 200 */ statusCode?: number; /** * If 'forceNetworkError' is truthy, Cypress will destroy the browser connection * and send no response. Useful for simulating a server that is not reachable. * Must not be set in combination with other options. */ forceNetworkError?: boolean; /** * Kilobits per second to send 'body'. */ throttleKbps?: number; /** * Milliseconds to delay before the response is sent. */ delay?: number; } /** * Either a `GlobPattern` string or a `RegExp`. */ export declare type StringMatcher = GlobPattern | RegExp; interface WaitOptions { /** * Displays the command in the Command Log * * @default true */ log: boolean; /** * Time to wait for the request (ms) * * @default {@link Timeoutable#timeout} * @see https://on.cypress.io/configuration#Timeouts */ requestTimeout: number; /** * Time to wait for the response (ms) * * @default {@link Timeoutable#timeout} * @see https://on.cypress.io/configuration#Timeouts */ responseTimeout: number; /** * Time to wait (ms) * * @default defaultCommandTimeout * @see https://on.cypress.io/configuration#Timeouts */ timeout: number; } declare global { namespace Cypress { interface Chainable<Subject = any> { /** * Use `cy.intercept()` to stub and intercept HTTP requests and responses. * * @see https://on.cypress.io/intercept * @example * cy.intercept('https://localhost:7777/users', [{id: 1, name: 'Pat'}]) * @example * cy.intercept('https://localhost:7777/protected-endpoint', (req) => { * req.headers['authorization'] = 'basic fooabc123' * }) * @example * cy.intercept('https://localhost:7777/some-response', (req) => { * req.reply(res => { * res.body = 'some new body' * }) * }) */ intercept(url: RouteMatcher, response?: RouteHandler): Chainable<null>; /** * Use `cy.intercept()` to stub and intercept HTTP requests and responses. * * @see https://on.cypress.io/intercept * @example * cy.intercept('GET', 'http://foo.com/fruits', ['apple', 'banana', 'cherry']) */ intercept(method: Method, url: RouteMatcher, response?: RouteHandler): Chainable<null>; /** * @deprecated Use `cy.intercept()` instead. */ route2(url: RouteMatcher, response?: RouteHandler): Chainable<null>; /** * @deprecated Use `cy.intercept()` instead. */ route2(method: Method, url: RouteMatcher, response?: RouteHandler): Chainable<null>; /** * Wait for a specific request to complete. * * @see https://on.cypress.io/wait * @param {string} alias - Name of the alias to wait for. * ``` // Wait for the route aliased as 'getAccount' to respond // without changing or stubbing its response cy.intercept('https://api.example.com/accounts/*').as('getAccount') cy.visit('/accounts/123') cy.wait('@getAccount').then((interception) => { // we can now access the low level request // that contains the request body, // response body, status, etc }) ``` */ wait(alias: string, options?: Partial<WaitOptions>): Chainable<Interception>; /** * Wait for list of requests to complete. * * @see https://on.cypress.io/wait * @param {string[]} aliases - An array of aliased routes as defined using the `.as()` command. * ``` // wait for 3 XHR requests to complete cy.intercept('users/*').as('getUsers') cy.intercept('activities/*').as('getActivities') cy.intercept('comments/*').as('getComments') cy.visit('/dashboard') cy.wait(['@getUsers', '@getActivities', '@getComments']) .then((interceptions) => { // intercepts will now be an array of matching HTTP requests }) ``` */ wait(alias: string[], options?: Partial<WaitOptions>): Chainable<Interception[]>; } } } export {};