forked from bahmutov/cypress-hyperapp-unit-test
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtodo-list-spec.js
81 lines (72 loc) · 1.74 KB
/
todo-list-spec.js
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
/// <reference types="cypress" />
import { h } from 'hyperapp'
import { TodoList } from '../../components/todo-list'
import { toggle } from '../../actions'
import { mount } from '../../src'
/* eslint-env mocha */
describe('TodoList', () => {
// let's test TodoList component by giving it simple
// state and a toggle action
// initial state
const state = {
todos: [
{
id: 1,
title: 'Try HyperApp',
completed: true
},
{
id: 2,
title: 'Test using Cypress',
completed: true
},
{
id: 3,
title: 'Profit!!!',
completed: false
}
]
}
// reuse toggle action in the test - why not?
const actions = {
toggle
}
const view = (state, actions) =>
// renders TodoList component, passing
// current state and actions
h(TodoList, {
todos: state.todos,
toggle: actions.toggle
})
beforeEach(() => {
mount(state, actions, view)
})
it('shows todo', () => {
cy.contains('Todo')
})
it('has expected number of todos', () => {
cy.get('.todo-list .todo').should('have.length', 3)
})
it('has 2 completed todos', () => {
cy.get('.todo-list .todo.done').should('have.length', 2)
})
it('is done with testing', () => {
cy
.contains('.todo-list .todo', 'Test using Cypress')
.find('.toggle')
.should('be.checked')
})
it('does not have profit yet', () => {
cy
.contains('.todo-list .todo', 'Profit')
.find('.toggle')
.should('not.be.checked')
})
it('completes todo by clicking', () => {
cy.contains('.todo-list .todo', 'Profit').click()
cy
.contains('.todo-list .todo', 'Profit')
.find('.toggle')
.should('be.checked')
})
})