-
Notifications
You must be signed in to change notification settings - Fork 12
/
storageAPI.js
126 lines (109 loc) · 3.86 KB
/
storageAPI.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
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
121
122
123
124
125
126
// @flow
import request from 'supertest'
import makeServer from '../../server-test'
import { getToken } from '../../__util__/'
import type { UserRecord } from '../../../imports/types'
import UserDBPrivate from '../../db/mongo/user-privat-provider'
jest.setTimeout(30000)
describe('storageAPI', () => {
let server
beforeAll(done => {
server = makeServer(done)
})
afterAll(done => {
server.close(err => {
console.log({ err })
done()
})
})
test('/user/add creds', async () => {
const token = await getToken(server)
const user: UserRecord = {
identifier: '0x7ac080f6607405705aed79675789701a48c76f55',
email: 'useraddtest@gooddollar.org' // required for mautic create contact
}
let res = await request(server)
.post('/user/add')
.set('Authorization', `Bearer ${token}`)
.send({ user })
expect(res).toMatchObject({ status: 200, body: { ok: 1 } })
})
test('/user/add with duplicated creds - should fail with error', async () => {
const token = await getToken(server)
const user: UserRecord = {
identifier: '0x7ac080f6607405705aed79675789701a48c76f55',
email: 'useraddtest@gooddollar.org' // required for mautic create contact
}
let res = await request(server)
.post('/user/add')
.set('Authorization', `Bearer ${token}`)
.send({ user })
expect(res).toMatchObject({
status: 400,
body: { message: 'You cannot create more than 1 account with the same credentials' }
})
})
test('/user/add creds dont update mauticId', async () => {
const token = await getToken(server)
const mauticId = '111'
await UserDBPrivate.updateUser({
identifier: '0x7ac080f6607405705aed79675789701a48c76f55',
mauticId: mauticId,
createdDate: null
})
const user: UserRecord = {
identifier: '0x7ac080f6607405705aed79675789701a48c76f55',
email: 'useraddtest@gooddollar.org' // required for mautic create contact
}
let res = await request(server)
.post('/user/add')
.set('Authorization', `Bearer ${token}`)
.send({ user })
expect(res).toMatchObject({ status: 200, body: { ok: 1 } })
const mauticIdAfterAddUser = await UserDBPrivate.getUserField(
'0x7ac080f6607405705aed79675789701a48c76f55',
'mauticId'
)
expect(mauticIdAfterAddUser === mauticId).toBeTruthy()
})
test('/user/add false creds', async () => {
const token = await getToken(server)
const user: UserRecord = { identifier: '0x7ac080f6607405705aed79675789701a48c76f56' }
let res = await request(server)
.post('/user/add')
.set('Authorization', `Bearer ${token}`)
.send({ user })
expect(res).toMatchObject({ status: 400 })
})
test('/user/delete with zoomId and bad signature', async () => {
const token = await getToken(server)
let res = await request(server)
.post('/user/delete')
.set('Authorization', `Bearer ${token}`)
.send({
zoomId: 'DEc4f150b719957a2dD434C48Dff9Bc57466e764',
zoomSignature: 'Bad signature'
})
expect(res).toMatchObject({ status: 400 })
})
test('/user/delete without zoomId ', async () => {
const token = await getToken(server)
let res = await request(server)
.post('/user/delete')
.set('Authorization', `Bearer ${token}`)
.send()
expect(res).toMatchObject({ status: 200 })
})
test('/user/delete with zoomId and good signature', async () => {
const token = await getToken(server)
let res = await request(server)
.post('/user/delete')
.set('Authorization', `Bearer ${token}`)
.send({
zoomId: 'DEc4f150b719957a2dD434C48Dff9Bc57466e764',
zoomSignature:
'0xda0c23e71a589adfb4f29b021549371f44de105678284e4d9acecb8b670a35c63bd1e200ae9293dcca0064ae87438094df7e7db3268c47e638cdffdfe8c386a11c'
})
expect(res).toMatchObject({ status: 200 })
})
})