From a270d16a129745adad516b4d57552bf5c6cd238c Mon Sep 17 00:00:00 2001 From: destruc7i0n Date: Sun, 16 Oct 2022 14:55:12 -0400 Subject: [PATCH 1/4] test on a running MC server --- .github/workflows/build.yml | 20 ---- .github/workflows/test.yml | 50 ++++++++++ global.d.ts | 1 + package.json | 3 +- src/MinecraftHandler.ts | 10 +- tests/MinecraftServer.test.ts | 117 ++++++++++++++++++++++ yarn.lock | 177 +++++++++++++++++++++++++++++++++- 7 files changed, 354 insertions(+), 24 deletions(-) delete mode 100644 .github/workflows/build.yml create mode 100644 .github/workflows/test.yml create mode 100644 global.d.ts create mode 100644 tests/MinecraftServer.test.ts diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml deleted file mode 100644 index 7b9f5111..00000000 --- a/.github/workflows/build.yml +++ /dev/null @@ -1,20 +0,0 @@ -name: Build -on: [push] - -jobs: - build: - runs-on: ubuntu-latest - - steps: - - uses: actions/checkout@v2 - - uses: actions/setup-node@v2 - with: - node-version: '16.x' - - name: Install packages - run: yarn install - - name: Type check - run: yarn type-check - - name: Test - run: yarn test --verbose - - name: Build - run: yarn build diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 00000000..07437e6e --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,50 @@ +name: Test +on: [push] + +jobs: + test: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v3 + - uses: actions/setup-node@v3 + with: + node-version: '16.x' + - name: Install packages + run: yarn install + - name: Type check + run: yarn type-check + - name: Test + run: yarn test --testPathIgnorePatterns 'MinecraftServer' + - name: Build + run: yarn build + + server: + runs-on: ubuntu-latest + needs: test + strategy: + matrix: + include: + # - javaVersion: 17 + # mcVersion: '1.18.2' + - javaVersion: 17 + mcVersion: '1.19' + - javaVersion: 17 + mcVersion: '1.19.2' + fail-fast: false + + steps: + - uses: actions/checkout@v3 + - uses: actions/setup-node@v3 + with: + node-version: '16.x' + - name: Setup Java JDK + uses: actions/setup-java@v3 + with: + distribution: 'temurin' + java-version: ${{ matrix.javaVersion }} + java-package: jre + - name: Test + run: yarn test -t 'MinecraftServer' + env: + MC_VERSION: ${{ matrix.mcVersion }} diff --git a/global.d.ts b/global.d.ts new file mode 100644 index 00000000..8b2e6968 --- /dev/null +++ b/global.d.ts @@ -0,0 +1 @@ +declare module 'minecraft-wrap'; \ No newline at end of file diff --git a/package.json b/package.json index 8bceaf8d..31f9b8f4 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,7 @@ "start": "node build/index.js", "build": "tsc", "type-check": "tsc --noEmit", - "test": "jest" + "test": "jest --verbose" }, "repository": { "type": "git", @@ -38,6 +38,7 @@ "@types/tail": "^2.2.1", "dotenv": "^16.0.0", "jest": "^27.5.1", + "minecraft-wrap": "^1.5.1", "ts-jest": "^27.1.3", "typescript": "^4.6.2" } diff --git a/src/MinecraftHandler.ts b/src/MinecraftHandler.ts index 7302c52d..d8f34d40 100644 --- a/src/MinecraftHandler.ts +++ b/src/MinecraftHandler.ts @@ -1,5 +1,7 @@ import fs from 'fs' import path from 'path' +import type { Server } from 'http' + import { Tail } from 'tail' import express from 'express' @@ -18,6 +20,7 @@ class MinecraftHandler { config: Config app: express.Application + server?: Server tail: Tail constructor(config: Config) { @@ -152,7 +155,7 @@ class MinecraftHandler { const port: number = Number(process.env.PORT) || this.config.PORT - this.app.listen(port, () => { + this.server = this.app.listen(port, () => { console.log('[INFO] Bot listening on *:' + port) if (!this.config.IS_LOCAL_FILE && this.config.SHOW_INIT_MESSAGE) { @@ -203,6 +206,11 @@ class MinecraftHandler { }) } + public _teardown() { + if (this.config.IS_LOCAL_FILE) this.tail.unwatch() + else if (this.server) this.server.close() + } + public init (callback: Callback) { if (this.config.IS_LOCAL_FILE) { this.initTail(callback) diff --git a/tests/MinecraftServer.test.ts b/tests/MinecraftServer.test.ts new file mode 100644 index 00000000..1e4362d7 --- /dev/null +++ b/tests/MinecraftServer.test.ts @@ -0,0 +1,117 @@ +import { Wrap, download } from 'minecraft-wrap' +import path from 'path' + +import Rcon from '../src/Rcon' +import MinecraftHandler, { LogLine } from '../src/MinecraftHandler' +import { defaultConfig } from './constants' + +const MC_VERSION = process.env['MC_VERSION'] +const MC_SERVER_PATH = path.resolve(`./tests/server/server-${MC_VERSION}`) +const MC_SERVER_JAR = path.join(MC_SERVER_PATH, `${MC_VERSION}.jar`) + +const RCON_PORT = 25575 +const RCON_PASSWORD = 'test' +const configWithServer = { + ...defaultConfig, + DEBUG: true, + IS_LOCAL_FILE: true, + LOCAL_FILE_PATH: path.join(MC_SERVER_PATH, 'logs/latest.log'), + MINECRAFT_SERVER_RCON_IP: '127.0.0.1', + MINECRAFT_SERVER_RCON_PORT: RCON_PORT, + MINECRAFT_SERVER_RCON_PASSWORD: RCON_PASSWORD +} + +const wrap = new Wrap(MC_SERVER_JAR, MC_SERVER_PATH) + +const serverProperties = { + 'online-mode': 'false', + 'level-type': 'FLAT', + 'enable-rcon': 'true', + 'rcon.password': RCON_PASSWORD, + 'rcon.port': RCON_PORT.toString(), +} + +describe(`MinecraftServer v${MC_VERSION}`, () => { + jest.setTimeout(1000 * 60 * 5) // 5 minutes + const serverLog = jest.fn((_line: string) => undefined) + // const logSpy = jest.spyOn(console, 'log') + + beforeAll((done) => { + console.log(`Downloading Minecraft ${MC_VERSION} server...`) + + wrap.on('line', (line: string) => { + console.log(`[${MC_VERSION} SERVER] ${line}`) + serverLog(line) + }) + + download(MC_VERSION, MC_SERVER_JAR, (err: any) => { + if (err) { + console.error(err) + done(err) + return + } + + console.log(`Starting Minecraft ${MC_VERSION} server...`) + wrap.startServer(serverProperties, (err: any) => { + if (err) { + console.error(err) + done(err) + return + } + done() + }) + }) + }) + + afterAll((done) => { + wrap.stopServer((err: any) => { + if (err) { + console.error(err) + } + // done() + wrap.deleteServerData((err: any) => { + if (err) { + console.log(err) + } + done(err) + }) + }) + }) + + // with 1.19.2 the name is surrounded with brackets rather than <> + + it('reads logs from Minecraft server', (done) => { + const handler = new MinecraftHandler(configWithServer) + // (handler as any) since private + const parseLogLineSpy = jest.spyOn(handler as any, 'parseLogLine') + + handler.init(async (data: LogLine) => { + // both the server and the handler should have received the line + expect(parseLogLineSpy).toHaveBeenCalledWith(expect.stringContaining('[Server] hello world!')) + expect(serverLog).toHaveBeenCalledWith(expect.stringContaining('[Server] hello world!')) + + console.log(`[${MC_VERSION} SHULKER]: ${data}`) + + handler._teardown() + done() + }) + + setTimeout(() => { + // simulate a chat message after a few seconds + wrap.writeServer('say hello world!\n') + }, 1000 * 10) + }) + + it('connects to Minecraft server via rcon', async () => { + const rcon = new Rcon(configWithServer.MINECRAFT_SERVER_RCON_IP, configWithServer.MINECRAFT_SERVER_RCON_PORT, configWithServer.DEBUG) + await rcon.auth(configWithServer.MINECRAFT_SERVER_RCON_PASSWORD) + + await rcon.command('say hello world from rcon!') + + await new Promise((resolve) => setTimeout(resolve, 1000 * 2)) + + expect(serverLog).toHaveBeenCalledWith(expect.stringContaining('[Rcon] hello world from rcon!')) + + rcon.close() + }) +}) \ No newline at end of file diff --git a/yarn.lock b/yarn.lock index 37f4aa6f..19100f14 100644 --- a/yarn.lock +++ b/yarn.lock @@ -801,6 +801,13 @@ dependencies: "@types/yargs-parser" "*" +"@types/yauzl@^2.9.1": + version "2.10.0" + resolved "https://registry.npmjs.org/@types/yauzl/-/yauzl-2.10.0.tgz#b3248295276cf8c6f153ebe6a9aba0c988cb2599" + integrity sha512-Cn6WYCm0tXv8p6k+A8PvbDG763EDpBoTzHdA+Q/MF6H3sapGjCm9NzoaJncJS9tUKSuCoDs9XHxYYsQDgxR6kw== + dependencies: + "@types/node" "*" + abab@^2.0.3, abab@^2.0.5: version "2.0.5" resolved "https://registry.npmjs.org/abab/-/abab-2.0.5.tgz#c0b678fb32d60fc1219c784d6a826fe385aeb79a" @@ -875,6 +882,11 @@ ansi-styles@^5.0.0: resolved "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz#07449690ad45777d1924ac2abb2fc8895dba836b" integrity sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA== +any-promise@^1.0.0: + version "1.3.0" + resolved "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz#abc6afeedcea52e809cdc0376aed3ce39635d17f" + integrity sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A== + anymatch@^3.0.3: version "3.1.2" resolved "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz#c0557c096af32f106198f4f4e2a383537e378716" @@ -1034,6 +1046,11 @@ bser@2.1.1: dependencies: node-int64 "^0.4.0" +buffer-crc32@~0.2.3: + version "0.2.13" + resolved "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz#0d333e3f00eac50aa1454abd30ef8c2a5d9a7242" + integrity sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ== + buffer-from@^1.0.0: version "1.1.2" resolved "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" @@ -1343,6 +1360,13 @@ encodeurl@~1.0.2: resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= +end-of-stream@^1.1.0: + version "1.4.4" + resolved "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" + integrity sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q== + dependencies: + once "^1.4.0" + error-ex@^1.3.1: version "1.3.2" resolved "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" @@ -1350,6 +1374,18 @@ error-ex@^1.3.1: dependencies: is-arrayish "^0.2.1" +es6-promise@^4.0.3: + version "4.2.8" + resolved "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.8.tgz#4eb21594c972bc40553d276e510539143db53e0a" + integrity sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w== + +es6-promisify@^5.0.0: + version "5.0.0" + resolved "https://registry.npmjs.org/es6-promisify/-/es6-promisify-5.0.0.tgz#5109d62f3e56ea967c4b63505aef08291c8a5203" + integrity sha512-C+d6UdsYDk0lMebHNR4S2NybQMMngAOnOwYBQjTOiv0MkoJMP0Myw2mgpDLBcpfCmRLxyFqYhS/CfOENq4SJhQ== + dependencies: + es6-promise "^4.0.3" + escalade@^3.1.1: version "3.1.1" resolved "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" @@ -1468,6 +1504,17 @@ express@^4.17.3: utils-merge "1.0.1" vary "~1.1.2" +extract-zip@^2.0.0: + version "2.0.1" + resolved "https://registry.npmjs.org/extract-zip/-/extract-zip-2.0.1.tgz#663dca56fe46df890d5f131ef4a06d22bb8ba13a" + integrity sha512-GDhU9ntwuKyGXdZBUgTIe+vXnWj0fppUEtMDL0+idd5Sta8TGpHssn/eusA9mrPr9qNDym6SxAYZjNvCn/9RBg== + dependencies: + debug "^4.1.1" + get-stream "^5.1.0" + yauzl "^2.10.0" + optionalDependencies: + "@types/yauzl" "^2.9.1" + fast-json-stable-stringify@2.x, fast-json-stable-stringify@^2.0.0: version "2.1.0" resolved "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" @@ -1485,6 +1532,13 @@ fb-watchman@^2.0.0: dependencies: bser "2.1.1" +fd-slicer@~1.1.0: + version "1.1.0" + resolved "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz#25c7c89cb1f9077f8891bbe61d8f390eae256f1e" + integrity sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g== + dependencies: + pend "~1.2.0" + fill-range@^7.0.1: version "7.0.1" resolved "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" @@ -1513,6 +1567,11 @@ find-up@^4.0.0, find-up@^4.1.0: locate-path "^5.0.0" path-exists "^4.0.0" +flatmap@0.0.3: + version "0.0.3" + resolved "https://registry.npmjs.org/flatmap/-/flatmap-0.0.3.tgz#1f18a4d938152d495965f9c958d923ab2dd669b4" + integrity sha512-OuR+o7kHVe+x9RtIujPay7Uw3bvDZBZFSBXClEphZuSDLmZTqMdclasf4vFSsogC8baDz0eaC2NdO/2dlXHBKQ== + follow-redirects@^1.14.8: version "1.14.9" resolved "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.9.tgz#dd4ea157de7bfaf9ea9b3fbd85aa16951f78d8d7" @@ -1576,6 +1635,13 @@ get-package-type@^0.1.0: resolved "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz#8de2d803cff44df3bc6c456e6668b36c3926e11a" integrity sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q== +get-stream@^5.1.0: + version "5.2.0" + resolved "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz#4966a1795ee5ace65e706c4b7beb71257d6e22d3" + integrity sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA== + dependencies: + pump "^3.0.0" + get-stream@^6.0.0: version "6.0.1" resolved "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" @@ -2343,6 +2409,11 @@ makeerror@1.0.12: dependencies: tmpl "1.0.5" +md5-file@^4.0.0: + version "4.0.0" + resolved "https://registry.npmjs.org/md5-file/-/md5-file-4.0.0.tgz#f3f7ba1e2dd1144d5bf1de698d0e5f44a4409584" + integrity sha512-UC0qFwyAjn4YdPpKaDNw6gNxRf7Mcx7jC1UGCY4boCzgvU2Aoc1mOGzTtrjjLKhM5ivsnhoKpQVxKPp+1j1qwg== + media-typer@0.3.0: version "0.3.0" resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" @@ -2417,6 +2488,29 @@ mimic-fn@^2.1.0: resolved "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== +minecraft-folder-path@^1.1.0: + version "1.2.0" + resolved "https://registry.npmjs.org/minecraft-folder-path/-/minecraft-folder-path-1.2.0.tgz#08ea450bfb20dbb02cf6e1470864e2f0d652e477" + integrity sha512-qaUSbKWoOsH9brn0JQuBhxNAzTDMwrOXorwuRxdJKKKDYvZhtml+6GVCUrY5HRiEsieBEjCUnhVpDuQiKsiFaw== + +minecraft-wrap@^1.5.1: + version "1.5.1" + resolved "https://registry.npmjs.org/minecraft-wrap/-/minecraft-wrap-1.5.1.tgz#844391b5451aa7e0eb04dd105b7cbec693b24fbc" + integrity sha512-7DZ2WhrcRD3fUMau84l9Va0KWzV92SHNdB7mnNdNhgXID2aW6pjWuYPZi8MepEBemA4XKKdnDx7HmhTbkoiR8A== + dependencies: + debug "^4.1.1" + es6-promisify "^5.0.0" + extract-zip "^2.0.0" + flatmap "0.0.3" + md5-file "^4.0.0" + minecraft-folder-path "^1.1.0" + mkdirp "^0.5.1" + mz "^2.7.0" + node-fetch "^2.6.1" + promise-queue "^2.2.5" + rimraf "^3.0.2" + yggdrasil "^1.1.1" + minimatch@^3.0.4: version "3.0.4" resolved "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" @@ -2429,6 +2523,18 @@ minimist@^1.2.5: resolved "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== +minimist@^1.2.6: + version "1.2.7" + resolved "https://registry.npmjs.org/minimist/-/minimist-1.2.7.tgz#daa1c4d91f507390437c6a8bc01078e7000c4d18" + integrity sha512-bzfL1YUZsP41gmu/qjrEk0Q6i2ix/cVeAhbCbqH9u3zYutS1cLg00qhrD0M2MVdCcx4Sc0UpP2eBWo9rotpq6g== + +mkdirp@^0.5.1: + version "0.5.6" + resolved "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz#7def03d2432dcae4ba1d611445c48396062255f6" + integrity sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw== + dependencies: + minimist "^1.2.6" + ms@2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" @@ -2444,6 +2550,15 @@ ms@2.1.3: resolved "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== +mz@^2.7.0: + version "2.7.0" + resolved "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz#95008057a56cafadc2bc63dde7f9ff6955948e32" + integrity sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q== + dependencies: + any-promise "^1.0.0" + object-assign "^4.0.1" + thenify-all "^1.0.0" + natural-compare@^1.4.0: version "1.4.0" resolved "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" @@ -2488,6 +2603,11 @@ nwsapi@^2.2.0: resolved "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.0.tgz#204879a9e3d068ff2a55139c2c772780681a38b7" integrity sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ== +object-assign@^4.0.1: + version "4.1.1" + resolved "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" + integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== + on-finished@~2.3.0: version "2.3.0" resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" @@ -2495,7 +2615,7 @@ on-finished@~2.3.0: dependencies: ee-first "1.1.1" -once@^1.3.0: +once@^1.3.0, once@^1.3.1, once@^1.4.0: version "1.4.0" resolved "https://registry.npmjs.org/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" integrity sha1-WDsap3WWHUsROsF9nFC6753Xa9E= @@ -2585,6 +2705,11 @@ path-to-regexp@0.1.7: resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" integrity sha1-32BBeABfUi8V60SQ5yR6G/qmf4w= +pend@~1.2.0: + version "1.2.0" + resolved "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz#7a57eb550a6783f9115331fcf4663d5c8e007a50" + integrity sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg== + picocolors@^1.0.0: version "1.0.0" resolved "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" @@ -2631,6 +2756,11 @@ pretty-format@^27.5.1: ansi-styles "^5.0.0" react-is "^17.0.1" +promise-queue@^2.2.5: + version "2.2.5" + resolved "https://registry.npmjs.org/promise-queue/-/promise-queue-2.2.5.tgz#2f6f5f7c0f6d08109e967659c79b88a9ed5e93b4" + integrity sha512-p/iXrPSVfnqPft24ZdNNLECw/UrtLTpT3jpAAMzl/o5/rDsGCPo3/CQS2611flL6LkoEJ3oQZw7C8Q80ZISXRQ== + prompts@^2.0.1: version "2.4.2" resolved "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz#7b57e73b3a48029ad10ebd44f74b01722a4cb069" @@ -2652,6 +2782,14 @@ psl@^1.1.33: resolved "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz#9326f8bcfb013adcc005fdff056acce020e51c24" integrity sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ== +pump@^3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz#b4a2116815bde2f4e1ea602354e8c75565107a64" + integrity sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww== + dependencies: + end-of-stream "^1.1.0" + once "^1.3.1" + punycode@^2.1.1: version "2.1.1" resolved "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec" @@ -2712,7 +2850,7 @@ resolve@^1.20.0: is-core-module "^2.2.0" path-parse "^1.0.6" -rimraf@^3.0.0: +rimraf@^3.0.0, rimraf@^3.0.2: version "3.0.2" resolved "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== @@ -2949,6 +3087,20 @@ test-exclude@^6.0.0: glob "^7.1.4" minimatch "^3.0.4" +thenify-all@^1.0.0: + version "1.6.0" + resolved "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz#1a1918d402d8fc3f98fbf234db0bcc8cc10e9726" + integrity sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA== + dependencies: + thenify ">= 3.1.0 < 4" + +"thenify@>= 3.1.0 < 4": + version "3.3.1" + resolved "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz#8932e686a4066038a016dd9e2ca46add9838a95f" + integrity sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw== + dependencies: + any-promise "^1.0.0" + throat@^6.0.1: version "6.0.1" resolved "https://registry.npmjs.org/throat/-/throat-6.0.1.tgz#d514fedad95740c12c2d7fc70ea863eb51ade375" @@ -3073,6 +3225,11 @@ utils-merge@1.0.1: resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" integrity sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM= +uuid@^8.2.0: + version "8.3.2" + resolved "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" + integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== + v8-to-istanbul@^8.1.0: version "8.1.0" resolved "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-8.1.0.tgz#0aeb763894f1a0a1676adf8a8b7612a38902446c" @@ -3236,6 +3393,22 @@ yargs@^16.2.0: y18n "^5.0.5" yargs-parser "^20.2.2" +yauzl@^2.10.0: + version "2.10.0" + resolved "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz#c7eb17c93e112cb1086fa6d8e51fb0667b79a5f9" + integrity sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g== + dependencies: + buffer-crc32 "~0.2.3" + fd-slicer "~1.1.0" + +yggdrasil@^1.1.1: + version "1.7.0" + resolved "https://registry.npmjs.org/yggdrasil/-/yggdrasil-1.7.0.tgz#bfe9fabfd3600078cd1fa0d4445bf6fc6bf46149" + integrity sha512-QBIo5fiNd7688G3FqXXYGr36uyrYzczlNuzpWFy2zL3+R+3KT2lF+wFxm51synfA3l3z6IBiGOc1/EVXWCYY1Q== + dependencies: + node-fetch "^2.6.1" + uuid "^8.2.0" + zod@^3.11.6: version "3.11.6" resolved "https://registry.npmjs.org/zod/-/zod-3.11.6.tgz#e43a5e0c213ae2e02aefe7cb2b1a6fa3d7f1f483" From 1b7b36edf2151476f83adc5e2c8f2f996b9f35ac Mon Sep 17 00:00:00 2001 From: destruc7i0n Date: Sun, 16 Oct 2022 14:56:55 -0400 Subject: [PATCH 2/4] install packages --- .github/workflows/test.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 07437e6e..4f3125ad 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -44,6 +44,8 @@ jobs: distribution: 'temurin' java-version: ${{ matrix.javaVersion }} java-package: jre + - name: Install packages + run: yarn install - name: Test run: yarn test -t 'MinecraftServer' env: From 13ba330281ed4b69d7053a4f9d36837f5323f6d6 Mon Sep 17 00:00:00 2001 From: destruc7i0n Date: Sun, 16 Oct 2022 15:16:44 -0400 Subject: [PATCH 3/4] reduce timeout --- tests/MinecraftServer.test.ts | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/tests/MinecraftServer.test.ts b/tests/MinecraftServer.test.ts index 1e4362d7..e7eba13a 100644 --- a/tests/MinecraftServer.test.ts +++ b/tests/MinecraftServer.test.ts @@ -32,7 +32,7 @@ const serverProperties = { } describe(`MinecraftServer v${MC_VERSION}`, () => { - jest.setTimeout(1000 * 60 * 5) // 5 minutes + jest.setTimeout(1000 * 60) // 1 minutes const serverLog = jest.fn((_line: string) => undefined) // const logSpy = jest.spyOn(console, 'log') @@ -85,13 +85,14 @@ describe(`MinecraftServer v${MC_VERSION}`, () => { // (handler as any) since private const parseLogLineSpy = jest.spyOn(handler as any, 'parseLogLine') - handler.init(async (data: LogLine) => { + handler.init((data: LogLine) => { + console.log(`[${MC_VERSION} SHULKER]:`, data) + // both the server and the handler should have received the line + expect(data).toBeNull() expect(parseLogLineSpy).toHaveBeenCalledWith(expect.stringContaining('[Server] hello world!')) expect(serverLog).toHaveBeenCalledWith(expect.stringContaining('[Server] hello world!')) - console.log(`[${MC_VERSION} SHULKER]: ${data}`) - handler._teardown() done() }) From a852cd3914260a2801de8f5235d55fba3d479eb7 Mon Sep 17 00:00:00 2001 From: destruc7i0n Date: Sun, 16 Oct 2022 15:26:23 -0400 Subject: [PATCH 4/4] set timeout minutes --- .github/workflows/test.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 4f3125ad..f4e8f5f0 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -22,6 +22,7 @@ jobs: server: runs-on: ubuntu-latest needs: test + timeout-minutes: 5 strategy: matrix: include: