// Copyright 2024 The Forgejo Authors. All rights reserved. // SPDX-License-Identifier: MIT import {flushPromises, mount} from '@vue/test-utils'; import PullRequestMergeForm from './PullRequestMergeForm.vue'; async function renderMergeForm(branchName) { window.config.pageData.pullRequestMergeForm = { textDeleteBranch: `Delete branch "${branchName}"`, textDoMerge: 'Merge', defaultMergeStyle: 'merge', isPullBranchDeletable: true, canMergeNow: true, mergeStyles: [{ 'name': 'merge', 'allowed': true, 'textDoMerge': 'Merge', 'mergeTitleFieldText': 'Merge PR', 'mergeMessageFieldText': 'Description', 'hideAutoMerge': 'Hide this message', }], }; const mergeform = mount(PullRequestMergeForm); mergeform.get('.merge-button').trigger('click'); await flushPromises(); return mergeform; } test('renders escaped branch name', async () => { let mergeform = await renderMergeForm('evil'); expect(mergeform.get('label[for="delete-branch-after-merge"]').text()).toBe('Delete branch "evil"'); mergeform = await renderMergeForm(''); expect(mergeform.get('label[for="delete-branch-after-merge"]').text()).toBe('Delete branch ""'); });