Initial progress
continuous-integration/drone/push Build is failing Details

This commit is contained in:
Jack Hadrill 2022-02-01 02:12:49 +00:00
parent 0f2f619e96
commit a93bfc182f
10 changed files with 209 additions and 15 deletions

36
package-lock.json generated
View File

@ -8,6 +8,10 @@
"name": "bennc-js", "name": "bennc-js",
"version": "1.0.0", "version": "1.0.0",
"license": "ISC", "license": "ISC",
"dependencies": {
"@types/websocket": "^1.0.5",
"romulus-js": "git+https://git.jacknet.io/TerribleCodeClub/romulus-js.git"
},
"devDependencies": { "devDependencies": {
"@types/jest": "^27.4.0", "@types/jest": "^27.4.0",
"jest": "^27.4.7", "jest": "^27.4.7",
@ -1078,8 +1082,7 @@
"node_modules/@types/node": { "node_modules/@types/node": {
"version": "17.0.13", "version": "17.0.13",
"resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.13.tgz", "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.13.tgz",
"integrity": "sha512-Y86MAxASe25hNzlDbsviXl8jQHb0RDvKt4c40ZJQ1Don0AAL0STLZSs4N+6gLEO55pedy7r2cLwS+ZDxPm/2Bw==", "integrity": "sha512-Y86MAxASe25hNzlDbsviXl8jQHb0RDvKt4c40ZJQ1Don0AAL0STLZSs4N+6gLEO55pedy7r2cLwS+ZDxPm/2Bw=="
"dev": true
}, },
"node_modules/@types/prettier": { "node_modules/@types/prettier": {
"version": "2.4.3", "version": "2.4.3",
@ -1093,6 +1096,14 @@
"integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==",
"dev": true "dev": true
}, },
"node_modules/@types/websocket": {
"version": "1.0.5",
"resolved": "https://registry.npmjs.org/@types/websocket/-/websocket-1.0.5.tgz",
"integrity": "sha512-NbsqiNX9CnEfC1Z0Vf4mE1SgAJ07JnRYcNex7AJ9zAVzmiGHmjKFEk7O4TJIsgv2B1sLEb6owKFZrACwdYngsQ==",
"dependencies": {
"@types/node": "*"
}
},
"node_modules/@types/yargs": { "node_modules/@types/yargs": {
"version": "16.0.4", "version": "16.0.4",
"resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz", "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz",
@ -5398,6 +5409,12 @@
"url": "https://github.com/sponsors/isaacs" "url": "https://github.com/sponsors/isaacs"
} }
}, },
"node_modules/romulus-js": {
"version": "1.0.0",
"resolved": "git+https://git.jacknet.io/TerribleCodeClub/romulus-js.git#8718556a6f976efb0bd30571f0699e925aafda82",
"hasInstallScript": true,
"license": "ISC"
},
"node_modules/run-parallel": { "node_modules/run-parallel": {
"version": "1.2.0", "version": "1.2.0",
"resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz",
@ -7212,8 +7229,7 @@
"@types/node": { "@types/node": {
"version": "17.0.13", "version": "17.0.13",
"resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.13.tgz", "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.13.tgz",
"integrity": "sha512-Y86MAxASe25hNzlDbsviXl8jQHb0RDvKt4c40ZJQ1Don0AAL0STLZSs4N+6gLEO55pedy7r2cLwS+ZDxPm/2Bw==", "integrity": "sha512-Y86MAxASe25hNzlDbsviXl8jQHb0RDvKt4c40ZJQ1Don0AAL0STLZSs4N+6gLEO55pedy7r2cLwS+ZDxPm/2Bw=="
"dev": true
}, },
"@types/prettier": { "@types/prettier": {
"version": "2.4.3", "version": "2.4.3",
@ -7227,6 +7243,14 @@
"integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==",
"dev": true "dev": true
}, },
"@types/websocket": {
"version": "1.0.5",
"resolved": "https://registry.npmjs.org/@types/websocket/-/websocket-1.0.5.tgz",
"integrity": "sha512-NbsqiNX9CnEfC1Z0Vf4mE1SgAJ07JnRYcNex7AJ9zAVzmiGHmjKFEk7O4TJIsgv2B1sLEb6owKFZrACwdYngsQ==",
"requires": {
"@types/node": "*"
}
},
"@types/yargs": { "@types/yargs": {
"version": "16.0.4", "version": "16.0.4",
"resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz", "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz",
@ -10390,6 +10414,10 @@
"glob": "^7.1.3" "glob": "^7.1.3"
} }
}, },
"romulus-js": {
"version": "git+https://git.jacknet.io/TerribleCodeClub/romulus-js.git#8718556a6f976efb0bd30571f0699e925aafda82",
"from": "romulus-js@git+https://git.jacknet.io/TerribleCodeClub/romulus-js.git"
},
"run-parallel": { "run-parallel": {
"version": "1.2.0", "version": "1.2.0",
"resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz",

View File

@ -15,16 +15,20 @@
"author": "Butlersaurus", "author": "Butlersaurus",
"license": "ISC", "license": "ISC",
"devDependencies": { "devDependencies": {
"typescript": "^4.5.5", "@types/jest": "^27.4.0",
"ts-standard": "^11.0.0",
"jest": "^27.4.7", "jest": "^27.4.7",
"ts-jest": "^27.1.3", "ts-jest": "^27.1.3",
"@types/jest": "^27.4.0" "ts-standard": "^11.0.0",
"typescript": "^4.5.5"
}, },
"jest": { "jest": {
"verbose": true, "verbose": true,
"transform": { "transform": {
"^.+\\.ts?$": "ts-jest" "^.+\\.ts?$": "ts-jest"
} }
},
"dependencies": {
"@types/websocket": "^1.0.5",
"romulus-js": "git+https://git.jacknet.io/TerribleCodeClub/romulus-js.git"
} }
} }

View File

@ -1,3 +1,17 @@
export function addNumbers (a: number, b: number): number { import { IMessageEvent } from 'websocket'
return a + b import { IncomingPacket } from './structures/server'
export function connect (url: string): void {
const webSocket = new WebSocket(url)
webSocket.binaryType = 'arraybuffer'
webSocket.onopen = onOpen
webSocket.onmessage = onMessage
}
function onOpen (): void {
console.log('Connected!')
}
function onMessage (event: IMessageEvent): void {
console.log(new IncomingPacket(event.data as Buffer))
} }

37
src/buffer-reader.ts Normal file
View File

@ -0,0 +1,37 @@
import { ByteLength } from './common'
export class BufferReader {
private readonly _data: Buffer
private _cursor: number
constructor (data: Buffer = Buffer.from([])) {
this._data = data
this._cursor = 0
}
get cursor (): number {
return this._cursor
}
set cursor (position: number) {
if (position < 0 || position > this._data.length) {
throw RangeError(`Cannot seek to ${this.cursor} of ${this._data.length} bytes.`)
}
this._cursor = position
}
readUInt16 (): number {
this.cursor += ByteLength.UInt16
return this._data.slice(this.cursor - ByteLength.UInt16, this.cursor).readInt16BE()
}
readUInt32 (): number {
this.cursor += ByteLength.UInt32
return this._data.slice(this.cursor - ByteLength.UInt32, this.cursor).readInt32BE()
}
readBuffer (len: number): Buffer {
this.cursor += len
return this._data.slice(this.cursor - len, this.cursor)
}
}

4
src/common.ts Normal file
View File

@ -0,0 +1,4 @@
export enum ByteLength {
UInt16 = 2,
UInt32 = 4
}

View File

@ -0,0 +1 @@
export { connect } from './bennc'

16
src/structures/server.ts Normal file
View File

@ -0,0 +1,16 @@
import { BufferReader } from '../buffer-reader'
export class IncomingPacket extends BufferReader {
messageType: number
senderId: number
length: number
data: Buffer
constructor (data: Buffer) {
super()
this.messageType = this.readUInt16()
this.senderId = this.readUInt32()
this.length = this.readUInt16()
this.data = this.readBuffer(this.length)
}
}

View File

@ -1,5 +0,0 @@
import { addNumbers } from '../src/bennc'
test('Add two numbers', () => {
expect(addNumbers(1, 2)).toBe(3)
})

View File

@ -0,0 +1,96 @@
import { BufferReader } from '../src/buffer-reader'
test('Read a UInt16.', () => {
// Given
const buffer = Buffer.from([0x30, 0x39])
// When
const smartBuffer = new BufferReader(buffer)
// Then
expect(smartBuffer.readUInt16()).toBe(12345)
})
test('Read a UInt32.', () => {
// Given
const buffer = Buffer.from([0x49, 0x96, 0x02, 0xD2])
// When
const smartBuffer = new BufferReader(buffer)
// Then
expect(smartBuffer.readUInt32()).toBe(1234567890)
})
test('Read a buffer.', () => {
// Given
const buffer = Buffer.from([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
// When
const smartBuffer = new BufferReader(buffer)
// Then
expect(smartBuffer.readBuffer(4)).toMatchObject(Buffer.from([0, 1, 2, 3]))
})
test('Cursor is correctly incremented after reading a UInt16.', () => {
// Given
const buffer = Buffer.from([0x30, 0x39, 0x1A, 0x85])
// When
const smartBuffer = new BufferReader(buffer)
// Then
expect(smartBuffer.readUInt16()).toBe(12345)
expect(smartBuffer.readUInt16()).toBe(6789)
})
test('Cursor is correctly incremented after reading a buffer.', () => {
// Given
const buffer = Buffer.from([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
// When
const smartBuffer = new BufferReader(buffer)
// Then
expect(smartBuffer.readBuffer(4)).toMatchObject(Buffer.from([0, 1, 2, 3]))
expect(smartBuffer.readBuffer(4)).toMatchObject(Buffer.from([4, 5, 6, 7]))
})
test('Cursor is correctly incremented after reading a UInt32.', () => {
// Given
const buffer = Buffer.from([0x49, 0x96, 0x02, 0xD2, 0x3A, 0xDE, 0x68, 0xB1])
// When
const smartBuffer = new BufferReader(buffer)
// Then
expect(smartBuffer.readUInt32()).toBe(1234567890)
expect(smartBuffer.readUInt32()).toBe(987654321)
})
test('Seek to position below 0 throws range error.', () => {
// Given
const buffer = Buffer.from([])
// When
const smartBuffer = new BufferReader(buffer)
// Then
expect(() => {
smartBuffer.cursor = -1
}).toThrow(RangeError)
})
test('Seek beyond buffer throws range error.', () => {
// Given
const buffer = Buffer.from([0, 1, 2, 3])
// When
const smartBuffer = new BufferReader(buffer)
// Then
expect(() => {
smartBuffer.cursor = 5
}).toThrow(RangeError)
})

View File

@ -1,5 +1,4 @@
{ {
"extends": "./tsconfig.json", "extends": "./tsconfig.json",
// "include": ["src", "tests"],
"exclude": [] "exclude": []
} }