mirror of
https://github.com/microsoft/playwright.git
synced 2025-01-07 11:46:42 +03:00
fix: accept post data params for request.get and request.head (#17566)
This commit is contained in:
parent
ec40e49978
commit
f5d7089819
@ -371,6 +371,16 @@ await request.GetAsync("https://example.com/api/getText", new() { Params = param
|
|||||||
* since: v1.16
|
* since: v1.16
|
||||||
### option: APIRequestContext.get.headers = %%-js-python-csharp-fetch-option-headers-%%
|
### option: APIRequestContext.get.headers = %%-js-python-csharp-fetch-option-headers-%%
|
||||||
* since: v1.16
|
* since: v1.16
|
||||||
|
### option: APIRequestContext.get.data = %%-js-python-csharp-fetch-option-data-%%
|
||||||
|
* since: v1.26
|
||||||
|
### option: APIRequestContext.get.form = %%-js-python-fetch-option-form-%%
|
||||||
|
* since: v1.26
|
||||||
|
### option: APIRequestContext.get.form = %%-csharp-fetch-option-form-%%
|
||||||
|
* since: v1.26
|
||||||
|
### option: APIRequestContext.get.multipart = %%-js-python-fetch-option-multipart-%%
|
||||||
|
* since: v1.26
|
||||||
|
### option: APIRequestContext.get.multipart = %%-csharp-fetch-option-multipart-%%
|
||||||
|
* since: v1.26
|
||||||
### option: APIRequestContext.get.timeout = %%-js-python-csharp-fetch-option-timeout-%%
|
### option: APIRequestContext.get.timeout = %%-js-python-csharp-fetch-option-timeout-%%
|
||||||
* since: v1.16
|
* since: v1.16
|
||||||
### option: APIRequestContext.get.failOnStatusCode = %%-js-python-csharp-fetch-option-failonstatuscode-%%
|
### option: APIRequestContext.get.failOnStatusCode = %%-js-python-csharp-fetch-option-failonstatuscode-%%
|
||||||
@ -398,6 +408,16 @@ context cookies from the response. The method will automatically follow redirect
|
|||||||
* since: v1.16
|
* since: v1.16
|
||||||
### option: APIRequestContext.head.headers = %%-js-python-csharp-fetch-option-headers-%%
|
### option: APIRequestContext.head.headers = %%-js-python-csharp-fetch-option-headers-%%
|
||||||
* since: v1.16
|
* since: v1.16
|
||||||
|
### option: APIRequestContext.head.data = %%-js-python-csharp-fetch-option-data-%%
|
||||||
|
* since: v1.26
|
||||||
|
### option: APIRequestContext.head.form = %%-js-python-fetch-option-form-%%
|
||||||
|
* since: v1.26
|
||||||
|
### option: APIRequestContext.head.form = %%-csharp-fetch-option-form-%%
|
||||||
|
* since: v1.26
|
||||||
|
### option: APIRequestContext.head.multipart = %%-js-python-fetch-option-multipart-%%
|
||||||
|
* since: v1.26
|
||||||
|
### option: APIRequestContext.head.multipart = %%-csharp-fetch-option-multipart-%%
|
||||||
|
* since: v1.26
|
||||||
### option: APIRequestContext.head.timeout = %%-js-python-csharp-fetch-option-timeout-%%
|
### option: APIRequestContext.head.timeout = %%-js-python-csharp-fetch-option-timeout-%%
|
||||||
* since: v1.16
|
* since: v1.16
|
||||||
### option: APIRequestContext.head.failOnStatusCode = %%-js-python-csharp-fetch-option-failonstatuscode-%%
|
### option: APIRequestContext.head.failOnStatusCode = %%-js-python-csharp-fetch-option-failonstatuscode-%%
|
||||||
|
@ -51,7 +51,6 @@ type NewContextOptions = Omit<channels.PlaywrightNewRequestOptions, 'extraHTTPHe
|
|||||||
};
|
};
|
||||||
|
|
||||||
type RequestWithBodyOptions = Omit<FetchOptions, 'method'>;
|
type RequestWithBodyOptions = Omit<FetchOptions, 'method'>;
|
||||||
type RequestWithoutBodyOptions = Omit<RequestWithBodyOptions, 'data'|'form'|'multipart'>;
|
|
||||||
|
|
||||||
export class APIRequest implements api.APIRequest {
|
export class APIRequest implements api.APIRequest {
|
||||||
private _playwright: Playwright;
|
private _playwright: Playwright;
|
||||||
@ -107,14 +106,14 @@ export class APIRequestContext extends ChannelOwner<channels.APIRequestContextCh
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async head(url: string, options?: RequestWithoutBodyOptions): Promise<APIResponse> {
|
async head(url: string, options?: RequestWithBodyOptions): Promise<APIResponse> {
|
||||||
return this.fetch(url, {
|
return this.fetch(url, {
|
||||||
...options,
|
...options,
|
||||||
method: 'HEAD',
|
method: 'HEAD',
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async get(url: string, options?: RequestWithoutBodyOptions): Promise<APIResponse> {
|
async get(url: string, options?: RequestWithBodyOptions): Promise<APIResponse> {
|
||||||
return this.fetch(url, {
|
return this.fetch(url, {
|
||||||
...options,
|
...options,
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
|
74
packages/playwright-core/types/types.d.ts
vendored
74
packages/playwright-core/types/types.d.ts
vendored
@ -12885,11 +12885,25 @@ export interface APIRequestContext {
|
|||||||
* @param options
|
* @param options
|
||||||
*/
|
*/
|
||||||
get(url: string, options?: {
|
get(url: string, options?: {
|
||||||
|
/**
|
||||||
|
* Allows to set post data of the request. If the data parameter is an object, it will be serialized to json string and
|
||||||
|
* `content-type` header will be set to `application/json` if not explicitly set. Otherwise the `content-type` header will
|
||||||
|
* be set to `application/octet-stream` if not explicitly set.
|
||||||
|
*/
|
||||||
|
data?: string|Buffer|Serializable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether to throw on response codes other than 2xx and 3xx. By default response object is returned for all status codes.
|
* Whether to throw on response codes other than 2xx and 3xx. By default response object is returned for all status codes.
|
||||||
*/
|
*/
|
||||||
failOnStatusCode?: boolean;
|
failOnStatusCode?: boolean;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides an object that will be serialized as html form using `application/x-www-form-urlencoded` encoding and sent as
|
||||||
|
* this request body. If this parameter is specified `content-type` header will be set to
|
||||||
|
* `application/x-www-form-urlencoded` unless explicitly provided.
|
||||||
|
*/
|
||||||
|
form?: { [key: string]: string|number|boolean; };
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allows to set HTTP headers.
|
* Allows to set HTTP headers.
|
||||||
*/
|
*/
|
||||||
@ -12906,6 +12920,29 @@ export interface APIRequestContext {
|
|||||||
*/
|
*/
|
||||||
maxRedirects?: number;
|
maxRedirects?: number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides an object that will be serialized as html form using `multipart/form-data` encoding and sent as this request
|
||||||
|
* body. If this parameter is specified `content-type` header will be set to `multipart/form-data` unless explicitly
|
||||||
|
* provided. File values can be passed either as [`fs.ReadStream`](https://nodejs.org/api/fs.html#fs_class_fs_readstream)
|
||||||
|
* or as file-like object containing file name, mime-type and its content.
|
||||||
|
*/
|
||||||
|
multipart?: { [key: string]: string|number|boolean|ReadStream|{
|
||||||
|
/**
|
||||||
|
* File name
|
||||||
|
*/
|
||||||
|
name: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* File type
|
||||||
|
*/
|
||||||
|
mimeType: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* File content
|
||||||
|
*/
|
||||||
|
buffer: Buffer;
|
||||||
|
}; };
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Query parameters to be sent with the URL.
|
* Query parameters to be sent with the URL.
|
||||||
*/
|
*/
|
||||||
@ -12925,11 +12962,25 @@ export interface APIRequestContext {
|
|||||||
* @param options
|
* @param options
|
||||||
*/
|
*/
|
||||||
head(url: string, options?: {
|
head(url: string, options?: {
|
||||||
|
/**
|
||||||
|
* Allows to set post data of the request. If the data parameter is an object, it will be serialized to json string and
|
||||||
|
* `content-type` header will be set to `application/json` if not explicitly set. Otherwise the `content-type` header will
|
||||||
|
* be set to `application/octet-stream` if not explicitly set.
|
||||||
|
*/
|
||||||
|
data?: string|Buffer|Serializable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether to throw on response codes other than 2xx and 3xx. By default response object is returned for all status codes.
|
* Whether to throw on response codes other than 2xx and 3xx. By default response object is returned for all status codes.
|
||||||
*/
|
*/
|
||||||
failOnStatusCode?: boolean;
|
failOnStatusCode?: boolean;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides an object that will be serialized as html form using `application/x-www-form-urlencoded` encoding and sent as
|
||||||
|
* this request body. If this parameter is specified `content-type` header will be set to
|
||||||
|
* `application/x-www-form-urlencoded` unless explicitly provided.
|
||||||
|
*/
|
||||||
|
form?: { [key: string]: string|number|boolean; };
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allows to set HTTP headers.
|
* Allows to set HTTP headers.
|
||||||
*/
|
*/
|
||||||
@ -12946,6 +12997,29 @@ export interface APIRequestContext {
|
|||||||
*/
|
*/
|
||||||
maxRedirects?: number;
|
maxRedirects?: number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides an object that will be serialized as html form using `multipart/form-data` encoding and sent as this request
|
||||||
|
* body. If this parameter is specified `content-type` header will be set to `multipart/form-data` unless explicitly
|
||||||
|
* provided. File values can be passed either as [`fs.ReadStream`](https://nodejs.org/api/fs.html#fs_class_fs_readstream)
|
||||||
|
* or as file-like object containing file name, mime-type and its content.
|
||||||
|
*/
|
||||||
|
multipart?: { [key: string]: string|number|boolean|ReadStream|{
|
||||||
|
/**
|
||||||
|
* File name
|
||||||
|
*/
|
||||||
|
name: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* File type
|
||||||
|
*/
|
||||||
|
mimeType: string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* File content
|
||||||
|
*/
|
||||||
|
buffer: Buffer;
|
||||||
|
}; };
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Query parameters to be sent with the URL.
|
* Query parameters to be sent with the URL.
|
||||||
*/
|
*/
|
||||||
|
@ -409,20 +409,83 @@ it('should return error with wrong credentials', async ({ context, server }) =>
|
|||||||
expect(response2.status()).toBe(401);
|
expect(response2.status()).toBe(401);
|
||||||
});
|
});
|
||||||
|
|
||||||
for (const method of ['delete', 'get', 'head', 'patch', 'post', 'put']) {
|
it('delete should support post data', async ({ context, server }) => {
|
||||||
it(`${method} should support post data`, async ({ context, server }) => {
|
const [request, response] = await Promise.all([
|
||||||
const [request, response] = await Promise.all([
|
server.waitForRequest('/simple.json'),
|
||||||
server.waitForRequest('/simple.json'),
|
context.request.delete(`${server.PREFIX}/simple.json`, {
|
||||||
context.request[method](`${server.PREFIX}/simple.json`, {
|
data: 'My request'
|
||||||
data: 'My request'
|
})
|
||||||
})
|
]);
|
||||||
]);
|
expect(request.method).toBe('DELETE');
|
||||||
expect(request.method).toBe(method.toUpperCase());
|
expect((await request.postBody).toString()).toBe('My request');
|
||||||
expect((await request.postBody).toString()).toBe('My request');
|
expect(response.status()).toBe(200);
|
||||||
expect(response.status()).toBe(200);
|
expect(request.url).toBe('/simple.json');
|
||||||
expect(request.url).toBe('/simple.json');
|
});
|
||||||
});
|
|
||||||
}
|
it('get should support post data', async ({ context, server }) => {
|
||||||
|
const [request, response] = await Promise.all([
|
||||||
|
server.waitForRequest('/simple.json'),
|
||||||
|
context.request.get(`${server.PREFIX}/simple.json`, {
|
||||||
|
data: 'My request'
|
||||||
|
})
|
||||||
|
]);
|
||||||
|
expect(request.method).toBe('GET');
|
||||||
|
expect((await request.postBody).toString()).toBe('My request');
|
||||||
|
expect(response.status()).toBe(200);
|
||||||
|
expect(request.url).toBe('/simple.json');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('head should support post data', async ({ context, server }) => {
|
||||||
|
const [request, response] = await Promise.all([
|
||||||
|
server.waitForRequest('/simple.json'),
|
||||||
|
context.request.head(`${server.PREFIX}/simple.json`, {
|
||||||
|
data: 'My request'
|
||||||
|
})
|
||||||
|
]);
|
||||||
|
expect(request.method).toBe('HEAD');
|
||||||
|
expect((await request.postBody).toString()).toBe('My request');
|
||||||
|
expect(response.status()).toBe(200);
|
||||||
|
expect(request.url).toBe('/simple.json');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('patch should support post data', async ({ context, server }) => {
|
||||||
|
const [request, response] = await Promise.all([
|
||||||
|
server.waitForRequest('/simple.json'),
|
||||||
|
context.request.patch(`${server.PREFIX}/simple.json`, {
|
||||||
|
data: 'My request'
|
||||||
|
})
|
||||||
|
]);
|
||||||
|
expect(request.method).toBe('PATCH');
|
||||||
|
expect((await request.postBody).toString()).toBe('My request');
|
||||||
|
expect(response.status()).toBe(200);
|
||||||
|
expect(request.url).toBe('/simple.json');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('post should support post data', async ({ context, server }) => {
|
||||||
|
const [request, response] = await Promise.all([
|
||||||
|
server.waitForRequest('/simple.json'),
|
||||||
|
context.request.post(`${server.PREFIX}/simple.json`, {
|
||||||
|
data: 'My request'
|
||||||
|
})
|
||||||
|
]);
|
||||||
|
expect(request.method).toBe('POST');
|
||||||
|
expect((await request.postBody).toString()).toBe('My request');
|
||||||
|
expect(response.status()).toBe(200);
|
||||||
|
expect(request.url).toBe('/simple.json');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('put should support post data', async ({ context, server }) => {
|
||||||
|
const [request, response] = await Promise.all([
|
||||||
|
server.waitForRequest('/simple.json'),
|
||||||
|
context.request.put(`${server.PREFIX}/simple.json`, {
|
||||||
|
data: 'My request'
|
||||||
|
})
|
||||||
|
]);
|
||||||
|
expect(request.method).toBe('PUT');
|
||||||
|
expect((await request.postBody).toString()).toBe('My request');
|
||||||
|
expect(response.status()).toBe(200);
|
||||||
|
expect(request.url).toBe('/simple.json');
|
||||||
|
});
|
||||||
|
|
||||||
it('should add default headers', async ({ context, server, page }) => {
|
it('should add default headers', async ({ context, server, page }) => {
|
||||||
const [request] = await Promise.all([
|
const [request] = await Promise.all([
|
||||||
|
Loading…
Reference in New Issue
Block a user