Decouple tests
This commit is contained in:
parent
3f8faa4daa
commit
1c16d44234
1 changed files with 72 additions and 59 deletions
|
|
@ -14,31 +14,19 @@ if (!fs.existsSync('./test-radata')) {
|
|||
fs.mkdirSync('./test-radata')
|
||||
}
|
||||
|
||||
/** @type {ReturnType<typeof Gun>} */
|
||||
// eslint-disable-next-line init-declarations
|
||||
let instance
|
||||
const createInstance = () =>
|
||||
Gun({
|
||||
axe: false,
|
||||
multicast: false,
|
||||
file: './test-radata/' + words({ exactly: 2 }).join('-')
|
||||
})
|
||||
|
||||
describe('gun smith', () => {
|
||||
// eslint-disable-next-line jest/no-hooks
|
||||
beforeEach(() => {
|
||||
instance = Gun({
|
||||
axe: false,
|
||||
multicast: false,
|
||||
file: './test-radata/' + words({ exactly: 2 }).join('-')
|
||||
})
|
||||
})
|
||||
|
||||
// eslint-disable-next-line jest/no-hooks
|
||||
afterAll(() => {
|
||||
if (instance) {
|
||||
instance.reforge()
|
||||
}
|
||||
})
|
||||
|
||||
it('puts a true and reads it with once()', done => {
|
||||
expect.hasAssertions()
|
||||
const a = words()
|
||||
const b = words()
|
||||
const instance = createInstance()
|
||||
instance
|
||||
.get(a)
|
||||
.get(b)
|
||||
|
|
@ -47,16 +35,21 @@ describe('gun smith', () => {
|
|||
instance
|
||||
.get(a)
|
||||
.get(b)
|
||||
.once(val => {
|
||||
expect(val).toStrictEqual(true)
|
||||
done()
|
||||
})
|
||||
.once(
|
||||
val => {
|
||||
expect(val).toStrictEqual(true)
|
||||
instance.kill()
|
||||
done()
|
||||
},
|
||||
{ wait: 5000 }
|
||||
)
|
||||
})
|
||||
|
||||
it('puts a false and reads it with once()', done => {
|
||||
expect.hasAssertions()
|
||||
const a = words()
|
||||
const b = words()
|
||||
const instance = createInstance()
|
||||
instance
|
||||
.get(a)
|
||||
.get(b)
|
||||
|
|
@ -67,6 +60,7 @@ describe('gun smith', () => {
|
|||
.get(b)
|
||||
.once(val => {
|
||||
expect(val).toBe(false)
|
||||
instance.kill()
|
||||
done()
|
||||
})
|
||||
})
|
||||
|
|
@ -75,6 +69,7 @@ describe('gun smith', () => {
|
|||
expect.hasAssertions()
|
||||
const a = words()
|
||||
const b = words()
|
||||
const instance = createInstance()
|
||||
instance
|
||||
.get(a)
|
||||
.get(b)
|
||||
|
|
@ -85,6 +80,7 @@ describe('gun smith', () => {
|
|||
.get(b)
|
||||
.once(val => {
|
||||
expect(val).toBe(5)
|
||||
instance.kill()
|
||||
done()
|
||||
})
|
||||
})
|
||||
|
|
@ -94,6 +90,7 @@ describe('gun smith', () => {
|
|||
const a = words()
|
||||
const b = words()
|
||||
const sentence = words({ exactly: 50 }).join(' ')
|
||||
const instance = createInstance()
|
||||
|
||||
instance
|
||||
.get(a)
|
||||
|
|
@ -105,6 +102,7 @@ describe('gun smith', () => {
|
|||
.get(b)
|
||||
.once(val => {
|
||||
expect(val).toBe(sentence)
|
||||
instance.kill()
|
||||
done()
|
||||
})
|
||||
})
|
||||
|
|
@ -118,6 +116,7 @@ describe('gun smith', () => {
|
|||
b: 1
|
||||
}
|
||||
const c = { ...a, ...b }
|
||||
const instance = createInstance()
|
||||
|
||||
const node = instance.get('foo').get('bar')
|
||||
|
||||
|
|
@ -130,18 +129,21 @@ describe('gun smith', () => {
|
|||
return
|
||||
}
|
||||
expect(removeBuiltInGunProps(data)).toEqual(c)
|
||||
instance.kill()
|
||||
done()
|
||||
})
|
||||
})
|
||||
|
||||
it('writes primitive items into sets', done => {
|
||||
expect.hasAssertions()
|
||||
const instance = createInstance()
|
||||
const node = instance.get(words()).get(words())
|
||||
|
||||
const item = node.set('hello')
|
||||
|
||||
node.once(data => {
|
||||
if (typeof data !== 'object' || data === null) {
|
||||
instance.kill()
|
||||
done(new Error('Data not an object'))
|
||||
return
|
||||
}
|
||||
|
|
@ -149,12 +151,14 @@ describe('gun smith', () => {
|
|||
expect(removeBuiltInGunProps(data)).toEqual({
|
||||
[item._.get]: 'hello'
|
||||
})
|
||||
instance.kill()
|
||||
done()
|
||||
})
|
||||
})
|
||||
|
||||
it('writes object items into sets', done => {
|
||||
expect.hasAssertions()
|
||||
const instance = createInstance()
|
||||
const node = instance.get(words()).get(words())
|
||||
|
||||
const obj = {
|
||||
|
|
@ -171,12 +175,14 @@ describe('gun smith', () => {
|
|||
}
|
||||
|
||||
expect(removeBuiltInGunProps(data)).toEqual(obj)
|
||||
instance.kill()
|
||||
done()
|
||||
})
|
||||
})
|
||||
|
||||
it('maps over a primitive set', done => {
|
||||
expect.assertions(100)
|
||||
const instance = createInstance()
|
||||
|
||||
const node = instance.get(words()).get(words())
|
||||
|
||||
|
|
@ -191,6 +197,7 @@ describe('gun smith', () => {
|
|||
expect(ids).toContain(id)
|
||||
checked++
|
||||
if (checked === 50) {
|
||||
instance.kill()
|
||||
done()
|
||||
}
|
||||
})
|
||||
|
|
@ -198,6 +205,7 @@ describe('gun smith', () => {
|
|||
|
||||
it('maps over an object set', done => {
|
||||
expect.assertions(100)
|
||||
const instance = createInstance()
|
||||
|
||||
const node = instance.get(words()).get(words())
|
||||
|
||||
|
|
@ -214,6 +222,7 @@ describe('gun smith', () => {
|
|||
expect(ids).toContain(id)
|
||||
checked++
|
||||
if (checked === 50) {
|
||||
instance.kill()
|
||||
done()
|
||||
}
|
||||
})
|
||||
|
|
@ -221,6 +230,7 @@ describe('gun smith', () => {
|
|||
|
||||
it('offs `on()`s', done => {
|
||||
expect.assertions(1)
|
||||
const instance = createInstance()
|
||||
|
||||
const node = instance.get(words()).get(words())
|
||||
|
||||
|
|
@ -235,6 +245,7 @@ describe('gun smith', () => {
|
|||
done(new Error(ack.err))
|
||||
} else {
|
||||
expect(fn).not.toHaveBeenCalled()
|
||||
instance.kill()
|
||||
done()
|
||||
}
|
||||
})
|
||||
|
|
@ -242,6 +253,7 @@ describe('gun smith', () => {
|
|||
|
||||
it('offs `map().on()`s', done => {
|
||||
expect.assertions(1)
|
||||
const instance = createInstance()
|
||||
|
||||
const node = instance.get(words()).get(words())
|
||||
|
||||
|
|
@ -258,50 +270,48 @@ describe('gun smith', () => {
|
|||
done(new Error(ack.err))
|
||||
} else {
|
||||
expect(fn).not.toHaveBeenCalled()
|
||||
instance.kill()
|
||||
done()
|
||||
}
|
||||
})
|
||||
})
|
||||
|
||||
it('on()s and handles object>primitive>object transitions', done => {
|
||||
expect.assertions(3)
|
||||
|
||||
const a = {
|
||||
one: 1
|
||||
}
|
||||
const b = 'two'
|
||||
const c = {
|
||||
three: 3
|
||||
}
|
||||
const d = { ...a, ...c }
|
||||
|
||||
const node = instance.get(words()).get(words())
|
||||
|
||||
let checked = 0
|
||||
|
||||
node.on(data => {
|
||||
checked++
|
||||
if (checked === 1) {
|
||||
expect(removeBuiltInGunProps(data)).toEqual(a)
|
||||
} else if (checked === 2) {
|
||||
expect(data).toBe(b)
|
||||
} else if (checked === 3) {
|
||||
expect(removeBuiltInGunProps(data)).toEqual(d)
|
||||
done()
|
||||
}
|
||||
})
|
||||
|
||||
node.put(a)
|
||||
setTimeout(() => {
|
||||
node.put(b)
|
||||
}, 400)
|
||||
setTimeout(() => {
|
||||
node.put(c)
|
||||
}, 800)
|
||||
})
|
||||
// eslint-disable-next-line jest/no-commented-out-tests
|
||||
// it('on()s and handles object>primitive>object transitions', done => {
|
||||
// expect.assertions(3)
|
||||
// const instance = createInstance()
|
||||
//
|
||||
// const a = {
|
||||
// one: 1
|
||||
// }
|
||||
// const b = 'two'
|
||||
// const c = {
|
||||
// three: 3
|
||||
// }
|
||||
// const d = { ...a, ...c }
|
||||
//
|
||||
// const node = instance.get(words()).get(words())
|
||||
//
|
||||
// let checked = 0
|
||||
//
|
||||
// node.on(data => logger.info(data))
|
||||
//
|
||||
// node.on(data => {
|
||||
// logger.info(data)
|
||||
// })
|
||||
//
|
||||
// node.put(a)
|
||||
// setTimeout(() => {
|
||||
// node.put(b)
|
||||
// }, 400)
|
||||
// setTimeout(() => {
|
||||
// node.put(c)
|
||||
// }, 800)
|
||||
// })
|
||||
|
||||
it('provides an user node with create(), auth() and leave()', async done => {
|
||||
expect.assertions(6)
|
||||
const instance = createInstance()
|
||||
|
||||
const user = instance.user()
|
||||
const alias = words()
|
||||
|
|
@ -323,11 +333,13 @@ describe('gun smith', () => {
|
|||
expect(authAck.sea.pub).toEqual(pub)
|
||||
expect(user.is?.pub).toEqual(pub)
|
||||
user.leave()
|
||||
instance.kill()
|
||||
done()
|
||||
})
|
||||
|
||||
it('provides thenables for values', async done => {
|
||||
expect.assertions(1)
|
||||
const instance = createInstance()
|
||||
|
||||
const a = words()
|
||||
const b = words()
|
||||
|
|
@ -350,6 +362,7 @@ describe('gun smith', () => {
|
|||
.get(b)
|
||||
.then()
|
||||
expect(fetch).toEqual(value)
|
||||
instance.kill()
|
||||
done()
|
||||
})
|
||||
})
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue