Browse Source

Add unit and integration test for organisms/ProjectDeletionForm

pull/341/head
Hironsan 5 years ago
parent
commit
a50700e369
4 changed files with 107 additions and 0 deletions
  1. 2
      frontend/components/organisms/ProjectDeletionForm.vue
  2. 0
      frontend/test/integration/.gitkeep
  3. 46
      frontend/test/integration/organisms/ProjectDeletionForm.spec.js
  4. 59
      frontend/test/unit/components/organisms/ProjectDeletionForm.spec.js

2
frontend/components/organisms/ProjectDeletionForm.vue

@ -15,6 +15,7 @@
class="text-capitalize"
text
color="primary"
data-test="cancel-button"
@click="cancel"
>
Cancel
@ -22,6 +23,7 @@
<v-btn
class="text-none"
text
data-test="delete-button"
@click="deleteProject"
>
Yes, delete

0
frontend/test/integration/.gitkeep

46
frontend/test/integration/organisms/ProjectDeletionForm.spec.js

@ -0,0 +1,46 @@
import { mount } from '@vue/test-utils'
import Vue from 'vue'
import Vuetify from 'vuetify'
import ProjectDeletionForm from '@/components/organisms/ProjectDeletionForm'
Vue.use(Vuetify)
describe('ProjectDeletionForm', () => {
const selected = [
{
id: 1,
name: 'CoNLL 2003',
description: 'This is a project for NER.',
guideline: 'Please write annotation guideline.',
users: [
1
],
project_type: 'SequenceLabeling',
image: '/static/assets/images/cats/sequence_labeling.jpg',
updated_at: '2019-07-09T06:19:29.789091Z',
randomize_document_order: false,
resourcetype: 'SequenceLabelingProject'
},
]
const factory = (propsData) => {
return mount(ProjectDeletionForm, {
propsData: {
...propsData
}
})
}
test('emit close event when cancel button is clicked', () => {
const wrapper = factory({ selected })
const button = wrapper.find('[data-test="cancel-button"]')
button.trigger('click')
expect(wrapper.emitted('close')).toBeTruthy()
})
test('emit delete event when delete button is clicked', () => {
const wrapper = factory({ selected })
const button = wrapper.find('[data-test="delete-button"]')
button.trigger('click')
expect(wrapper.emitted('delete')).toBeTruthy()
})
})

59
frontend/test/unit/components/organisms/ProjectDeletionForm.spec.js

@ -0,0 +1,59 @@
import { shallowMount } from '@vue/test-utils'
import Vue from 'vue'
import Vuetify from 'vuetify'
import ProjectDeletionForm from '@/components/organisms/ProjectDeletionForm'
Vue.use(Vuetify)
describe('ProjectDeletionForm', () => {
const selected = [
{
id: 1,
name: 'CoNLL 2003',
description: 'This is a project for NER.',
guideline: 'Please write annotation guideline.',
users: [
1
],
project_type: 'SequenceLabeling',
image: '/static/assets/images/cats/sequence_labeling.jpg',
updated_at: '2019-07-09T06:19:29.789091Z',
randomize_document_order: false,
resourcetype: 'SequenceLabelingProject'
},
]
const factory = (propsData) => {
return shallowMount(ProjectDeletionForm, {
propsData: {
...propsData
}
})
}
test('can receive props', () => {
const wrapper = factory({ selected })
expect(wrapper.props()).toEqual({ selected })
})
test('emit close event', () => {
const wrapper = factory({ selected })
wrapper.vm.cancel(selected)
expect(wrapper.emitted('close')).toBeTruthy()
})
test('emit delete event', () => {
const wrapper = factory({ selected })
wrapper.vm.deleteProject(selected)
expect(wrapper.emitted('delete')).toBeTruthy()
})
test('raise warning when passing no props', () => {
const spy = jest.spyOn(console, 'error')
spy.mockImplementation()
const wrapper = factory()
expect(spy).toBeCalledWith(
expect.stringContaining('[Vue warn]: Missing required prop')
)
spy.mockRestore()
})
})
Loading…
Cancel
Save