1
1
mirror of https://github.com/leon-ai/leon.git synced 2025-01-02 21:56:57 +03:00
leon/test/unit/server/core/server.spec.js

115 lines
2.9 KiB
JavaScript
Raw Normal View History

2019-02-10 15:26:50 +03:00
import net from 'net'
import { EventEmitter } from 'events'
import Server from '@/core/server'
describe('server', () => {
describe('constructor()', () => {
test('creates a new instance of Server', () => {
const server = new Server()
expect(server).toBeInstanceOf(Server)
expect(server.brain).toBeEmpty()
2019-02-10 15:26:50 +03:00
})
})
describe('init()', () => {
test('uses default language if there is an unsupported one', async () => {
const server = new Server()
server.bootstrap = jest.fn() // Need to mock bootstrap method to not continue the init
2019-02-10 15:26:50 +03:00
process.env.LEON_LANG = 'fake-lang'
await server.init()
2019-02-10 15:26:50 +03:00
expect(process.env.LEON_LANG).toBe('en-US')
})
})
describe('bootstrap()', () => {
test('initializes HTTP server', async () => {
const server = new Server()
2019-02-10 15:26:50 +03:00
await server.bootstrap()
expect(server.httpServer).not.toBeEmpty()
2021-04-02 14:02:37 +03:00
await server.httpServer.close()
2019-02-10 15:26:50 +03:00
})
})
describe('listen()', () => {
test('listens port already in use', async () => {
const fakeServer = net.createServer()
fakeServer.once('error', (err) => {
2019-02-10 15:26:50 +03:00
expect(err.code).toBe('EADDRINUSE')
fakeServer.close()
2019-02-10 15:26:50 +03:00
})
const server = new Server()
await server.init()
fakeServer.listen(process.env.LEON_PORT)
2021-04-02 14:02:37 +03:00
await server.httpServer.close()
})
test('listens for request', async () => {
const server = new Server()
console.log = jest.fn()
await server.listen(process.env.LEON_PORT)
expect(console.log.mock.calls[0][1].indexOf(process.env.LEON_PORT)).not.toBe(-1)
2019-02-10 15:26:50 +03:00
})
})
describe('connection()', () => {
test('initializes main nodes', async (done) => {
const server = new Server()
await server.init()
2019-02-10 15:26:50 +03:00
// Mock the WebSocket with an EventEmitter
const ee = new EventEmitter()
ee.broadcast = { emit: jest.fn() }
console.log = jest.fn()
await server.connection(ee)
2019-02-10 15:26:50 +03:00
expect(console.log.mock.calls[0][1]).toBe('CLIENT')
console.log = jest.fn()
ee.emit('init', 'hotword-node')
console.log = jest.fn()
ee.emit('hotword-detected', { })
expect(console.log.mock.calls[0][1]).toBe('SOCKET')
console.log = jest.fn()
2019-02-10 15:26:50 +03:00
2021-04-02 14:02:37 +03:00
ee.emit('init', 'jest')
expect(server.brain).not.toBeEmpty()
expect(server.nlu).not.toBeEmpty()
expect(server.asr).not.toBeEmpty()
2019-02-10 15:26:50 +03:00
setTimeout(() => {
2021-04-02 14:02:37 +03:00
ee.emit('query', { client: 'jest', value: 'Hello' })
}, 50)
setTimeout(() => {
2021-12-27 12:09:12 +03:00
expect(console.log.mock.calls[26][1]).toBe('Query found')
2021-04-02 14:02:37 +03:00
console.log = jest.fn()
}, 100)
setTimeout(() => {
ee.emit('recognize', 'blob')
}, 150)
setTimeout(async () => {
2021-04-02 14:02:37 +03:00
expect(console.log.mock.calls[0][1]).toBe('ASR')
2019-02-10 15:26:50 +03:00
console.log = jest.fn()
await server.httpServer.close()
2019-02-10 15:26:50 +03:00
done()
2021-04-02 14:02:37 +03:00
}, 200)
2019-02-10 15:26:50 +03:00
})
})
})