2018-05-13 16:50:16 -04:00
|
|
|
/* eslint-env mocha */
|
2015-10-01 20:02:54 -04:00
|
|
|
|
2018-05-13 16:50:16 -04:00
|
|
|
const mc = require('../')
|
|
|
|
const assert = require('power-assert')
|
2017-05-09 20:49:13 -04:00
|
|
|
|
2018-09-24 16:07:34 -04:00
|
|
|
const { firstVersion, lastVersion } = require('./common/parallel')
|
2015-10-01 20:02:54 -04:00
|
|
|
|
2018-05-13 16:50:16 -04:00
|
|
|
mc.supportedVersions.forEach(function (supportedVersion, i) {
|
|
|
|
if (!(i >= firstVersion && i <= lastVersion)) { return }
|
|
|
|
|
|
|
|
const PORT = Math.round(30000 + Math.random() * 20000)
|
|
|
|
const mcData = require('minecraft-data')(supportedVersion)
|
|
|
|
const version = mcData.version
|
|
|
|
|
|
|
|
describe('mc-server ' + version.minecraftVersion, function () {
|
|
|
|
this.timeout(5000)
|
|
|
|
it('starts listening and shuts down cleanly', function (done) {
|
2017-07-13 08:03:52 -04:00
|
|
|
const server = mc.createServer({
|
2015-10-01 20:02:54 -04:00
|
|
|
'online-mode': false,
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
let listening = false
|
|
|
|
server.on('listening', function () {
|
|
|
|
listening = true
|
|
|
|
server.close()
|
|
|
|
})
|
|
|
|
server.on('close', function () {
|
|
|
|
assert.ok(listening)
|
|
|
|
done()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
it('kicks clients that do not log in', function (done) {
|
2017-07-13 08:03:52 -04:00
|
|
|
const server = mc.createServer({
|
2015-10-01 20:02:54 -04:00
|
|
|
'online-mode': false,
|
|
|
|
kickTimeout: 100,
|
|
|
|
checkTimeoutInterval: 10,
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
let count = 2
|
|
|
|
server.on('connection', function (client) {
|
|
|
|
client.on('end', function (reason) {
|
|
|
|
assert.strictEqual(reason, '{"text":"LoginTimeout"}')
|
|
|
|
server.close()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
server.on('close', function () {
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
server.on('listening', function () {
|
|
|
|
const client = new mc.Client(false, version.minecraftVersion)
|
|
|
|
client.on('end', function () {
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
client.connect(PORT, '127.0.0.1')
|
|
|
|
})
|
2015-10-01 20:02:54 -04:00
|
|
|
|
2018-05-13 16:50:16 -04:00
|
|
|
function resolve () {
|
|
|
|
count -= 1
|
|
|
|
if (count <= 0) done()
|
2015-10-01 20:02:54 -04:00
|
|
|
}
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
|
|
|
it('kicks clients that do not send keepalive packets', function (done) {
|
2017-07-13 08:03:52 -04:00
|
|
|
const server = mc.createServer({
|
2015-10-01 20:02:54 -04:00
|
|
|
'online-mode': false,
|
|
|
|
kickTimeout: 100,
|
|
|
|
checkTimeoutInterval: 10,
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
let count = 2
|
|
|
|
server.on('connection', function (client) {
|
|
|
|
client.on('end', function (reason) {
|
|
|
|
assert.strictEqual(reason, '{"text":"KeepAliveTimeout"}')
|
|
|
|
server.close()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
server.on('close', function () {
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
server.on('listening', function () {
|
2017-07-13 08:03:52 -04:00
|
|
|
const client = mc.createClient({
|
2015-10-01 20:02:54 -04:00
|
|
|
username: 'superpants',
|
|
|
|
host: '127.0.0.1',
|
2016-02-23 13:37:47 -05:00
|
|
|
port: PORT,
|
2015-10-01 20:02:54 -04:00
|
|
|
keepAlive: false,
|
2016-02-18 18:48:39 -05:00
|
|
|
version: version.minecraftVersion
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
|
|
|
client.on('end', function () {
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
function resolve () {
|
|
|
|
count -= 1
|
|
|
|
if (count <= 0) done()
|
2015-10-01 20:02:54 -04:00
|
|
|
}
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
|
|
|
it('responds to ping requests', function (done) {
|
2017-07-13 08:03:52 -04:00
|
|
|
const server = mc.createServer({
|
2015-10-01 20:02:54 -04:00
|
|
|
'online-mode': false,
|
|
|
|
motd: 'test1234',
|
|
|
|
'max-players': 120,
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
server.on('listening', function () {
|
2015-10-01 20:02:54 -04:00
|
|
|
mc.ping({
|
|
|
|
host: '127.0.0.1',
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
}, function (err, results) {
|
|
|
|
if (err) return done(err)
|
|
|
|
assert.ok(results.latency >= 0)
|
|
|
|
assert.ok(results.latency <= 1000)
|
|
|
|
delete results.latency
|
2015-10-01 20:02:54 -04:00
|
|
|
assert.deepEqual(results, {
|
|
|
|
version: {
|
|
|
|
name: version.minecraftVersion,
|
|
|
|
protocol: version.version
|
|
|
|
},
|
|
|
|
players: {
|
|
|
|
max: 120,
|
|
|
|
online: 0,
|
|
|
|
sample: []
|
|
|
|
},
|
2018-09-24 16:07:34 -04:00
|
|
|
description: { text: 'test1234' }
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
|
|
|
server.close()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
server.on('close', done)
|
|
|
|
})
|
|
|
|
it('clients can log in and chat', function (done) {
|
2017-07-13 08:03:52 -04:00
|
|
|
const server = mc.createServer({
|
2015-10-01 20:02:54 -04:00
|
|
|
'online-mode': false,
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
const username = ['player1', 'player2']
|
|
|
|
let index = 0
|
|
|
|
server.on('login', function (client) {
|
|
|
|
assert.notEqual(client.id, null)
|
|
|
|
assert.strictEqual(client.username, username[index++])
|
|
|
|
broadcast(client.username + ' joined the game.')
|
|
|
|
client.on('end', function () {
|
|
|
|
broadcast(client.username + ' left the game.', client)
|
|
|
|
if (client.username === 'player2') server.close()
|
|
|
|
})
|
2015-10-01 20:02:54 -04:00
|
|
|
client.write('login', {
|
|
|
|
entityId: client.id,
|
|
|
|
levelType: 'default',
|
|
|
|
gameMode: 1,
|
|
|
|
dimension: 0,
|
|
|
|
difficulty: 2,
|
|
|
|
maxPlayers: server.maxPlayers,
|
|
|
|
reducedDebugInfo: 0
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
|
|
|
client.on('chat', function (packet) {
|
|
|
|
const message = '<' + client.username + '>' + ' ' + packet.message
|
|
|
|
broadcast(message)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
server.on('close', done)
|
|
|
|
server.on('listening', function () {
|
2017-07-13 08:03:52 -04:00
|
|
|
const player1 = mc.createClient({
|
2015-10-01 20:02:54 -04:00
|
|
|
username: 'player1',
|
|
|
|
host: '127.0.0.1',
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
player1.on('login', function (packet) {
|
|
|
|
assert.strictEqual(packet.gameMode, 1)
|
|
|
|
assert.strictEqual(packet.levelType, 'default')
|
|
|
|
assert.strictEqual(packet.dimension, 0)
|
|
|
|
assert.strictEqual(packet.difficulty, 2)
|
|
|
|
player1.once('chat', function (packet) {
|
|
|
|
assert.strictEqual(packet.message, '{"text":"player2 joined the game."}')
|
|
|
|
player1.once('chat', function (packet) {
|
|
|
|
assert.strictEqual(packet.message, '{"text":"<player2> hi"}')
|
|
|
|
player2.once('chat', fn)
|
|
|
|
function fn (packet) {
|
|
|
|
if (/<player2>/.test(packet.message)) {
|
|
|
|
player2.once('chat', fn)
|
|
|
|
return
|
2015-10-01 20:02:54 -04:00
|
|
|
}
|
2018-05-13 16:50:16 -04:00
|
|
|
assert.strictEqual(packet.message, '{"text":"<player1> hello"}')
|
|
|
|
player1.once('chat', function (packet) {
|
|
|
|
assert.strictEqual(packet.message, '{"text":"player2 left the game."}')
|
|
|
|
player1.end()
|
|
|
|
})
|
|
|
|
player2.end()
|
2015-10-01 20:02:54 -04:00
|
|
|
}
|
|
|
|
|
2018-09-24 16:07:34 -04:00
|
|
|
player1.write('chat', { message: 'hello' })
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
2018-09-24 16:07:34 -04:00
|
|
|
player2.write('chat', { message: 'hi' })
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
2017-07-13 08:03:52 -04:00
|
|
|
const player2 = mc.createClient({
|
2015-10-01 20:02:54 -04:00
|
|
|
username: 'player2',
|
|
|
|
host: '127.0.0.1',
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
2015-10-01 20:02:54 -04:00
|
|
|
|
2018-05-13 16:50:16 -04:00
|
|
|
function broadcast (message, exclude) {
|
|
|
|
let client
|
|
|
|
for (const clientId in server.clients) {
|
|
|
|
if (!server.clients.hasOwnProperty(clientId)) continue
|
2015-10-01 20:02:54 -04:00
|
|
|
|
2018-05-13 16:50:16 -04:00
|
|
|
client = server.clients[clientId]
|
2018-09-24 16:07:34 -04:00
|
|
|
if (client !== exclude) client.write('chat', { message: JSON.stringify({ text: message }), position: 0 })
|
2015-10-01 20:02:54 -04:00
|
|
|
}
|
|
|
|
}
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
|
|
|
it('kicks clients when invalid credentials', function (done) {
|
|
|
|
this.timeout(10000)
|
2017-07-13 08:03:52 -04:00
|
|
|
const server = mc.createServer({
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
let count = 4
|
|
|
|
server.on('connection', function (client) {
|
|
|
|
client.on('end', function (reason) {
|
|
|
|
resolve()
|
|
|
|
server.close()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
server.on('close', function () {
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
server.on('listening', function () {
|
|
|
|
resolve()
|
2017-07-13 08:03:52 -04:00
|
|
|
const client = mc.createClient({
|
2015-10-01 20:02:54 -04:00
|
|
|
username: 'lalalal',
|
2018-05-13 16:50:16 -04:00
|
|
|
host: '127.0.0.1',
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
client.on('end', function () {
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
function resolve () {
|
|
|
|
count -= 1
|
|
|
|
if (count <= 0) done()
|
2015-10-01 20:02:54 -04:00
|
|
|
}
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
|
|
|
it('gives correct reason for kicking clients when shutting down', function (done) {
|
2017-07-13 08:03:52 -04:00
|
|
|
const server = mc.createServer({
|
2015-10-01 20:02:54 -04:00
|
|
|
'online-mode': false,
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
let count = 2
|
|
|
|
server.on('login', function (client) {
|
|
|
|
client.on('end', function (reason) {
|
|
|
|
assert.strictEqual(reason, '{"text":"ServerShutdown"}')
|
|
|
|
resolve()
|
|
|
|
})
|
2015-10-01 20:02:54 -04:00
|
|
|
client.write('login', {
|
|
|
|
entityId: client.id,
|
|
|
|
levelType: 'default',
|
|
|
|
gameMode: 1,
|
|
|
|
dimension: 0,
|
|
|
|
difficulty: 2,
|
|
|
|
maxPlayers: server.maxPlayers,
|
|
|
|
reducedDebugInfo: 0
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
|
|
|
})
|
|
|
|
server.on('close', function () {
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
server.on('listening', function () {
|
2017-07-13 08:03:52 -04:00
|
|
|
const client = mc.createClient({
|
2015-10-01 20:02:54 -04:00
|
|
|
username: 'lalalal',
|
|
|
|
host: '127.0.0.1',
|
2016-02-23 13:37:47 -05:00
|
|
|
version: version.minecraftVersion,
|
2018-05-13 16:50:16 -04:00
|
|
|
port: PORT
|
|
|
|
})
|
|
|
|
client.on('login', function () {
|
|
|
|
server.close()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
function resolve () {
|
|
|
|
count -= 1
|
|
|
|
if (count <= 0) done()
|
2015-10-01 20:02:54 -04:00
|
|
|
}
|
2018-05-13 16:50:16 -04:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|