Decouple tests

This commit is contained in:
Daniel Lugo 2021-09-16 17:10:05 -04:00
parent 3f8faa4daa
commit 1c16d44234

View file

@ -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
describe('gun smith', () => {
// eslint-disable-next-line jest/no-hooks
beforeEach(() => {
instance = Gun({
const createInstance = () =>
Gun({
axe: false,
multicast: false,
file: './test-radata/' + words({ exactly: 2 }).join('-')
})
})
// eslint-disable-next-line jest/no-hooks
afterAll(() => {
if (instance) {
instance.reforge()
}
})
describe('gun smith', () => {
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 => {
.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()
})
})