Plumb default prompt value to the dialog (#243)
This patch: - plumbs default prompt value to the dialog - enables one more phantom test
This commit is contained in:
parent
53baed6af6
commit
dbac6788ae
@ -76,6 +76,7 @@
|
|||||||
+ [tracing.stop()](#tracingstop)
|
+ [tracing.stop()](#tracingstop)
|
||||||
* [class: Dialog](#class-dialog)
|
* [class: Dialog](#class-dialog)
|
||||||
+ [dialog.accept([promptText])](#dialogacceptprompttext)
|
+ [dialog.accept([promptText])](#dialogacceptprompttext)
|
||||||
|
+ [dialog.defaultValue()](#dialogdefaultvalue)
|
||||||
+ [dialog.dismiss()](#dialogdismiss)
|
+ [dialog.dismiss()](#dialogdismiss)
|
||||||
+ [dialog.message()](#dialogmessage)
|
+ [dialog.message()](#dialogmessage)
|
||||||
+ [dialog.type](#dialogtype)
|
+ [dialog.type](#dialogtype)
|
||||||
@ -901,6 +902,9 @@ browser.newPage().then(async page => {
|
|||||||
- `promptText` <[string]> A text to enter in prompt. Does not cause any effects if the dialog's `type` is not prompt.
|
- `promptText` <[string]> A text to enter in prompt. Does not cause any effects if the dialog's `type` is not prompt.
|
||||||
- returns: <[Promise]> Promise which resolves when the dialog has being accepted.
|
- returns: <[Promise]> Promise which resolves when the dialog has being accepted.
|
||||||
|
|
||||||
|
#### dialog.defaultValue()
|
||||||
|
- returns: <[string]> If dialog is prompt, returns default prompt value. Otherwise, returns empty string.
|
||||||
|
|
||||||
#### dialog.dismiss()
|
#### dialog.dismiss()
|
||||||
- returns: <[Promise]> Promise which resolves when the dialog has being dismissed.
|
- returns: <[Promise]> Promise which resolves when the dialog has being dismissed.
|
||||||
|
|
||||||
|
@ -21,12 +21,14 @@ class Dialog {
|
|||||||
* @param {!Session} client
|
* @param {!Session} client
|
||||||
* @param {!Dialog.Type} type
|
* @param {!Dialog.Type} type
|
||||||
* @param {string} message
|
* @param {string} message
|
||||||
|
* @param {(string|undefined)} defaultValue
|
||||||
*/
|
*/
|
||||||
constructor(client, type, message) {
|
constructor(client, type, message, defaultValue) {
|
||||||
this._client = client;
|
this._client = client;
|
||||||
this.type = type;
|
this.type = type;
|
||||||
this._message = message;
|
this._message = message;
|
||||||
this._handled = false;
|
this._handled = false;
|
||||||
|
this._defaultValue = defaultValue || '';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -36,6 +38,13 @@ class Dialog {
|
|||||||
return this._message;
|
return this._message;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return {string}
|
||||||
|
*/
|
||||||
|
defaultValue() {
|
||||||
|
return this._defaultValue;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {string=} promptText
|
* @param {string=} promptText
|
||||||
* @return {!Promise}
|
* @return {!Promise}
|
||||||
|
@ -237,7 +237,7 @@ class Page extends EventEmitter {
|
|||||||
else if (event.type === 'beforeunload')
|
else if (event.type === 'beforeunload')
|
||||||
dialogType = Dialog.Type.BeforeUnload;
|
dialogType = Dialog.Type.BeforeUnload;
|
||||||
console.assert(dialogType, 'Unknown javascript dialog type: ' + event.type);
|
console.assert(dialogType, 'Unknown javascript dialog type: ' + event.type);
|
||||||
let dialog = new Dialog(this._client, dialogType, event.message);
|
let dialog = new Dialog(this._client, dialogType, event.message, event.defaultPrompt);
|
||||||
this.emit(Page.Events.Dialog, dialog);
|
this.emit(Page.Events.Dialog, dialog);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -58,6 +58,7 @@ class WebPage {
|
|||||||
|
|
||||||
this._onResourceRequestedCallback = undefined;
|
this._onResourceRequestedCallback = undefined;
|
||||||
this._onConfirmCallback = undefined;
|
this._onConfirmCallback = undefined;
|
||||||
|
this._onPromptCallback = undefined;
|
||||||
this._onAlertCallback = undefined;
|
this._onAlertCallback = undefined;
|
||||||
this._onError = noop;
|
this._onError = noop;
|
||||||
|
|
||||||
@ -351,6 +352,22 @@ class WebPage {
|
|||||||
this._onConfirmCallback = handler;
|
this._onConfirmCallback = handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return {(function()|undefined)}
|
||||||
|
*/
|
||||||
|
get onPrompt() {
|
||||||
|
return this._onPromptCallback;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {function()} handler
|
||||||
|
*/
|
||||||
|
set onPrompt(handler) {
|
||||||
|
if (typeof handler !== 'function')
|
||||||
|
handler = undefined;
|
||||||
|
this._onPromptCallback = handler;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return {(function()|undefined)}
|
* @return {(function()|undefined)}
|
||||||
*/
|
*/
|
||||||
@ -377,6 +394,9 @@ class WebPage {
|
|||||||
} else if (dialog.type === 'confirm' && this._onConfirmCallback) {
|
} else if (dialog.type === 'confirm' && this._onConfirmCallback) {
|
||||||
let result = this._onConfirmCallback.call(null, dialog.message());
|
let result = this._onConfirmCallback.call(null, dialog.message());
|
||||||
await(result ? dialog.accept() : dialog.dismiss());
|
await(result ? dialog.accept() : dialog.dismiss());
|
||||||
|
} else if (dialog.type === 'prompt' && this._onPromptCallback) {
|
||||||
|
let result = this._onPromptCallback.call(null, dialog.message(), dialog.defaultValue());
|
||||||
|
await(result ? dialog.accept(result) : dialog.dismiss());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -818,6 +818,7 @@ describe('Page', function() {
|
|||||||
it('should fire', SX(async function() {
|
it('should fire', SX(async function() {
|
||||||
page.on('dialog', dialog => {
|
page.on('dialog', dialog => {
|
||||||
expect(dialog.type).toBe('alert');
|
expect(dialog.type).toBe('alert');
|
||||||
|
expect(dialog.defaultValue()).toBe('');
|
||||||
expect(dialog.message()).toBe('yo');
|
expect(dialog.message()).toBe('yo');
|
||||||
dialog.accept();
|
dialog.accept();
|
||||||
});
|
});
|
||||||
@ -826,10 +827,11 @@ describe('Page', function() {
|
|||||||
it('should allow accepting prompts', SX(async function() {
|
it('should allow accepting prompts', SX(async function() {
|
||||||
page.on('dialog', dialog => {
|
page.on('dialog', dialog => {
|
||||||
expect(dialog.type).toBe('prompt');
|
expect(dialog.type).toBe('prompt');
|
||||||
|
expect(dialog.defaultValue()).toBe('yes.');
|
||||||
expect(dialog.message()).toBe('question?');
|
expect(dialog.message()).toBe('question?');
|
||||||
dialog.accept('answer!');
|
dialog.accept('answer!');
|
||||||
});
|
});
|
||||||
let result = await page.evaluate(() => prompt('question?'));
|
let result = await page.evaluate(() => prompt('question?', 'yes.'));
|
||||||
expect(result).toBe('answer!');
|
expect(result).toBe('answer!');
|
||||||
}));
|
}));
|
||||||
it('should dismiss the prompt', SX(async function() {
|
it('should dismiss the prompt', SX(async function() {
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
//! unsupported
|
|
||||||
test(function () {
|
test(function () {
|
||||||
var page = require('webpage').create();
|
var page = require('webpage').create();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user