Skip to content

Commit

Permalink
feat(firefox): roll firefox to r1137 (#3095)
Browse files Browse the repository at this point in the history
  • Loading branch information
pavelfeldman authored Jul 22, 2020
1 parent 2a08883 commit 80c0711
Show file tree
Hide file tree
Showing 11 changed files with 73 additions and 24 deletions.
2 changes: 1 addition & 1 deletion browsers.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
},
{
"name": "firefox",
"revision": "1134"
"revision": "1137"
},
{
"name": "webkit",
Expand Down
4 changes: 4 additions & 0 deletions docs/api.md
Original file line number Diff line number Diff line change
Expand Up @@ -3486,6 +3486,7 @@ If request gets a 'redirect' response, the request is successfully finished with
- [request.isNavigationRequest()](#requestisnavigationrequest)
- [request.method()](#requestmethod)
- [request.postData()](#requestpostdata)
- [request.postDataBuffer()](#requestpostdatabuffer)
- [request.postDataJSON()](#requestpostdatajson)
- [request.redirectedFrom()](#requestredirectedfrom)
- [request.redirectedTo()](#requestredirectedto)
Expand Down Expand Up @@ -3526,6 +3527,9 @@ Whether this request is driving frame's navigation.
#### request.postData()
- returns: <?[string]> Request's post body, if any.

#### request.postDataBuffer()
- returns: <?[Buffer]> Request's post body in a binary form, if any.

#### request.postDataJSON()
- returns: <?[Object]> Parsed request's body for `form-urlencoded` and JSON as a fallback if any.

Expand Down
8 changes: 6 additions & 2 deletions src/chromium/crNetworkManager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -342,10 +342,14 @@ class InterceptableRequest implements network.RouteDelegate {
headers,
method,
url,
postData = null,
postDataEntries = null,
} = requestPausedEvent ? requestPausedEvent.request : requestWillBeSentEvent.request;
const type = (requestWillBeSentEvent.type || '').toLowerCase();
this.request = new network.Request(allowInterception ? this : null, frame, redirectedFrom, documentId, url, type, method, postData, headersObject(headers));
let postDataBuffer = null;
if (postDataEntries && postDataEntries.length && postDataEntries[0].bytes)
postDataBuffer = Buffer.from(postDataEntries[0].bytes, 'base64');

this.request = new network.Request(allowInterception ? this : null, frame, redirectedFrom, documentId, url, type, method, postDataBuffer, headersObject(headers));
}

async continue(overrides: types.NormalizedContinueOverrides) {
Expand Down
6 changes: 4 additions & 2 deletions src/firefox/ffNetworkManager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -153,9 +153,11 @@ class InterceptableRequest implements network.RouteDelegate {
const headers: types.Headers = {};
for (const {name, value} of payload.headers)
headers[name.toLowerCase()] = value;

let postDataBuffer = null;
if (payload.postData)
postDataBuffer = Buffer.from(payload.postData, 'base64');
this.request = new network.Request(payload.isIntercepted ? this : null, frame, redirectedFrom ? redirectedFrom.request : null, payload.navigationId,
payload.url, internalCauseToResourceType[payload.internalCause] || causeToResourceType[payload.cause] || 'other', payload.method, payload.postData || null, headers);
payload.url, internalCauseToResourceType[payload.internalCause] || causeToResourceType[payload.cause] || 'other', payload.method, postDataBuffer, headers);
}

async continue(overrides: types.NormalizedContinueOverrides) {
Expand Down
15 changes: 10 additions & 5 deletions src/network.ts
Original file line number Diff line number Diff line change
Expand Up @@ -78,14 +78,14 @@ export class Request {
private _url: string;
private _resourceType: string;
private _method: string;
private _postData: string | null;
private _postData: Buffer | null;
private _headers: types.Headers;
private _frame: frames.Frame;
private _waitForResponsePromise: Promise<Response | null>;
private _waitForResponsePromiseCallback: (value: Response | null) => void = () => {};

constructor(routeDelegate: RouteDelegate | null, frame: frames.Frame, redirectedFrom: Request | null, documentId: string | undefined,
url: string, resourceType: string, method: string, postData: string | null, headers: types.Headers) {
url: string, resourceType: string, method: string, postData: Buffer | null, headers: types.Headers) {
assert(!url.startsWith('data:'), 'Data urls should not fire requests');
assert(!(routeDelegate && redirectedFrom), 'Should not be able to intercept redirects');
this._routeDelegate = routeDelegate;
Expand Down Expand Up @@ -121,11 +121,16 @@ export class Request {
}

postData(): string | null {
return this._postData ? this._postData.toString('utf8') : null;
}

postDataBuffer(): Buffer | null {
return this._postData;
}

postDataJSON(): Object | null {
if (!this._postData)
const postData = this.postData();
if (!postData)
return null;

const contentType = this.headers()['content-type'];
Expand All @@ -134,13 +139,13 @@ export class Request {

if (contentType === 'application/x-www-form-urlencoded') {
const entries: Record<string, string> = {};
const parsed = new URLSearchParams(this._postData);
const parsed = new URLSearchParams(postData);
for (const [k, v] of parsed.entries())
entries[k] = v;
return entries;
}

return JSON.parse(this._postData);
return JSON.parse(postData);
}

headers(): {[key: string]: string} {
Expand Down
2 changes: 1 addition & 1 deletion src/rpc/channels.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1400,7 +1400,7 @@ export type RequestInitializer = {
url: string,
resourceType: string,
method: string,
postData?: string,
postData?: Binary,
headers: {
name: string,
value: string,
Expand Down
15 changes: 11 additions & 4 deletions src/rpc/client/network.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ export class Request extends ChannelOwner<RequestChannel, RequestInitializer> {
private _redirectedTo: Request | null = null;
_failureText: string | null = null;
private _headers: types.Headers;
private _postData: Buffer | null;

static from(request: RequestChannel): Request {
return (request as any)._object;
Expand All @@ -64,6 +65,7 @@ export class Request extends ChannelOwner<RequestChannel, RequestInitializer> {
if (this._redirectedFrom)
this._redirectedFrom._redirectedTo = this;
this._headers = headersArrayToObject(initializer.headers);
this._postData = initializer.postData ? Buffer.from(initializer.postData, 'base64') : null;
}

url(): string {
Expand All @@ -79,11 +81,16 @@ export class Request extends ChannelOwner<RequestChannel, RequestInitializer> {
}

postData(): string | null {
return this._initializer.postData || null;
return this._postData ? this._postData.toString('utf8') : null;
}

postDataBuffer(): Buffer | null {
return this._postData;
}

postDataJSON(): Object | null {
if (!this._initializer.postData)
const postData = this.postData();
if (!postData)
return null;

const contentType = this.headers()['content-type'];
Expand All @@ -92,13 +99,13 @@ export class Request extends ChannelOwner<RequestChannel, RequestInitializer> {

if (contentType === 'application/x-www-form-urlencoded') {
const entries: Record<string, string> = {};
const parsed = new URLSearchParams(this._initializer.postData);
const parsed = new URLSearchParams(postData);
for (const [k, v] of parsed.entries())
entries[k] = v;
return entries;
}

return JSON.parse(this._initializer.postData);
return JSON.parse(postData);
}

headers(): types.Headers {
Expand Down
2 changes: 1 addition & 1 deletion src/rpc/protocol.pdl
Original file line number Diff line number Diff line change
Expand Up @@ -1291,7 +1291,7 @@ interface Request
url: string
resourceType: string
method: string
postData?: string
postData?: binary
headers: object[]
name: string
value: string
Expand Down
4 changes: 2 additions & 2 deletions src/rpc/server/networkDispatchers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,13 +33,13 @@ export class RequestDispatcher extends Dispatcher<Request, RequestInitializer> i
}

private constructor(scope: DispatcherScope, request: Request) {
const postData = request.postData();
const postData = request.postDataBuffer();
super(scope, request, 'Request', {
frame: FrameDispatcher.from(scope, request.frame()),
url: request.url(),
resourceType: request.resourceType(),
method: request.method(),
postData: postData === null ? undefined : postData,
postData: postData === null ? undefined : postData.toString('base64'),
headers: headersObjectToArray(request.headers()),
isNavigationRequest: request.isNavigationRequest(),
redirectedFrom: RequestDispatcher.fromNullable(scope, request.redirectedFrom()),
Expand Down
5 changes: 4 additions & 1 deletion src/webkit/wkInterceptableRequest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,8 +53,11 @@ export class WKInterceptableRequest implements network.RouteDelegate {
this._requestId = event.requestId;
this._allowInterception = allowInterception;
const resourceType = event.type ? event.type.toLowerCase() : (redirectedFrom ? redirectedFrom.resourceType() : 'other');
let postDataBuffer = null;
if (event.request.postData)
postDataBuffer = Buffer.from(event.request.postData, 'binary');
this.request = new network.Request(allowInterception ? this : null, frame, redirectedFrom, documentId, event.request.url,
resourceType, event.request.method, event.request.postData || null, headersObject(event.request.headers));
resourceType, event.request.method, postDataBuffer, headersObject(event.request.headers));
this._interceptedPromise = new Promise(f => this._interceptedCallback = f);
}

Expand Down
34 changes: 29 additions & 5 deletions test/network.jest.js
Original file line number Diff line number Diff line change
Expand Up @@ -133,13 +133,39 @@ describe('Request.postData', function() {
expect(request).toBeTruthy();
expect(request.postData()).toBe('{"foo":"bar"}');
});
it('should work with binary', async({page, server}) => {
await page.goto(server.EMPTY_PAGE);
server.setRoute('/post', (req, res) => res.end());
let request = null;
page.on('request', r => request = r);
await page.evaluate(async () => {
await fetch('./post', { method: 'POST', body: new Uint8Array(Array.from(Array(256).keys())) })
});
expect(request).toBeTruthy();
const buffer = request.postDataBuffer();
expect(buffer.length).toBe(256);
for (let i = 0; i < 256; ++i)
expect(buffer[i]).toBe(i);
});
it('should work with binary and interception', async({page, server}) => {
await page.goto(server.EMPTY_PAGE);
server.setRoute('/post', (req, res) => res.end());
let request = null;
await page.route('/post', route => route.continue());
page.on('request', r => request = r);
await page.evaluate(async () => {
await fetch('./post', { method: 'POST', body: new Uint8Array(Array.from(Array(256).keys())) })
});
expect(request).toBeTruthy();
const buffer = request.postDataBuffer();
expect(buffer.length).toBe(256);
for (let i = 0; i < 256; ++i)
expect(buffer[i]).toBe(i);
});
it('should be |undefined| when there is no post data', async({page, server}) => {
const response = await page.goto(server.EMPTY_PAGE);
expect(response.request().postData()).toBe(null);
});
});

describe('Request.postDataJSON', function () {
it('should parse the JSON payload', async ({ page, server }) => {
await page.goto(server.EMPTY_PAGE);
server.setRoute('/post', (req, res) => res.end());
Expand All @@ -149,7 +175,6 @@ describe('Request.postDataJSON', function () {
expect(request).toBeTruthy();
expect(request.postDataJSON()).toEqual({ "foo": "bar" });
});

it('should parse the data if content-type is application/x-www-form-urlencoded', async({page, server}) => {
await page.goto(server.EMPTY_PAGE);
server.setRoute('/post', (req, res) => res.end());
Expand All @@ -160,7 +185,6 @@ describe('Request.postDataJSON', function () {
expect(request).toBeTruthy();
expect(request.postDataJSON()).toEqual({'foo':'bar','baz':'123'});
})

it('should be |undefined| when there is no post data', async ({ page, server }) => {
const response = await page.goto(server.EMPTY_PAGE);
expect(response.request().postDataJSON()).toBe(null);
Expand Down

0 comments on commit 80c0711

Please sign in to comment.