Welcome to mirror list, hosted at ThFree Co, Russian Federation.

TextEditor.spec.js « components « unit « tests « src - github.com/nextcloud/mail.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 2501f57a7c1ae3516926b9f676207be39e1a8f59 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/*
 * @copyright 2022 Christoph Wurst <christoph@winzerhof-wurst.at>
 *
 * @author 2022 Christoph Wurst <christoph@winzerhof-wurst.at>
 *
 * @license AGPL-3.0-or-later
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

import {createLocalVue, shallowMount} from '@vue/test-utils'
import Vue from 'vue'
import Vuex from 'vuex'

import Nextcloud from '../../../mixins/Nextcloud'
import TextEditor from '../../../components/TextEditor'
import VirtualTestEditor from '../../virtualtesteditor'
import ParagraphPlugin from '@ckeditor/ckeditor5-paragraph/src/paragraph'
import MailPlugin from '../../../ckeditor/mail/MailPlugin'

const localVue = createLocalVue()

localVue.use(Vuex)
localVue.mixin(Nextcloud)

describe('TextEditor', () => {

	it('shallow mounts', async() => {
		const wrapper = shallowMount(TextEditor, {
			localVue,
			propsData: {
				value: 'bonjour',
				bus: new Vue(),
			},
		})
	})

	it('throw when editor not ready', async() => {
		const wrapper = shallowMount(TextEditor, {
			localVue,
			propsData: {
				value: 'bonjour',
				bus: new Vue(),
			},
		})

		const error = new Error(
			'Impossible to execute a command before editor is ready.')
		expect(() => wrapper.vm.editorExecute('insertSignature', {})).
			toThrowError(error)
	})

	it('emit event on input', async() => {
		const wrapper = shallowMount(TextEditor, {
			localVue,
			propsData: {
				value: 'bonjour',
				bus: new Vue(),
			},
		})

		wrapper.vm.onEditorInput('bonjour bonjour')

		expect(wrapper.emitted().input[0]).toBeTruthy()
		expect(wrapper.emitted().input[0]).toEqual(['bonjour bonjour'])
	})

	it('emit event on ready', async() => {
		const wrapper = shallowMount(TextEditor, {
			localVue,
			propsData: {
				value: 'bonjour',
				bus: new Vue(),
			},
		})

		const editor = await VirtualTestEditor.create({
			initialData: '<p>bonjour bonjour</p>',
			plugins: [ParagraphPlugin],
		})

		wrapper.vm.onEditorReady(editor)

		expect(wrapper.emitted().ready[0]).toBeTruthy()
	})

	it('register conversion to add margin: 0px to every <p> element',
		async() => {
			const wrapper = shallowMount(TextEditor, {
				localVue,
				propsData: {
					value: '',
					bus: new Vue(),
				},
			})

			const editor = await VirtualTestEditor.create({
				initialData: '<p>bonjour bonjour</p>',
				plugins: [ParagraphPlugin, MailPlugin],
			})

			wrapper.vm.onEditorReady(editor)

			expect(wrapper.emitted().ready[0]).toBeTruthy()
			expect(wrapper.emitted().ready[0][0].getData()).
				toEqual('<p style="margin:0;">bonjour bonjour</p>')
		})

})