diff --git a/modules/twinkleblock.js b/modules/twinkleblock.js index 218e7556c..f4342aa1c 100644 --- a/modules/twinkleblock.js +++ b/modules/twinkleblock.js @@ -1902,13 +1902,14 @@ Twinkle.block.callback.issue_template = function twinkleblockCallbackIssueTempla // "talk page" of an IP range (which does not exist) const userTalkPage = 'User_talk:' + mw.config.get('wgRelevantUserName'); - const params = $.extend(formData, { - messageData: Twinkle.block.blockPresetsInfo[formData.template], - reason: Twinkle.block.field_template_options.block_reason, - disabletalk: Twinkle.block.field_template_options.notalk, - noemail: Twinkle.block.field_template_options.noemail_template, - nocreate: Twinkle.block.field_template_options.nocreate_template - }); + const params = Twinkle.block.combineFormDataAndFieldTemplateOptions( + formData, + Twinkle.block.blockPresetsInfo[formData.template], + Twinkle.block.field_template_options.block_reason, + Twinkle.block.field_template_options.notalk, + Twinkle.block.field_template_options.noemail_template, + Twinkle.block.field_template_options.nocreate_template + ); Morebits.wiki.actionCompleted.redirect = userTalkPage; Morebits.wiki.actionCompleted.notice = 'Actions complete, loading user talk page in a few seconds'; @@ -1918,6 +1919,16 @@ Twinkle.block.callback.issue_template = function twinkleblockCallbackIssueTempla wikipedia_page.load(Twinkle.block.callback.main); }; +Twinkle.block.combineFormDataAndFieldTemplateOptions = function(formData, messageData, reason, disabletalk, noemail, nocreate) { + return $.extend(formData, { + messageData: messageData, + reason: reason, + disabletalk: disabletalk, + noemail: noemail, + nocreate: nocreate + }); +}; + Twinkle.block.callback.getBlockNoticeWikitext = function(params) { let text = '{{'; const settings = Twinkle.block.blockPresetsInfo[params.template]; diff --git a/tests/jest.setup.js b/tests/jest.setup.js index b3d3c7790..f25aeb8c4 100644 --- a/tests/jest.setup.js +++ b/tests/jest.setup.js @@ -6,6 +6,7 @@ mw.config.set({ require('../morebits.js'); require('../twinkle.js'); +require('../modules/twinkleblock.js'); require('../modules/twinklewarn.js'); require('../modules/twinklexfd.js'); global.Morebits = window.Morebits; diff --git a/tests/twinkleblock.test.js b/tests/twinkleblock.test.js new file mode 100644 index 000000000..732af83da --- /dev/null +++ b/tests/twinkleblock.test.js @@ -0,0 +1,15 @@ +describe('modules/twinkleblock', () => { + describe('combineFormDataAndFieldTemplateOptions', () => { + // https://github.com/wikimedia-gadgets/twinkle/issues/2106 + test('regression test: merging true and undefined should return true', () => { + const formData = {disabletalk: true}; + const messageData = undefined; + const reason = undefined; + const disabletalk = undefined; + const noemail = undefined; + const nocreate = undefined; + const expected = {disabletalk: true}; + expect(Twinkle.block.combineFormDataAndFieldTemplateOptions(formData, messageData, reason, disabletalk, noemail, nocreate)).toStrictEqual(expected); + }); + }); +});