diff --git a/src/common/JSHandle.ts b/src/common/JSHandle.ts index c0ee4070..cbe97e1f 100644 --- a/src/common/JSHandle.ts +++ b/src/common/JSHandle.ts @@ -243,7 +243,7 @@ export class JSHandle { * on the object in page and consequent {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse | JSON.parse} in puppeteer. * **NOTE** The method throws if the referenced object is not stringifiable. */ - async jsonValue(): Promise> { + async jsonValue(): Promise { if (this._remoteObject.objectId) { const response = await this._client.send('Runtime.callFunctionOn', { functionDeclaration: 'function() { return this; }', @@ -251,9 +251,9 @@ export class JSHandle { returnByValue: true, awaitPromise: true, }); - return helper.valueFromRemoteObject(response.result); + return helper.valueFromRemoteObject(response.result) as T; } - return helper.valueFromRemoteObject(this._remoteObject); + return helper.valueFromRemoteObject(this._remoteObject) as T; } /** diff --git a/test/evaluation.spec.ts b/test/evaluation.spec.ts index a2497d9c..e3803d54 100644 --- a/test/evaluation.spec.ts +++ b/test/evaluation.spec.ts @@ -278,7 +278,7 @@ describe('Evaluation specs', function () { const windowHandle = await page.evaluateHandle(() => window); const errorText = await windowHandle - .jsonValue() + .jsonValue() .catch((error_) => error_.message); const error = await page .evaluate<(errorText: string) => Error>((errorText) => { diff --git a/test/jshandle.spec.ts b/test/jshandle.spec.ts index bb135083..7978d4ac 100644 --- a/test/jshandle.spec.ts +++ b/test/jshandle.spec.ts @@ -114,9 +114,26 @@ describe('JSHandle', function () { const { page } = getTestState(); const aHandle = await page.evaluateHandle(() => ({ foo: 'bar' })); - const json = await aHandle.jsonValue(); + const json = await aHandle.jsonValue>(); expect(json).toEqual({ foo: 'bar' }); }); + + it('works with jsonValues that are not objects', async () => { + const { page } = getTestState(); + + const aHandle = await page.evaluateHandle(() => ['a', 'b']); + const json = await aHandle.jsonValue(); + expect(json).toEqual(['a', 'b']); + }); + + it('works with jsonValues that are primitives', async () => { + const { page } = getTestState(); + + const aHandle = await page.evaluateHandle(() => 'foo'); + const json = await aHandle.jsonValue(); + expect(json).toEqual('foo'); + }); + itFailsFirefox('should not work with dates', async () => { const { page } = getTestState();